Copyright (c) 2012 by Delphix. All rights reserved.
Copyright (c) 2013 by Saso Kiselkov. All rights reserved.
The contents of this file are subject to the terms of the Common Development
and Distribution License (the "License"). You may not use this file except
in compliance with the License. You can obtain a copy of the license at
usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing.
See the License for the specific language governing permissions and
limitations under the License. When distributing Covered Code, include this
CDDL HEADER in each file and include the License file at
usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this
CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your
own identifying information:
Portions Copyright [yyyy] [name of copyright owner]
ZFS pool on-disk format versions are specified via "features" which replace the old on-disk format numbers (the last supported on-disk format number is 28). To enable a feature on a pool use the upgrade subcommand of the zpool(1M) command, or set the feature@feature_name property to enabled.
The pool format does not affect file system version compatibility or the ability to send file systems between pools.
Since most features can be enabled independently of each other the on-disk format of the pool is specified by the set of all features marked as active on the pool. If the pool was created by another software version this set may include unsupported features.
Every feature has a guid of the form com.example:feature_name. The reverse DNS name ensures that the feature's guid is unique across all ZFS implementations. When unsupported features are encountered on a pool they will be identified by their guids. Refer to the documentation for the ZFS implementation that created the pool for information about those features.
Each supported feature also has a short name. By convention a feature's short name is the portion of its guid which follows the ':' (e.g. com.example:feature_name would have the short name feature_name), however a feature's short name may differ across ZFS implementations if following the convention would result in name conflicts.
Features can be in one of three states: active
This feature's on-disk format changes are in effect on the pool. Support for this feature is required to import the pool in read-write mode. If this feature is not read-only compatible, support is also required to import the pool in read-only mode (see "Read-only compatibility").
An administrator has marked this feature as enabled on the pool, but the feature's on-disk format changes have not been made yet. The pool can still be imported by software that does not support this feature, but changes may be made to the on-disk format at any time which will move the feature to the active state. Some features may support returning to the enabled state after becoming active. See feature-specific documentation for details.
This feature's on-disk format changes have not been made and will not be made unless an administrator moves the feature to the enabled state. Features cannot be disabled once they have been enabled.
The state of supported features is exposed through pool properties of the form feature@short_name.
Some features may make on-disk format changes that do not interfere with other software's ability to read from the pool. These features are referred to as "read-only compatible". If all unsupported features on a pool are read-only compatible, the pool can be imported in read-only mode by setting the readonly property during import (see zpool(1M) for details on importing pools).
For each unsupported feature enabled on an imported pool a pool property named unsupported@feature_guid will indicate why the import was allowed despite the unsupported feature. Possible values for this property are: inactive
The feature is in the enabled state and therefore the pool's on-disk format is still compatible with software that does not support this feature.
The feature is read-only compatible and the pool has been imported in read-only mode.
Some features depend on other features being enabled in order to function properly. Enabling a feature will automatically enable any features it depends on.
The following features are supported on this system: async_destroy
GUID com.delphix:async_destroy |
READ-ONLY COMPATIBLE yes |
DEPENDENCIES none |
GUID com.delphix:empty_bpobj |
READ-ONLY COMPATIBLE yes |
DEPENDENCIES none |
GUID org.illumos:lz4_compress |
READ-ONLY COMPATIBLE no |
DEPENDENCIES none |