Class CIM_StoragePool
extends CIM_ResourcePool

A StoragePool is a conglomeration of storage capacity for the purpose of assignment and allocation based on service characteristics, such as location, available space or other criteria (for example, cost per megabyte or hardware ownership). A StoragePool is managed within the scope of a particular System. StoragePools may consist of component StoragePools or StorageExtents. StorageExtents that belong to the StoragePool have a Component relationship to the StoragePool. StorageExtents/StoragePools that are elements of a pool have their available space aggregated into the pool. StoragePools, StorageVolumes and LogicalDisks may be created from StoragePools. This is indicated by the AllocatedFromStoragePool association. StoragePool is scoped to a system by the HostedStoragePool association.

Table of Contents
Hierarchy
Direct Known Subclasses
Class Qualifiers
Class Properties
Class Methods


Class Hierarchy

CIM_ManagedElement
   |
   +--CIM_ManagedSystemElement
   |
   +--CIM_LogicalElement
   |
   +--CIM_ResourcePool
   |
   +--CIM_StoragePool

Direct Known Subclasses

Class Qualifiers

NameData TypeValue
DescriptionstringA StoragePool is a conglomeration of storage capacity for the purpose of assignment and allocation based on service characteristics, such as location, available space or other criteria (for example, cost per megabyte or hardware ownership). A StoragePool is managed within the scope of a particular System. StoragePools may consist of component StoragePools or StorageExtents. StorageExtents that belong to the StoragePool have a Component relationship to the StoragePool. StorageExtents/StoragePools that are elements of a pool have their available space aggregated into the pool. StoragePools, StorageVolumes and LogicalDisks may be created from StoragePools. This is indicated by the AllocatedFromStoragePool association. StoragePool is scoped to a system by the HostedStoragePool association.
UMLPackagePathstringCIM::Device::StorageServices
Versionstring2.27.0

Class Properties

Local Class Properties

NameData TypeDefault ValueQualifiers
NameData TypeValue
CapacityInMigratingSourceuint64
DescriptionstringThe total capacity of extents in migrating out from this storage pool
Experimentalbooleantrue
UnitsstringBytes
CapacityInMigratingTargetuint64
DescriptionstringThe total capacity of extents in migrating into this storage pool
Experimentalbooleantrue
UnitsstringBytes
InstanceIDstring
DescriptionstringWithin the scope of the instantiating Namespace, InstanceID opaquely and uniquely identifies an instance of this class. In order to ensure uniqueness within the NameSpace, the value of InstanceID SHOULD be constructed using the following 'preferred' algorithm: <OrgID>:<LocalID> Where <OrgID> and <LocalID> are separated by a colon ':', and where <OrgID> MUST include a copyrighted, trademarked or otherwise unique name that is owned by the business entity creating/defining the InstanceID, or is a registered ID that is assigned to the business entity by a recognized global authority (This is similar to the <Schema Name>_<Class Name> structure of Schema class names.) In addition, to ensure uniqueness <OrgID> MUST NOT contain a colon (':'). When using this algorithm, the first colon to appear in InstanceID MUST appear between <OrgID> and <LocalID>. <LocalID> is chosen by the business entity and SHOULD not be re-used to identify different underlying (real-world) elements. If the above 'preferred' algorithm is not used, the defining entity MUST assure that the resultant InstanceID is not re-used across any InstanceIDs produced by this or other providers for this instance's NameSpace. For DMTF defined instances, the 'preferred' algorithm MUST be used with the <OrgID> set to 'CIM'.
Keybooleantrue
OverridestringInstanceID
LowSpaceWarningThresholduint16
DescriptionstringLowSpaceWarningThreshold simplifies the creation of a pool specific Indication based on RemainingManagedSpace <= (TotalManagedSpace*LowSpaceWarningThreshold)/100. One example client for an Indication based on this property is a delta copy implementation where the pool enables continuous, variable space consumption for the delta storage. Another example client for an Indication based on this property is a provisioning manager implementing a policy for adding storage to a pool when it becomes low.
Experimentalbooleantrue
MaxValuesint64100
MinValuesint640
ModelCorrespondencestringCIM_StoragePool.RemainingManagedSpace
PUnitstringpercent
UnitsstringPercentage
OtherUsageDescriptionstring
DescriptionstringPopulated when "Usage" has the value of "Other".
Experimentalbooleantrue
ModelCorrespondencestringCIM_StoragePool.Usage
PoolIDstring
DescriptionstringA unique name in the context of the System that identifies this pool.
MaxLenuint32256
ModelCorrespondencestringCIM_ResourceAllocationSettingData.PoolId
OverridestringPoolID
Requiredbooleantrue
Primordialbooleanfalse
DescriptionstringIf true, "Primordial" indicates that this StoragePool is the base from which storage capacity is drawn and returned in the activity of storage management. Being primordial means that this StoragePool shall not be created or deleted by consumers of this model. However, other actions, modeled or not, may affect the characteristics or size of primordial StoragePools. If false, "Primordial" indicated that the StoragePool, a concrete Storage Pool, is subject to storage services functions. This distinction is important because higher-level StoragePools may be assembled using the Component or AllocatedFromStoragePool associations. Although the higher-level abstractions can be created and deleted, the most basic, (i.e. primordial), hardware-based StoragePools cannot. They are physically realized as part of the System, or are actually managed by some other System and imported as if they were physically realized.
OverridestringPrimordial
RemainingManagedSpaceuint64
DescriptionstringThe remaining usable capacity after the allocation of StorageVolumes, LogicalDisks, or child Storage Pools. This property is maintained here to provide efficient access to this information. However, note that it is possible to compute RemainingManagedSpace as (TotalManagedSpace minus the sum of SpaceConsumed from all of the AllocatedFromStoragePool references from this StoragePool). Note that SpaceConsumed remains useful to determine the amount of capacity consumed by a particular allocated element.
ModelCorrespondencestringCIM_StoragePool.TotalManagedSpace, CIM_AllocatedFromStoragePool.SpaceConsumed
PUnitstringbyte
Requiredbooleantrue
UnitsstringBytes
SpaceLimituint64
DescriptionstringThe capacity of the storage allocated to the pool when SpaceLimitDetermination has the value 3 (Quota) or 4 (Limitless) or is set to the value of TotalManagedSpace if SpaceLimitDetermination has the value 2 (Allocated).
Experimentalbooleantrue
PUnitstringbyte
UnitsstringBytes
SpaceLimitDeterminationuint16
DescriptionstringThis property is the Subsystem ID if the array or virtualizer supports Subsystem IDs. If they are supported they would be required on volume creation.
Experimentalbooleantrue
ValueMapstring2, 3, 4
ValuesstringAllocated, Quote, Limitless
ThinProvisionMetaDataSpaceuint64
DescriptionstringThe size of metadata consumed by this storage pool. Only defined if the pool is thin provisioned.
Experimentalbooleantrue
PUnitstringbyte
UnitsstringBytes
TotalManagedSpaceuint64
DescriptionstringThe total amount of capacity usable for the allocation of StorageVolumes, LogicalDisks, or child Storage Pools. For primordial Storage Pools, this capacity reflects the usable capacity of Disk Drives or LUNs, for example, to the owning storage device or application. For example, in storage array, a primordial Storage Pool's TotalManagedSpace does not include metadata such as the disk label area and absolute disk drive capacity lost in disk formatting. For concrete Storage Pools, the same applies, but the metadata not included in TotalManagedSpace is consumed in virtualization like RAID and concatenation. Concrete Storage Pool may also be simple reserve of capacity. In such a case, no capacity may be lost in formation of the Storage Pool. Conceptually TotalManagedSpace is the sum of all storage known via AssociatedComponentExtent associations to underlying StorageExtents. However, note some of these underlying storage may not be modeled by the instrumentation.
ModelCorrespondencestringCIM_StoragePool.RemainingManagedSpace
PUnitstringbyte
UnitsstringBytes
Usageuint16
DescriptionstringIndicates the intended usage or any restrictions that may have been imposed on the usage of this component. For example, a storage pool may be reserved for use by the block server. In that case the Usage of the storage pool is marked as "Reserved for the ComputerSystem". In the case of "Other", see OtherUsageDescription for more information.
Experimentalbooleantrue
ModelCorrespondencestringCIM_StoragePool.OtherUsageDescription
ValueMapstring1, 2, 3, 4, 5, 6, 7, 8, .., 32768..65535
ValuesstringOther, Unrestricted, Reserved for ComputerSystem (the block server), Reserved as a Delta Replica Container, Reserved for Migration Services, Reserved for Local Replication Services, Reserved for Remote Replication Services, Reserved for Sparing, DMTF Reserved, Vendor Reserved
ClientSettableUsageuint16[]
DescriptionstringIndicates which values from the "Usage" valuemap can be manipulated by a client using the method "StorageConfigurationService.RequestUsageChange".
Experimentalbooleantrue
ModelCorrespondencestringCIM_StoragePool.Usage

Inherited Properties

NameData TypeClass Origin
AllocationUnitsstringCIM_ResourcePool
Capacityuint64CIM_ResourcePool
CaptionstringCIM_ManagedElement
CommunicationStatusuint16CIM_ManagedSystemElement
ConsumedResourceUnitsstringCIM_ResourcePool
CurrentlyConsumedResourceuint64CIM_ResourcePool
DescriptionstringCIM_ManagedElement
DetailedStatusuint16CIM_ManagedSystemElement
ElementNamestringCIM_ManagedElement
Generationuint64CIM_ManagedElement
HealthStateuint16CIM_ManagedSystemElement
InstallDatedatetimeCIM_ManagedSystemElement
MaxConsumableResourceuint64CIM_ResourcePool
NamestringCIM_ManagedSystemElement
OperatingStatusuint16CIM_ManagedSystemElement
OtherResourceTypestringCIM_ResourcePool
PrimaryStatusuint16CIM_ManagedSystemElement
Reserveduint64CIM_ResourcePool
ResourceSubTypestringCIM_ResourcePool
ResourceTypeuint16CIM_ResourcePool
StatusstringCIM_ManagedSystemElement
OperationalStatusuint16[]CIM_ManagedSystemElement
StatusDescriptionsstring[]CIM_ManagedSystemElement

Class Methods

Local Class Methods

GetSupportedSizes (uint32)

Method Qualifiers (GetSupportedSizes)

NameData TypeValue
DescriptionstringFor pools that that support a range of sizes for volume or pool creation, this method can be used to retrieve the supported range. Note that different pool implementations may support either or both the GetSupportedSizes and GetSupportedSizeRanges methods at different times, depending on Pool configuration. Also note that the advertised sizes may change after the call due to requests from other clients. If the pool currently only supports discrete sizes, then the return value will be set to 1.
ValueMapstring0, 1, 2, 3
ValuesstringMethod completed OK, Method not supported, Use GetSupportedSizes instead, Invalid Element Type

Method Parameters (GetSupportedSizes)

NameTypeQualifiers
NameData TypeValue
ElementTypeuint16
DescriptionstringThe type of element for which supported sizes are reported. The Thin Provision values are only supported when the Thin Provisioning Profile is supported; the resulting StorageVolues/LogicalDisk shall have ThinlyPprovisioned set to true.
Experimentalbooleantrue
INbooleantrue
ValueMapstring2, 3, 4, 5, 6
ValuesstringStorage Pool, Storage Volume, Logical Disk, Thin Provisioned Volume, Thin Provisioned Logical Disk
Sizesuint64[]
DescriptionstringList of supported sizes for a Volume/Pool creation or modification.
INbooleantrue
OUTbooleantrue
PUnitstringbyte
UnitsstringBytes
Goal REF CIM_StorageSetting
DescriptionstringThe StorageSetting for which supported sizes should be reported for.
INbooleantrue

GetSupportedSizeRange (uint32)

Method Qualifiers (GetSupportedSizeRange)

NameData TypeValue
DescriptionstringFor pools that that support a range of sizes for volume or pool creation, this method can be used to retrieve the supported range. Note that different pool implementations may support either or both the GetSupportedSizes and GetSupportedSizeRanges methods at different times, depending on Pool configuration. Also note that the advertised sizes may change after the call due to requests from other clients. If the pool currently only supports discrete sizes, then the return value will be set to 1.
ValueMapstring0, 1, 2, 3
ValuesstringMethod completed OK, Method not supported, Use GetSupportedSizes instead, Invalid Element Type

Method Parameters (GetSupportedSizeRange)

NameTypeQualifiers
NameData TypeValue
ElementTypeuint16
DescriptionstringThe type of element for which supported size ranges are reported. The Thin Provision values are only supported when the Thin Provisioning Profile is supported; the resulting StorageVolues/LogicalDisk shall have ThinlyPprovisioned set to true.
Experimentalbooleantrue
INbooleantrue
ValueMapstring2, 3, 4, 5, 6
ValuesstringStorage Pool, Storage Volume, Logical Disk, Thin Provisioned Volume, Thin Provisioned Logical Disk
MaximumVolumeSizeuint64
DescriptionstringThe maximum size for a volume/pool in bytes.
INbooleantrue
OUTbooleantrue
PUnitstringbyte
UnitsstringBytes
MinimumVolumeSizeuint64
DescriptionstringThe minimum size for a volume/pool in bytes.
INbooleantrue
OUTbooleantrue
PUnitstringbyte
UnitsstringBytes
VolumeSizeDivisoruint64
DescriptionstringA volume/pool size must be a multiple of this value which is specified in bytes.
INbooleantrue
OUTbooleantrue
PUnitstringbyte
UnitsstringBytes
Goal REF CIM_StorageSetting
DescriptionstringThe StorageSetting for which supported size ranges should be reported for.
INbooleantrue

GetAvailableExtents (uint32)

Method Qualifiers (GetAvailableExtents)

NameData TypeValue
DescriptionstringThis method can be used to retrieve a list of available Extents that may be used in the creation or modification of a StoragePool, StorageVolume, or LogicalDisk. The GetAvailableExtents method MUST return the Extents from the set of Component Extents of the Pool on which the method is being invoked. The returned Extents are available at the time the method returns. There is no guarantee that the same Extents will be available later. This method MUST return the Extents that are not being used as supporting capacity for any other Pools, Volumes, or LogicalDisks that have been allocated from this Pool. The Extent returned MUST be a component Extent of the Pool or subdivisions of a component Extent, the subdivisions themselves represented as Extents.
ValueMapstring0, 1, 2, 3, 4, 5, 6, .., 4098..32767, 32768..65535
ValuesstringCompleted with No Error, Not Supported, Unknown, Timeout, Failed, Invalid Parameter, In Use, DMTF Reserved, Method Reserved, Vendor Specific

Method Parameters (GetAvailableExtents)

NameTypeQualifiers
NameData TypeValue
AvailableExtentsCIM_StorageExtent[]
DescriptionstringList of references to available StorageExtents, or subclass instances.
OUTbooleantrue
Goal REF CIM_StorageSetting
DescriptionstringThe StorageSetting (Goal) for which supported extents should be retrieved as available. If a NULL is passed for the Goal, the method will return all available extents, regardless of the goal. There exists a possibility of error in creating a Pool, Volume, or LogicalDisk retrieved in this manner.
INbooleantrue