Device.Storage Requirements
Updated: January 17, 2014
Device.Storage.Controller
General feature that applies to all Storage Controllers
Related Requirements |
Device.Storage.Controller.BasicFunction Device.Storage.Controller.ClassCode Device.Storage.Controller.InfFile Device.Storage.Controller.MiniportDriverModel |
Device.Storage.Controller.BasicFunction
Storage Controller Basic Functionality
Target Feature |
Device.Storage.Controller |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Controller Basic Functionality
PCI-based host controllers and adapters must support PCI bus mastering as the default setting, and virtual direct access memory (DMA) services must be supported in the host adapter option ROM.
Devices that cannot perform their function without other registry modifications, other than those performed automatically by the device class co-installer, are not eligible for the certification.
All commands must be passed to the underlying physical device unless the controller is a RAID adapter.
If a device returns less data than requested, it must correctly indicate an underrun condition and adapters must handle this in accordance with the WDK (adjust DataTransferLength).
Non-RAID Controller
Miniport drivers other than RAID drivers may not create pseudo devices to be used as targets for management commands for the adapter when no actual LUNs are present. Instead, a SCSI miniports INF must specify the CreateInitiatorLu parameter under the services Parameters key and set this DWORD value to 1. This may not be done using a coinstaller. Storage miniport drivers do not use this parameter as the adapter may always be used even if no devices are present. Values for storage drivers that are documented in the WDK.
The following Storage Controller Driver Logo requirement is for the storage controller driver that does not have a matched submission category in the current Windows Hardware Certification Program. Any storage controller with a matched submission category shall be submitted under its matched category.
Storage controller driver must be a STORPORT MINIPORT driver.
Registry Entries for STORPORT Miniport Drivers - STORAGE_BUS_TYPE must set to BusTypeUnknown (0x00).
For storage controllers, the controller itself must correctly translate the commands and respond in accordance with the applicable SCSI specifications, even if the controller implements other command protocols on a different interface type such as SATA, NVMe, or PQI. Any commands that are not recognized must result in a SCSI check condition with valid sense data.
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Controller.ClassCode
Bus-attached controllers must implement the correct class/subclass code as specified in PCI 2.3, Appendix D.
Target Feature |
Device.Storage.Controller |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Controller Class CodeStorage host controllers and adapters must meet the requirements for the device protocol used and any requirements related to the device storage bus.Bus-attached controllers must implement the correct class/subclass code as specified in PCI 2.3, Appendix D. This applies to all bus types including, but not limited to, IDE, Fibre Channel, SCSI, and SATA-based devices. Any device which implements RAID functionality regardless of whether the RAID implementation is done in hardware, firmware or in the driver code, must implement the PCI RAID Class Code (01/04) and not use the interconnect class code (for example, a SATA RAID controller must implement the 01/04 class code and not the AHCI class code 01/06/01). Non-PCI attached storage host controller does not need to report PCI class code. However, it must report the equivalent ACPI Compatibility ID.
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.InfFile
All host adapters must be installed by using Plug and Play mechanisms and require the use of an INF file
Target Feature |
Device.Storage.Controller |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Controller INF FileAll host adapters must be installed by using Plug and Play mechanisms and require the use of an INF. Installation programs must use INF files, must pass the most current Chkinf tool, and can explicitly modify the registry values only by using INF file constructs that meet the Windows certification program requirements. Changes can be made only under the following keys:
TimeoutValues under the class driver services keys (Disk and Tape).
SpecialTargetList only for SCSIport implementations.
Device's service key (must be HKLM\System\CurrentControlSet\Services\ and the Parameters\Device subkey under that).
Signal BusChangeDetected on any link transition or detection of a hot-plug event. A limited settling is allowed before this is signaled, but it must be settable through a registry parameter.
Implementation of the BusType registry DWORD to correctly set the interface type in accordance with the enumeration in NTDDSTOR.H (see the WDK).This value must be set in the miniport's INF under the service's Parameters key - there is no programmatic way to set it and you may not rely on coinstallers as they do not run under all scenarios.
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.MiniportDriverModel
Storage Miniport Driver Model
Target Feature |
Device.Storage.Controller |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Miniport Driver Model
Drivers used with storage controllers must follow the miniport driver model. Storage Miniports must comply with all miniport interface definitions as defined in the WDK. Fibre Channel, iSCSI, SAS, SAS RAID SATA, SATA RAID, SCSI, and SCSI RAID controller drivers must be STORPORT miniports. Monolithic, full-port drivers or other types of drivers that do not follow the miniport model are not eligible for the certification. All drivers for physical hardware must be implemented to support Plug and Play. Legacy drivers are no longer supported.
Any device that depends on a filter driver for physical disk drive functionality is not eligible for certification. Filter drivers may not be used to bypass any part of the storage stack. For example, a filter driver many not directly access any hardware (such as by using HAL calls) and filter drivers may not be used to link cache manager to the hardware implementation. Filter drivers may not be used to violate any terms of the certification program.
Multipathing drivers may not be tied to specific HBAs except for PCI RAID controllers and must use the MPIO model.
Transient or pseudo-devices may not be exposed to the system. Drivers that specify NODRV may be used to "claim" management devices that report as processor, controller, or MSC device types. Such drivers that do not refer to a service entry are not eligible for the certification, but they can be signed.
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.Ata
Defines the Industry and Microsoft standards that must be met
Related Requirements |
Device.Storage.Controller.Ata.Interface |
Device.Storage.Controller.Ata.Interface
PATA Controller Interface
Target Feature |
Device.Storage.Controller.Ata |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
PATA InterfacePATA controllers must comply with the ATA/ATAPI-7 specification. Bus-mastering DMA capability is required for all PATA controllers with the exception of compact flash and similar flash-RAM device. The following requirements are also applied to ATA/ATAPI controllers.
The PACKET command protocol as defined in ATA/ATAPI-7 Volume 2, Section 11.8, must not be implemented in ATA-only controllers.
PATA controllers that support the PACKET command protocol must be fully implemented as defined in ATA/ATAPI-7 Volume 2, Section 11.8.
Identify Device data fields (61:60) and (103:100) must not be used to determine 28-bit or 48-bit LBA addressing support. Instead, bit 10 of word 83 and bit 10 of word 86 must be checked for 48-bit LBA addressing support as defined in ATA/ATAPI-7, Volume 1, Section 4.2.1.
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.Boot
Defines requirements that must be met if the Storage Controller support Boot
Related Requirements |
Device.Storage.Controller.Boot.BasicFunction Device.Storage.Controller.Boot.BitLocker |
Device.Storage.Controller.Boot.BasicFunction
If the controller implements boot support it must support Int13h functions
Target Feature |
Device.Storage.Controller.Boot |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Controller Boot Support
Option ROMs in host controllers and adapters for any interface type, including RAID controllers, that provide boot support must fully support extended Int13h functions (functions 4xh) as defined in BIOS Enhanced Disk Drive Services - 3 [T13-D1572], Revision 3 or later. Logical block addressing is the only addressing mechanism supported.
It is recommended that controllers also support booting using the Extensible Firmware Interface (EFI) and implement device paths as defined in EDD-3. Starting from Windows 8, it is required for controllers to support booting using the Extensible Firmware Interface (EFI).
SD/eMMC/NAND flash controllers do not have Option ROM, so the first part of this requirement does not apply. EFI support is required.
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.Boot.BitLocker
BitLocker must not cause failure in SAN Boot thru Storage Controllers
Target Feature |
Device.Storage.Controller.Boot |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
BitLocker must be properly enabled to protect Operating System in a SAN Boot configuration
Additional Information
Business Justification |
(1) When a server is placed in an environment without adequate physical security, BitLocker protects data on the server against unauthorized access if a server is stolen; (2) When hosting service providers repurpose or decommission storage arrays, BitLocker Disk Encryption prevents data breach. |
Enforcement Date |
Aug. 15, 2011 |
Device.Storage.Controller.BootDeviceGreaterThan
Defines requirements that must be met if the Storage Controller support 2.2 Terabyte Boot
Related Requirements |
Device.Storage.Controller.BootDeviceGreaterThan.BasicFunction |
Device.Storage.Controller.BootDeviceGreaterThan.BasicFunction
Controllers supporting a boot device with a capacity greater than 2.2 terabytes must comply with requirements
Target Feature |
Device.Storage.Controller.BootDeviceGreaterThan |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Controllers supporting a boot device with a capacity greater than 2.2 terabytes must comply with the following requirements:
Small Computer System Interface (SCSI) and SCSI-compatible storage controllers must comply with section 14, "SCSI Driver Model", of UEFI specification version 2.3.1.
The Internet Small Computer System Interface (iSCSI) boot initiator must comply with section 15, "iSCSI Boot", of UEFI specification version 2.3.
The storage controller must support T10 SBC3 Read Capacity (16) command in the UEFI device driver and the Windows device driver. If Advanced Technology Attachment (ATA) or an Advanced Technology Attachment with Packet Interface (ATAPI) storage controller or disk drive is used, the controller firmware or driver must implement SCSI ATA Translation according T10 SAT3 specifications.
The storage controller must report the exact size of the boot disk drive in the EFI shell and in the Windows operating system.
Additional Information
Business Justification |
Disk drive vendors are ready to ship greater than 2.2 TB disks into the market in 2010. OEM vendors are also preparing greater than 2.2 TB boot solutions for their new system platforms. To protect Microsoft® partners' investment and provide a good user experience with a greater than 2.2 TB disk drive, controllers must meet these requirements. |
Enforcement Date |
Dec. 01, 2010 |
Device.Storage.Controller.Fc
Defines the Industry and Microsoft standards that must be met
Related Requirements |
Device.Storage.Controller.Fc.Interface |
Device.Storage.Controller.Fc.Interface
Fibre Channel HBA Interface
Target Feature |
Device.Storage.Controller.Fc |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Fibre Channel InterfaceFibre channel host bus adapters drivers must support the WMI classes and methods required to implement the FC-HBA or SM-API by using the Microsoft HBAAPI.DLL. Vendors may not replace the Microsoft-provided version of the HBAAPI.DLL file. A subset of Hbapiwmi.mof WMI classes and methods are required for Windows compatibility. Other WMI classes are optional and are grouped to form feature sets. If a driver implements any part of an optional feature set, all related classes in that feature set must be supported. In some cases, some features are grouped into subfeatures. If a driver implements such a subfeature, the driver must correctly support that specific subfeature.
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.Fc.NPIV
NPIV is used to deliver Virtual Fibre Channel functionality in Hyper-V
Related Requirements |
Device.Storage.Controller.Fc.NPIV.BasicFunction |
Device.Storage.Controller.Fc.NPIV.BasicFunction
Hyper-V Virtual Fibre Channel N_Port IO Virtualization Support
Target Feature |
Device.Storage.Controller.Fc.NPIV |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
N_Port IO Virtualization (NPIV) is the underlying technology used in the Hyper-V feature Virtual Fibre Channel. These tests allow vendors to self-test drivers for compatibility with Virtual Fibre Channel at an API level during the development cycle, and before submitting updated drivers to Microsoft for certification.
The following classes are required: MSFC_VirtualFibrePortAttributes, MSFC_FibrePortNPIVAttributes, MSFC_FibrePortNPIVMethodsEx, MSFC_FibrePortNPIVCapabilities, MSFC_NPIVCapabilities MSFC_NPIVLUNMappingInformationEx. Optionally, MSFC_DH_Chap_Parameters may be implemented.
These tests cover typical valid and invalid API calls, but do not cover in-depth scenarios covering VM workloads, storage target functionality and data integrity, performance, or other considerations.
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Controller.Fcoe
Defines the Industry and Microsoft standards that must be met
Related Requirements |
Device.Storage.Controller.Fcoe.Interface Device.Storage.Controller.Fcoe.Interoperability |
Device.Storage.Controller.Fcoe.Interface
Fibre Channel over Ethernet Host Bus Adapter
Target Feature |
Device.Storage.Controller.Fcoe |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Fibre Channel over Ethernet Host Bus Adapter
FCoE Adapter must implement FC-BB-5 FC-BB_E specification.
FCoE Adapter miniport must be implemented as a Storport miniport.
FCoE Adapter miniport must define VER_FILEDESCRIPTION_STR and contain the substring "[FCoE]".
For FCoE Adapter miniport INF's [service-install-section]
"DisplayName" entry value is required and must contain the substring "[FCoE]".
"Description" entry value is optional, if specified, must contain the substring "[FCoE]".
For FCoE Adapter miniport INF's Models Section [models-section-name] | [models-section-name.TargetOSVersion]
"device-description" entry value must contain the substring "[FCoE]".
FCoE Adapter miniport must declare BusTypeFibre as its STORAGE_BUS_TYPE in the INF file. STORAGE_BUS_TYPE Enumeration
FCoE Adapters that expose PCI storage device(s)/function(s) for FCoE frame processing (either egress or ingress), must report 0x0c0400 (Fibre Channel) as its Class Code (Base Class, Sub-Class and Interface code).
Additional Information
Enforcement Date |
Dec. 01, 2010 |
Device.Storage.Controller.Fcoe.Interoperability
Fibre Channel over Ethernet Host Bus Adapter - Interoperability
Target Feature |
Device.Storage.Controller.Fcoe |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Interoperability
FCoE Adapter must interoperate with FC SAN devices through FCF.
FCoE Adapter must interoperate with native FCoE devices.
FCoE Adapter must be able to transport network (IP) and storage (FCoE) traffic concurrently.
Disable/removal/loss of FC (storage) functionality must not impact network (Ethernet) connectivity and functionality.
FCoE Adapter must be able to access and address FC and native FCoE devices concurrently (through FCF).
Initiator Coexistence
FCoE Adapter must coexist with FC Adapter without interference on the same system.
FCoE Adapter must coexist with other FCoE Adapters without interference on the same system.
Additional Information
Enforcement Date |
Dec. 01, 2010 |
Device.Storage.Controller.Flush
Defines the Industry and Microsoft standards that must be met
Related Requirements |
Device.Storage.Controller.Flush.BasicFunction |
Device.Storage.Controller.Flush.BasicFunction
Flush to Connected Device
Target Feature |
Device.Storage.Controller.Flush |
Applies to |
Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Industry standard spec requirements:
For ATA device, FLUSH CACHE (E7h, Non-Data ) 28-bit command is optional for ATA devices and ATAPI devices. FLUSH CACHE EXT (EAh, Non-Data) 48-bit command is mandatory for devices implementing the 48-bit Address feature set
For SCSI Devices, SYNCHRONIZE CACHE (10) command and /or SYNCHRONIZE CACHE (16) command shall be implemented
Windows Design Spec requirements - Controller:
For controllers and device drivers of all bus types (ATA, SCSI and USB), flush cache command shall be sent to connected device without any omission.
Note: The requirement is not applicable to Laptop.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Controller.Iscsi
Defines the Industry and Microsoft standards that must be met
Related Requirements |
Device.Storage.Controller.Iscsi.Interface |
Device.Storage.Controller.Iscsi.Interface
iSCSI Interface
Target Feature |
Device.Storage.Controller.Iscsi |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
iSCSI InterfaceiSCSI host bus adapters must be compatible with iSCSI RFC3720 and must implement all mandatory requirements. The only exception to this is that IPsec is not mandatory but, if implemented, will be tested. All optional components, if implemented, must comply with this specification.
Optional behavior must not undermine compliance with the iSCSI specification or the Windows certification program requirements for iSCSI.
The device and drivers must also meet applicable requirements for SCSI controllers and devices.
An iSNS client must be implemented and comply with RFC3723.
An Adapter must be able to receive ping (ICMP) and send ping (ICMP).
Device logons must be consistent with the Microsoft iSCSI Discovery Service.
Any boot device configured by other means must be reported to the service after boot.
Any other persistent target assignments and sessions under control of the HBA must be reported by using WMI to the iSCSI Initiator Service when it is available.
The following logon authentication implementations are both required:
"CHAP-target authenticates initiator"
None
Mutual CHAP, if implemented, must adhere to the specification and will be tested.
IPSec support must adhere to all applicable IPSec requirements in this document.
The HBA driver must implement all required WMI interfaces documented in the WDK.
The initiator must perform an automatic logon to targets assigned to the computer as persistent targets. The initiator will connect to all persistent targets before the targets are enumerated by Windows, which starts with an Inquiry to LUN 0. If a connection drops, it will continue to try to reconnect. Devices cannot depend on the discovery service for this information.
Initiators must:
Maintain the persistent logon information in the registry or in NVRAM.
Support the new WMI class for defining/managing persistent logons.
Persist IP network adapter and discovery configurations (IP configuration information, such as static IP address, static default gateway IP address, static subnet mask, and DNS server) or use DHCP to obtain this information.
For discovery configuration, remember which discovery methods are used and, for iSNS, maintain the address of the iSNS server.
An iSCSI HBA must support changers, disk, tape, and external RAID devices.
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.Iscsi.iSCSIBootComponent
Defines the Industry and Microsoft standards that must be met
Related Requirements |
Device.Storage.Controller.Iscsi.iSCSIBootComponent.FwTable |
Device.Storage.Controller.Iscsi.iSCSIBootComponent.FwTable
iSCSI Boot Functionality
Target Feature |
Device.Storage.Controller.Iscsi.iSCSIBootComponent |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
iSCSI Boot FunctionalityThe iSCSI boot component must:
Be compatible with iSCSI targets complying to iSCSI RFC3720.
Defer all iSCSI functionality to the Microsoft iSCSI software initiator after the Windows boot sequence begins (once ntoskrnl.exe loads).
Support Login Redirection.
Support one-way CHAP and must maintain CHAP secret in non-volatile memory.
Implement iSCSI Boot Firmware Table in firmware or Option ROM per the ACPI SIIG optional table.
Support crashdump.
Support use of IPV6 addressing.
Support iSNS (Internet Server Name Service)
Support RELOGIN as minimum error handling in the case of an error during logon initialization sequence with the iSCSI target.
Support the following DHCP option numbers: 1, 3, 17, 43, 51, 54, 57, 60, 61, 255, 201, 202, 203, 204, 205, and 206.
Support the following DHCP parameters:
DHCPDISCOVER to get an IP address assigned.
DHCPDISCOVER to get an IP address assigned.
DHCPREQUEST to obtain iSCSI protocol parameters.
DHCPINFORM to inquire updates in information from the DHCP server.
In addition:
All requests from iSCSI preboot component DHCP clients to DHCP servers must use option 60 to signal the appropriate vendor scope.
All requests from iSCSI preboot component DHCP clients to DHCP servers must use option 61 to signal the identity of this given client. If the client Alt ID is not defined, then the type field should be set to 0x01 and the EN MAC address must be used to define client identity. If the client Alt Id is defined, then the type field should be set to 0x00 and the CAID field must be used.
All requests from iSCSI preboot component DHCP clients to DHCP servers must use the CHADDR field containing the EN MAC address of the DHCP client.
The use of CIADDR in iSCSI preboot component must conform to the DHCP usage of CIADDR.
The use of YIADDR iSCSI preboot component must conform to the DHCP usage of YIADDR; namely, the iSCSI preboot component DHCP client must accept the YIADDR provided by the DHCP server during the DHCPREQUESTóDHCPACK or DHCPINFORMóDHCPACK transaction sequence.
The use of SIADDR in iSCSI preboot component must conform to the DHCP usage of SIADDR; namely, the iSCSI preboot component DHCP client must use this address to access the DHCP server during DHCPREQUESTóDHCPACK or DHCPINFORMóDHCPACK transactions.
To support DHCP option 1, the subnet mask provided in the DHCPOFFER response from iSCSI pre-boot component must provide the subnet mask.
All transactions between iSCSI preboot component DHCP clients and DHCP servers must be a single-frame transaction.
To avoid conflict with other services, iSCSI preboot component must not use DHCP option 52.
Implementation of multiple option responses in iSCSI preboot component must comply with RFC 3396.
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Controller.Optical
General feature that applies to all Storage Controllers to ensure optical burning requirements are met
Related Requirements |
Device.Storage.Controller.Optical.BasicFunction |
Device.Storage.Controller.Optical.BasicFunction
Storage HBA Drivers must support Optical drives
Target Feature |
Device.Storage.Controller.Optical |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Controller Optical SupportThe storage HBA drivers must support the optical device. The CDBs sent to the optical device and the response from the optical device must be handled properly.
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.PassThroughSupport
Pass-through storage controller basic functionality
Related Requirements |
Device.Storage.Controller.PassThroughSupport.BasicFunction |
Device.Storage.Controller.PassThroughSupport.BasicFunction
Pass-through storage controller basic functionality
Target Feature |
Device.Storage.Controller.PassThroughSupport |
Applies to |
Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
The bus adapter must report the actual bus type used to connected drives (e.g. drives are connected via the SAS bus; reporting drives as connected via the "RAID" bus is invalid). All commands must be passed directly through to the underlying physical devices. The physical devices must not be abstracted (e.g. formed into a logical RAID disk) and the bus adapter must not respond to commands in behalf of the physical devices.NOTE: This applies only to SAS and SATA Controllers.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Controller.Raid
Defines the Industry and Microsoft standards that must be met
Related Requirements |
Device.Storage.Controller.Raid.BasicFunction |
Device.Storage.Controller.Raid.BasicFunction
RAID Controller
Target Feature |
Device.Storage.Controller.Raid |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
RAID Controller
Miniport drivers for PCI RAID adapters may create a management LU if this device is always available for management commands and has a device type other than disk. Since this device will appear in device manager, a NODRV INF may be submitted to claim this device and prevent user popups (this INF may be signed).
For RAID controllers, the controller itself must correctly interpret the commands and respond in accordance with the applicable SCSI specifications, even if the controller implements RAID on a different interface type such as SATA. Any commands that are not recognized must result in a SCSI check condition with valid sense data.
SCSI Requirements can be found in Device.Storage.SCSI section.
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.Raid.ContinuousAvailability
Validates that Continuous Availability (CA) storage controller and drivers meet all applicable requirements
Related Requirements |
Device.Storage.Controller.Raid.ContinuousAvailability.ActiveMode Device.Storage.Controller.Raid.ContinuousAvailability.FailoverClustering Device.Storage.Controller.Raid.ContinuousAvailability.LunAccess Device.Storage.Controller.Raid.ContinuousAvailability.RAID Device.Storage.Controller.Raid.ContinuousAvailability.RecoveryProcessing |
Device.Storage.Controller.Raid.ContinuousAvailability.ActiveMode
Device and driver must support active LUN access on each node in a Windows Failover Cluster system configuration
Target Feature |
Device.Storage.Controller.Raid.ContinuousAvailability |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
When the device and driver are configured in multiple nodes in a Windows Failover Cluster, each node must support as a minimum “dual-active” access, defined as full read/write functionality for at least one LUN that has capability for being failed over to another node in the cluster. Specifically not allowed is to only support passive operation where the device and driver operates only in a standby mode until the cluster fails over a LUN from another node.
Design Notes:
•For this “dual-active” access, LUNs do not need to provide full, performant read/write functionality to all nodes in the cluster. Access from other nodes only needs to be supported as required to support a valid Windows Failover cluster.
•Specifically, it is desirable but not required to support simultaneous, shared access to a LUN from multiple nodes in the cluster.
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Controller.Raid.ContinuousAvailability.FailoverClustering
Device and driver must meet a minimum set of requirements to operate in a Windows failover cluster
Target Feature |
Device.Storage.Controller.Raid.ContinuousAvailability |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Device must comply with SPC-3 section 6.11 PERSISTENT RESERVE IN command
Device must comply with SPC-3 section 6.12 PERSISTENT RESERVE OUT command
Device must support Persistent reservations type as defined in section 6.11.3.4 Table 107:
5h Write Exclusive – Registrants Only
Device must comply with Reservation behavior as defined in SPC-3 section 5.6
Specifically SCSI compliance testing should take special care to verify the following:
Verify Reserving – once reserved the scope & type of an existing persistent reservation cannot be changed
Comply with section 5.6.1 – table 32
Comply with section 5.6.6 – table 33, table 34, table 36 – verify Good Status conditions
Verify, re-register an I_T nexus that has already been registered (5.6.6) – should return good status
Verify, re-reserve an I_T nexus that holds the persistent reservation (5.6.9) – should return good status
Return Reservation conflict – if PRO command with service action PREEMPT or PREEMPT & ABORT is sent with invalid Service Action Reservation Key (5.6.10.4.4)
Verify Additional Length Field per 6.11.3.2 - should return zero when no persistent reservation is held
Design Notes:
It is recommended that in addition to the standard HCT qualification all solutions are also validated with the "Microsoft Cluster Configuration Validation Wizard" (ClusPrep) tool.
Only SAS devices using the Serial SCSI Protocol (SSP) transport will be supported on failover clusters (including SAS JBOD or any SAS SSP RAID systems).
If the system disks are attached to a bus type that is not a valid type for shared storage (something other than FC, iSCSI, or SAS), then the system disks and shared
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Controller.Raid.ContinuousAvailability.LunAccess
Device and driver must meet requirements for accessing LUNs in a Windows Failover Clustering configuration
Target Feature |
Device.Storage.Controller.Raid.ContinuousAvailability |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
When a node in a Windows Failover Cluster fails over its resources, either planned or unplanned (e.g., resulting from a node crash or node power failure), the device and driver must meet the following requirements:
All data from successfully acknowledged writes prior to failover must be preserved and accessible from surviving nodes. Specifically, data corresponding to write operations sent to the device and driver on the failing node prior to the start of failover of its LUNs (i.e., after the corresponding RAID controller on a surviving node receives a persistent reservation request corresponding to the LUNs from the failed node) that have been acknowledged by the driver as completed must be accessible after failover completes from a surviving node. In addition, any data that may be pending from unacknowledged writes at the start of failover must not change data subsequently written to the device from a surviving node.
When the LUNs supported by the RAID controller on the failing node stop being accessible (i.e., stop acknowledging and processing I/O requests), the LUN must be made accessible (i.e., acknowledge and process I/O requests) by at least one other node in the cluster with a maximum delay of 5 seconds. This time limit must be supported for up to 100 LUNs or the maximum number of LUNs supported by the controller, whichever is smaller.
During normal operation (i.e., not during failover) in a Windows Failover Cluster, the device and driver must meet the following requirement:
All I/O requests to any LUN supported by the RAID controller must complete within 25 seconds. This time limit must be supported for up to 100 LUNs or the maximum number of LUNs supported by the controller, whichever is smaller.
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Controller.Raid.ContinuousAvailability.RAID
Device and driver must meet a minimum set of requirements for RAID functionality
Target Feature |
Device.Storage.Controller.Raid.ContinuousAvailability |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Device and driver must support commands from SBC-2 (or later) regardless of the drive interface implemented.
Device and driver must support, at a minimum, one of: RAID1, RAID 5, RAID6 or RAID 1/0, or an equivalent feature that supports full LUN functionality in the event of failure of a single data drive.
Device and driver RAID implementation must provide a solution to prevent data loss due to the RAID “write hole” failure mechanism. (See Design Notes for definition of the RAID “write hole” failure mechanism.)
Design Notes:
If there is a system or controller failure during active writes, the erasure code information of a stripe (e.g., parity) may become inconsistent with the data. Data loss may result if this incorrect erasure code information is subsequently used to reconstruct the missing block in that stripe. This problem is known as the RAID “write hole”.
Examples of typical solutions for the RAID write hole problem are to provide mechanisms to detect and recover from an interrupted update-in-place operation or to avoid update-in-place semantics
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Controller.Raid.ContinuousAvailability.RecoveryProcessing
Device and driver must automatically complete all recovery processing resulting from failing over a LUN from a node in a Windows failover cluster
Target Feature |
Device.Storage.Controller.Raid.ContinuousAvailability |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
When the device and driver are configured in a Windows failover cluster and LUN access is restored after a failover (see requirement CAHWStorage-0004), all processing required by the device and driver to recover from the failover operation and restore normal operation must complete automatically, i.e., without any manual intervention
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Controller.Sas
Defines the Industry and Microsoft standards that must be met
Related Requirements |
Device.Storage.Controller.Sas.Interface |
Device.Storage.Controller.Sas.Interface
SAS Controller Interface
Target Feature |
Device.Storage.Controller.Sas |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
SAS InterfaceSAS host bus adapter miniport drivers must use the Microsoft hbaapi DLL to support the Windows Management Instrumentation (WMI) methods. The specific required WMI classes and methods are grouped and designated as mandatory or optional. All mandatory classes and methods must be supported. If a group is identified as optional and a miniport driver supports that group, individual methods and classes within that group are also classified as mandatory if the group is implemented or optional if the group is implemented. Note: The SAS HBA API is currently in draft stage at the T11.5 working group. This support will not be a requirement until the draft document is complete. WHQL will issue an announcement when this support becomes a requirement.
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.Sata
Defines the Industry and Microsoft standards that must be met
Related Requirements |
Device.Storage.Controller.Sata.Interface |
Device.Storage.Controller.Sata.Interface
SATA Controller Interface
Target Feature |
Device.Storage.Controller.Sata |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
SATA Interface
SATA controllers must comply with the ATA/ATAPI-7 specification
SATA controllers must support hot plug.
SATA controllers shall support Asynchronous Notification as defined in Serial ATA: High Speed Serialized AT Attachment, Version 2.6 or later and AHCI 1.3 or later.
If implemented, NCQ must be supported properly.
If implemented, larger sectors other than 512 bytes must be supported properly.
AHCI SATA controllers must comply with the AHCI 1.0 specification or later.
SATA controllers shall not emulate PATA.
Interfaces for non-AHCI SATA controllers, if implementing an interface other than AHCI, must be supported by a Windows inbox driver or must certify with a supplied driver set. The supplied drivers must meet the driver certification requirements in this document.
Recommendation: SATA controllers should implement interface power management
Recommendation: SATA controllers should implement Native Command Queuing (NCQ) support
Additional Information
Enforcement Date |
Jun. 01, 2009 |
Device.Storage.Controller.SD
Defines the Industry and Microsoft standards that must be met.
Related Requirements |
Device.Storage.Controller.SD.BasicFunction |
Device.Storage.Controller.SD.BasicFunction
SD Controller Basic Functionality
Target Feature |
Device.Storage.Controller.SD |
Applies to |
Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Supports the SD Standard Host Interface (as per the SD 3.0 Standard)
Supports CMD21 tuning for eMMC HS200.
All interrupts shall be disabled except for buffer read ready when executing the tuning procedure for either SD 3.0 devices (CMD19) or eMMC 4.5 devices (CMD21).
Tuning procedure must use the standard tuning blocks defined in the SD and eMMC standard specifications, respectively.
Supports 1.8V and 3.3V signaling voltages.
Supports ADMA2 (no system DMA).
Properly express all capabilities supported by the host controller in the standard capabilities register.
Supports Byte (8-bit), Word (16-bit), and Double Word (32-bit) register accesses based on the register size given in the standard host controller specification.
Supports write protect where write protect is indicated by the value 0.
Supports 1-bit and 4-bit bus widths. 8-bit bus width is also required for eMMC controller.
Supports all UHS-I modes (SDR50, DDR50, SDR104). HS200 is also required for eMMC controller.
No retuning shall be necessary for SDR50 mode.
Retuning shall not require a software timer.
Supports Auto CMD23 and Auto CMD12.
No toggling of any proprietary register bits shall be necessary to enable any functionality.
Clock frequency shall be calculated according to standard specification.
Support standard error recovery procedure.
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.ControllerDrive.NVMe
Storage NVMe Feature
Related Requirements |
Device.Storage.ControllerDrive.NVMe.BasicFunction |
Device.Storage.ControllerDrive.NVMe.BasicFunction
NVMe Device Requirements
Target Feature |
Device.Storage.ControllerDrive.NVMe |
Applies to |
Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 |
Description
The following requirements must be fulfilled by the NVMe device in general:
The device must support PCIe Gen2 or higher.
The device must support the following interrupt modes:
Running with the requested number of interrupts (i.e. > 1 MSI or MSI-X based interrupt)
Running with only 1 MSI or MSI-X interrupt
Running with only 1 line-based interrupt
[Server] MSI-X is required
[Client] MSI or MSI-X is required
The device must use the following class and sub-class codes for identification, for further driver matching the vendor and product IDs should be utilized:
Base Class:01h
Sub-Class:08h
Programming Interface:02h
The device must have at least one upgradeable firmware slot
The following requirements that the device must fulfill are specific to revision 1.0 + errata of the official NVMe spec:
3.1.1 Controller Capabilities
MPSMIN (Memory Page Size Minimum) must be set to 0. Bit: 51:48
4.1.3 Queue Size
[Server] Submission Queues must be capable to be at least128 entries deep
[Client] Submission Queues must be capable to be at least 64 entries deep
5.2 Asynchronous Event Request
Error events, as well as SMART / Health status events must be supported, see section 5.12 below.
5.3 Create I/O Completion Queue
5.4 Create I/O Submission Queue
5.5 Delete I/O Completion Queue
5.6 Delete I/O Submission Queue
[Server] At least 64 queues must be supported for 5.3 through 5.6
63 sets of I/O submission and completion queues and 1 set of admin submission and completion queues are acceptable. The device must then report that it supports 63 I/O queues.
[Client] At least 4 queues must be supported for 5.3 through 5.6
3 sets of I/O submission and completion queues and 1 set of admin submission and completion queues are acceptable. The device must then report that it supports 3 I/O queues.
5.9 Get Features – at least the following must be reported accurately:
5.12.1.5 Error Recovery
5.12.1.6 Volatile Write Cache
A volatile write cache is not required on the device to adhere to these requirements. This field has to be accurately reported.
5.12.1.7 Number of Queues
5.12.1.8 Interrupt Coalescing
[Server] required
[Client] not required
5.12.1.11 Asynchronous Event Configuration
5.10 Get Log Page
The device must implement and populate at least the log pages for Error Information (01h), SMART / Health Information (02h), and Firmware Slot Information (03h)
5.11 Identify
MDTS (Maximum Data Transfer Size) must be either 0 (no limitation) or at least 5 (128KB). Byte: 77
Note: This value will likely be increased in future revisions and next-generation devices should be designed with this in mind.
NN (Number of Namespaces) must be at least 1. Bytes: 519:516
FLBAS (Formatted LBA Size) must have bit 4 set to 0. Byte: 26
If the Metadata Capabilities feature is supported, this requirement holds, otherwise it can be ignored; i.e. iff MC bit 1 is set to 1, the above FLBAS requirement is binding. Byte: 27
LBADS (LBA Data Size) must be set to 9 or 12, i.e. 512B or 4KB. Bits: 23:16
Other LBA data sizes are acceptable, as long as 512B or 4KB is supported.
5.12 Set Features – at least the following must be implemented:
Error Recovery (05h)
Volatile Write Cache (06h)
If a volatile write cache exists on the device
Number of Queues (07h)
Interrupt Coalescing (08h)
Asynchronous Event Configuration (0Bh)
5.13 Format NVM
The device must be capable to perform at least a User Data Erase (SES Value 001b)
The device must be capable to perform the Format NVM command on a per namespace basis. Specifically, Bit 1 and Bit 0 of Byte 524 in the Identify Controller Data Structure must be set to 0.
6.6 Dataset Management – Deallocate
All I/O and Deallocate commands shall be completed in less than 500 ms.
98.5% of I/O commands shall be completed in less than 100 ms.
6.7 Flush
If a volatile cache exists on the device
6.8 Read
6.9 Write
Additional Information
Business Justification |
By conforming to the features and standards mentioned in the detailed description section of this document, Windows will be capable of efficiently and securely utilizing NVMe devices. •Deallocate will allow easy removal of data from the device without incurring additional I/Os, thus prolonging the expected life of the flash. •Flush for volatile caches is required for Bitlocker scenarios that include storage caches. It is necessary to have the capability to synchronize all data from a caching layer to the final storage medium. •Asynchronous Event Requests allow Windows to retrieve health information about the device that may indicate errors and failures. This capability yields better error handling and preventive measures can be taken to minimize the risk of data loss. |
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Enclosure
Drive Enclosures must meet these requirements
Related Requirements |
Device.Storage.Enclosure.DirectAccess Device.Storage.Enclosure.DriveIdentification |
Device.Storage.Enclosure.DirectAccess
Drive enclosures must provide direct access to the drives they house
Target Feature |
Device.Storage.Enclosure |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Enclosures must not abstract the drives they house (e.g. formed into a logical RAID disk). Integrated switches, if present, must provide discovery of and access to all the drives in the enclosure without requiring additional physical host connections.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Enclosure.DriveIdentification
Drive enclosures must provide drive identification service
Target Feature |
Device.Storage.Enclosure |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Storage enclosure must meet the following requirements to support storage space configuration.
Must support the following commands:
-
INQUIRY
-
SEND DIAGNOSTIC
-
RECEIVE DIAGNOSTIC RESULTS
-
REQUEST SENSE
-
TEST UNIT READY
Must set ENCSERV bit to one in the Standard Inquiry Data (SPC4) to indicate that storage target device contains an embedded enclosure services component that is addressable through this logical unit.
Must support the following Diagnostic pages for enclosure service devices:
-
Supported Diagnostic Pages diagnostic page (00h)
-
Configuration diagnostic page (01h)
-
Enclosure Control diagnostic page (02h)
-
Enclosure Status diagnostic page (02h)
-
Additional Element Status diagnostic page (0Ah)
The following Type Control and Status Elements are used in Windows Storage Space feature:
Element Type Code | Element Type Name |
---|---|
01h |
Device Slot |
02h |
Power Supply |
03h |
Cooling |
04h |
Temperature Sensor |
07h |
Enclosure Service Controller Electronics |
12h |
Voltage Sensor |
13h |
Current Sensor |
17h |
Array Device Slot |
Storage enclosure must support either Device Slot (01h) or Array Device Slot (17h) Element Type. All other element types (Power Supply, Cooling, Temperature Sensor, Enclosure Service Controller Electronics, Voltage Sensor and Current Sensor) are optional.
For Additional Element Status diagnostic page (0Ah), enclosures shall provide additional element status descriptor with the EIP (element index present) bit set to one.
Element Index field reported by drive bays are in ascending order.
The protocol identifier must set to 6h (SAS).
The SES device must report the same address the drive reports for Device Identification VPD page (83h) should include one designation descriptor in which the target port name or identifier (see SAM-5) is indicated. The designation descriptor, if any, shall have the ASSOCIATION field set to 01b (i.e., target port) and the DESIGNATOR TYPE field set to:
-
2h (i.e., EUI-64-based);
-
3h (i.e., NAA); or
-
8h (i.e., SCSI name string
For Enclosure Control diagnostic page (02h), control descriptors are enumerated by disk bay number in ascending order.
Must comply with T10 SES3 spec to implement both Enclosure Control diagnostic page and Enclosure Status diagnostic page with INFO, 1NON-CRIT, CRIT and UNRECOV bits.
ELEMENT STATUS CODE field in all Status element formats must adopt the following codes:
Code | Name | Condition |
---|---|---|
0h |
Unsupported |
Status detection is not implemented for this element. |
1h |
OK |
Element is installed and no error conditions are known. |
2h |
Critical |
Critical condition is detected. |
3h |
Noncritical |
Noncritical condition is detected. |
4h |
Unrecoverable |
Unrecoverable condition is detected. |
5h |
Not Installed |
Element is not installed in enclosure. |
6h |
Unknown |
Sensor has failed or element status is not available. |
7h |
Not Available |
Element installed, no known errors, but the element has not been turned on or set into operation. |
8h |
No Access Allowed |
The initiator port from which the RECEIVE DIAGNOSTIC RESULT command was not received does not have access to this element. |
9h to Fh |
Reserved |
|
Notes: Windows correlates enclosure services to drives via the protocol-specific information and the drives’ Device Identification VPD page (83h) with ASSOCIATION field set to 1.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd
Related Requirements |
Device.Storage.Hd.BasicFunction Device.Storage.Hd.PhysicalSectorSizeReportsAccurately Device.Storage.Hd.RotationalRate |
Device.Storage.Hd.BasicFunction
HD Basic Functionality
Target Feature |
Device.Storage.Hd |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
The device must be able to perform the following scenarios:
Sequential read
Sequential write
Sequential verify (write followed by read and comparison)
Random read
Random write
Random verify
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Hd.PhysicalSectorSizeReportsAccurately
Reported physical sector size must be the unit of atomic write
Target Feature |
Device.Storage.Hd |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Following applies to ATA based Hard Disk Drives:If implemented, support for storage devices with logical sector sizes larger than 512-bytes need to be implemented as described in the ATA-8 specifications. Please refer to the INCITS T13 specification repository for access to the specification. Following applies to SCSI based Hard Disk Drives: If implemented, support for storage devices with logical sector sizes larger than 512-bytes need to be implemented as described in the SBC-3, SPC-4, and SAT-3 specifications. Please refer to the INCITS T10 specification repository for access to the relevant specifications.
Additional Information
Business Justification |
Some Hard Disk Drives report the physical sector size of the disk incorrectly. For example, the drive is released a "4K" drive without reporting that it is indeed a 4K drive. Applications use the reported physical sector size as a notion of atomicity and perform I/O based on this. The most basic example is a database-style application will only store one commit record within the unit of atomic write for fear of loss if power is lost or if a physical sector becomes physically bad. When the reported physical sector size is not the unit of atomicity, serious reliability concerns can arise in scenarios where power is lost such as:Applications can fail to recover, and users will need to restore from backup.Applications can fail to recover, but the application will need to perform a lengthy consistency check.Corruption of metadata, log file data, user data, or even data from other applications. |
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.RotationalRate
Hd Rotational Rate Logo Requirements
Target Feature |
Device.Storage.Hd |
Applies to |
Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 |
Description
Solid State Device (SSD) shall set Nominal Media Rotation Rate to non-rotating medium value. A rotational or a mixed rotational and SSD device shall report the rotational rate of the rotational medium.
Following applies to ATA based Hard Disk Drives:
ATA hard disk devices must report nominal media rotation rate as described in the ATA-8 specifications. The Word 217 of Identify Device command return shall not be 0000h.
Nominal Media Rotation Rate Value Description
Value |
Description |
0000h |
Rate not reported |
0001h |
Non-rotating media (e.g., solid state device) |
0002h-0400h |
Reserved |
0401h-FFFEh |
Nominal media rotation rate in rotations per minute (rpm) (e.g., 7 200 rpm = 1C20h) |
FFFFh |
Reserved |
Following applies to SCSI based Hard Disk Drives:
SCSI hard disk device must report nominal media rotation rate as described in the T10 SBC3 specifications. The Inquiry command return for Block Device Characteristics VPD page shall not set media rotation rate = 0000h.
MEDIUM ROTATION RATE field
Code |
Description |
0000h |
Medium rotation rate is not reported |
0001h |
Non-rotating medium (e.g., solid state) |
0002h-0400h |
Reserved |
0401h-FFFEh |
Nominal medium rotation rate in rpm (e.g., 7 200 rpm = 1C20h,10 000 rpm = 2710h, and 15 000 rpm = 3A98h) |
FFFFh |
Reserved |
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Hd.1394
Related Requirements |
Device.Storage.Hd.1394.Compliance |
Device.Storage.Hd.1394.Compliance
IEEE 1394 Hard Disk Drive Specification compliance
Target Feature |
Device.Storage.Hd.1394 |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
1394 ComplianceIEEE-1394 (Firewire) devices must comply with Serial Bus Protocol-2 (SBP-2) and SCSI Primary Commands-2 (SPC-2), and disk devices must comply with SCSI Reduced Block Commands (RBC). The reference for specification compliance...:SBP-2, SPC-2, Min:RBC
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Hd.Alua
Related Requirements |
Device.Storage.Hd.Alua.Compliance |
Device.Storage.Hd.Alua.Compliance
Asymmetric Logical Unit Acces (ALUA)
Target Feature |
Device.Storage.Hd.Alua |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
If a device supports asymmetric logical unit access (ALUA), the device must comply with the requirement of implementing target port group support (TPGS) in standard inquiry data as SPC3-r23 section 6.4.2.The Report Target Port Group command must be supported, if logical units report in the standard Inquiry Data that they support ALUA. The storage device must comply with SPC3 -r23 section 6.25 Report Target Port Group command according to its TPGS field code in the standard Inquiry data.
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.Ata
Related Requirements |
Device.Storage.Hd.Ata.BasicFunction Device.Storage.Hd.Ata.Dma |
Device.Storage.Hd.Ata.BasicFunction
ATA/ATAPI Interface
Target Feature |
Device.Storage.Hd.Ata |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
PATA Devices (legacy) (PATA Devices will no longer be accepted for WHQL submission after June 2013.)Microsoft recommends the use of SATA for new devices. However, in a spirit of compatibility with existing device base, the following requirements are provided for PATA devices. Shared bus capabilities are required for PATA devices; devices shall be configurable as device 0 or device 1.
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Hd.Ata.Dma
ATA/ATAPI DMA Mode
Target Feature |
Device.Storage.Hd.Ata |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
ATA/ATAPI DMA Mode All PATA controllers and PATA peripherals shall support Ultra-DMA as defined in ATA/ATAPI-7.Justification: In addition to improved transfer rates, Ultra-DMA also provides error checking for improved robustness over previous PATA implementations.
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Hd.AtaProtocol
Related Requirements |
Device.Storage.Hd.AtaProtocol.Performance Device.Storage.Hd.AtaProtocol.Protocol |
Device.Storage.Hd.AtaProtocol.Performance
ATA Device Performance
Target Feature |
Device.Storage.Hd.AtaProtocol |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 |
Description
ATA Device Performance The Windows 7 Windows System Assessment Tool (WinSAT) disk formal test for the block storage device must pass the following performance requirements for any visible storage space utilization up to 95% (% of utilization as % of "used space" seen through the Windows file system).
Disk Sequential 64K Byte Read >25 MB/s
Disk Random 16K Byte Read >0.5MB/s
Disk Sequential 64K Byte Write >20 MB/s
Average Read Time with Sequential Writes <25 ms
Latency: 95th Percentile <120 ms
Latency: Maximum <700 ms
Average Read Time with Random Writes <40 ms
Additional Information
Enforcement Date |
Jun. 01, 2010 |
Device.Storage.Hd.AtaProtocol.Protocol
ATA/ATAPI Protocol
Target Feature |
Device.Storage.Hd.AtaProtocol |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
ATA/ATAPI Protocol
ATA/ATAPI controllers and devices shall comply with the following standard(s)
INCITS 397-2005 (1532D): AT Attachment with Packet Interface - 7 or later, also referred to in this document as ATA/ATAPI-7. AT Attachment with Packet Interface -8 or later will be required when this revision 8 is final and published.
ATA/ATAPI controllers shall support Windows operating system boot
ATA/ATAPI devices shall not rely on Identify Device data fields (61:60) and (103:100) to determine 28 bit or 48 bit LBA addressing support. ATA/ATAPI shall rely instead on bit 10 of word 83 and bit 10 of word 86 to identify 48 bit LBA addressing support (as per ATA/ATAPI-7).
Design notesRecommended:Reporting Nominal Media Rotation RateIf a device requires Windows defragmentation to be turned off by default, the device should report its Nominal Media Rotation Rate as 0001h Non-rotating media (e.g. solid state device) as per the ATA8-ACS1 specification, section 7.16.7.77. Justification: When the Nominal Media Rotation Rate reported by the device is anything but 0001h Non-rotating media, Windows will by default perform defragmentation of the block storage device.
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Hd.DataVerification
Disk Verification Tests to ensure there is no data loss or corruption
Related Requirements |
Device.Storage.Hd.DataVerification.BasicFunction |
Device.Storage.Hd.DataVerification.BasicFunction
All Storage Devices will work correctly on Windows
Target Feature |
Device.Storage.Hd.DataVerification |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Storage devices must reliably read and write data without data loss or data corruption
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Hd.Ehdd
Related Requirements |
Device.Storage.Hd.Ehdd.Compliance |
Device.Storage.Hd.Ehdd.Compliance
Encrypted Hard Drive complies with Microsoft and Industry specifications
Target Feature |
Device.Storage.Hd.Ehdd |
Applies to |
Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Encrypted Hard Drive
eDrives must be compliant with these industry specifications
IEEE 1667 version IEEE 1667-2009
Support Probe silo
Support TCG Storage silo
TCG
TCG core specification version 2.0
OPAL SSC 2.0
Programmatic TPer Reset Rev
Modifiable CommonName Column
SID Authority Disable
OPAL SSC Feature Sets
Set Additional Data Store Rev 1.05 or later
Single User Mode Rev 1.02 or later
SCSI
SPC4
SAT2
ATA
ACS2
eDrives must comply with these Windows Design Spec requirements:
Support at least AES 128
Support one or more of the following cipher modes
CBC
XTS
Support at least 8 bands
Support additional data store tables
Support range crossing
Support authenticate method
Support secret protect info
Support modifiable common name
Support TCG stack reset
Support programmatic TPer reset
Support single user mode
If SCSI devices(SPC4):-
The 1667 Version Descriptor, 0xFFC2 (IEEE 1667-2009) should be reported in the INQUIRY data. The 'Additional Length' field of the INQUIRY data must be greater than or equal to 0x38.
Security Protocol IN output must report 00, 01, 02, EE in the Supported Security Protocol List payload
If ATA devices (ACS2):-
The TrustedComputer.FeatureSupported (word 48 - bit 0 must be set to '1') must be reported in the IDENTIFY data
The AdditionalSupported.IEEE1667IDENTIFY (word 69 - bit 7 should be set to '1') must be reported in the IDENTIFY data
Trusted Receive output should report 00,01, 02, EE in the Supported Security Protocol List payload
If SATA-USB:-
Support SAT2
Command Performance:- The drive must complete the following operations within the specified duration
Operations |
Max completion time |
Discovery/Enumeration |
24 sec (8 bands) |
Activate |
45 sec |
Revert |
8 sec |
Create Band |
1.5 sec |
Delete Band |
2 sec |
Erase Band |
2 sec |
Set Metadata |
20 sec |
Get Metadata |
14 sec |
Lock Band |
1.5 sec |
Unlock Band |
1.5 sec |
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.EMMC
Defines the Industry and Microsoft standards that must be met.
Related Requirements |
Device.Storage.Hd.EMMC.BasicFunction |
Device.Storage.Hd.EMMC.BasicFunction
Emmc Basic Functionality
Target Feature |
Device.Storage.Hd.EMMC |
Applies to |
Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Must support industry standards.
eMMC 4.5.1 Requirements
Support discard/sanitize on both sector size and erase block boundaries.
Support HPI/BKOPS.
Support Packed commands.
Support HS200 signaling.
Support DDR50 signaling.
Support a RPMB of at least 128KB in size and creation of GPPs.
Support sleep (CMD5).
Support crypto offload operations (CMD53/54).
Support OS initiated cache flushing if device supports volatile cache.
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Hd.EnhancedStorage
Related Requirements |
Device.Storage.Hd.EnhancedStorage.1667Compliance |
Device.Storage.Hd.EnhancedStorage.1667Compliance
Enhanced Storage Devices comply with the IEEE 1667 defined standards
Target Feature |
Device.Storage.Hd.EnhancedStorage |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
IEEE1667-Class (Enhanced Storage) enabled storage devices meet industry standardsEnhanced Storage devices comply with the IEEE 1667 defined standards.
Enhanced Storage device must:
Support authenticating the host
Implement support for IEEE 1667 (version 1.1 or later) defined Probe Silo on the device.
Implement at least one Certificate or Password Silo on the device.
Enhanced Storage device that implements Certificate Silo must:
Load native windows certificate silo driverï€
Responds to all commands of the IEEE 1667 version 1.1 specification
Verify certificate-based authentication is used to allow and block access to volume.
Enhanced Storage device that implements Password Silo must:
Load native password silo driver
Respond to all commands in the IEEE 1667 Password Silo specificationï€
Verify password-based authentication is used to allow and block access to the volume.
Design Notes:Obtain IEEE 1667 specification from IEEE at the following location:http://go.microsoft.com/fwlink/?LinkID=110100
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Hd.FibreChannel
Related Requirements |
Device.Storage.Hd.FibreChannel.Compliance |
Device.Storage.Hd.FibreChannel.Compliance
Fibre Channel Devices
Target Feature |
Device.Storage.Hd.FibreChannel |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Fibre Channel devices must comply with Fibre Channel Protocol for SCSI, Second Version (FCP-2) or later. To ensure interoperability at the electrical and signaling levels, Fibre Channel devices must comply with Third-Generation Fibre Channel Physical and Signaling Interface (formerly ANSI X3.303:1998).
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.Flush
Related Requirements |
Device.Storage.Hd.Flush.BasicFunction |
Device.Storage.Hd.Flush.BasicFunction
Flush Command Completion
Target Feature |
Device.Storage.Hd.Flush |
Applies to |
Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Industry standard spec requirements:
For ATA device, FLUSH CACHE (E7h, Non-Data ) 28-bit command is optional for ATA devices and ATAPI devices. FLUSH CACHE EXT (EAh, Non-Data) 48-bit command is mandatory for devices implementing the 48-bit Address feature set
For SCSI Devices, SYNCHRONIZE CACHE (10) command and /or SYNCHRONIZE CACHE (16) command shall be implemented
Windows Design Spec requirements - HDD:
Correct Reporting of Completion: When the OS issues a flush cache command, the storage device should synchronously report Completion of the command only when the content of cache has been persisted.
Note: The requirement is not applicable to Laptop.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.Iscsi
Related Requirements |
Device.Storage.Hd.Iscsi.BasicFunction |
Device.Storage.Hd.Iscsi.BasicFunction
iSCSI Devices
Target Feature |
Device.Storage.Hd.Iscsi |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
iSCSI devicesiSCSI devices must comply with RFC3720, RFC3721, and RFC3723.
Device must complete testing by using the Microsoft iSCSI initiator.
Device must be able to receive ping (ICMP) and send ping (ICMP).
The following iSCSI protocol features are required:
Send Targets.
Logon Authentication: CHAP and none. Targets may delegate CHAP authentication to Radius.
Discovery Session Logon key/value pairs: InitiatorName, SessionType, and AuthMethod.
Normal Session Logon key/value pairs: InitiatorName, SessionType, AuthMethod, and TargetName.
DataPDUInOrder.
DataSequenceInOrder.
DefaultTime2Wait.
DefaultTime2Retain
ErrorRecoveryLevel=0.
Targets that allow different shared secrets for different initiator names.
The following iSCSI protocol features must pass testing if they are implemented:
Mutual CHAP.
HeaderDigest: CRC32 and none.
DataDigest: CRC32 and none.
InitialR2T.
IPsec; when using IPsec, Main mode must be available. In addition, the following items are required when IPsec is implemented:
IPsec transport mode must be implemented.
Internet key exchange (IKE) implementations must support main mode and preshared keys. Target portals with the same IP address must expect the identical main mode IKE policy.
Targets and initiators must allow different preshared keys for different identifier payloads.
Targets and initiators must have static IP addresses for main mode.
Additional Standard Inquiry data VERSION DESCRIPTORS (SPC-3) are required
At least one iSCSI VERSION DESCRIPTOR is required (value = 0960h).
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.Mpio
Related Requirements |
Device.Storage.Hd.Mpio.BasicFunction |
Device.Storage.Hd.Mpio.BasicFunction
RAID implementations that provide a multipathing solution must comply with Microsoft multipath I/O (MPIO)
Target Feature |
Device.Storage.Hd.Mpio |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Internal or external RAID implementations that provide a multipathing solution must comply with Microsoft multipath I/O (MPIO). Windows multipathing solutions must consist of a Device Specific Module (DSM) created by using the Microsoft MPIO DDK and must comply with all requirements set forth in the Multipath I/O Program Agreement.Following WMI classes must be implemented by 3rd party DSM .
DSM_QuerySupportedLBPolicies
DSM_QueryUniqyeId
3rd party DSM must report minor, major version numbers for the DSM
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.MultipleAccess
Drives that support Multiple Access must meet these requirements
Related Requirements |
Device.Storage.Hd.MultipleAccess.MultiplePorts |
Device.Storage.Hd.MultipleAccess.MultiplePorts
Multi-port drives must provide symmetric access
Target Feature |
Device.Storage.Hd.MultipleAccess |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Multi-port drives must support the same set of commands on all ports. Drives must not provide different behavior or degraded performance for commands based on which port used for command delivery.When drives are connected to a host via multiple paths, the drives must use Windows' Multipath IO (MPIO) solution with the Microsoft Device Specific Module (DSM).Example: Drives must provide the same performance for data access commands and the same behavior for persistent reservation commands arriving on different ports as they provide when those commands arrive on the same port.The performance degradation between any two ports should be within 10% range.Notes: Multi-port drives may be connected to one or more computer hosts via one or more paths per host. Connecting a drive to multiple hosts enables Windows to use the drive as part of a failover cluster of hosts. Connecting a drive to a single host via multiple paths enables Windows to continue to provide access to the drive in the event of cable failure. Windows supports using these connection topologies independently and jointly.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.MultipleAccess.PersistentReservation
Drives that support Persistent Reservations must meet these requirements
Related Requirements |
Device.Storage.Hd.MultipleAccess.PersistentReservation.BasicFunction |
Device.Storage.Hd.MultipleAccess.PersistentReservation.BasicFunction
Drives must provide persistent reservations
Target Feature |
Device.Storage.Hd.MultipleAccess.PersistentReservation |
Applies to |
Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Drives must implement persistent reservations as per the SCSI-3 Primary Commands (SPC-3) specification. Windows depends on proper behavior for the below persistent reservation capabilities.
PERSISTENT RESERVE IN Read Keys (00h)
PERSISTENT RESERVE IN Read Reservation (01h)
PERSISTENT RESERVE OUT Reserve (01h)
Scope: LU_SCOPE (0h)
Type: Write Exclusive - Registrants Only (5h)
PERSISTENT RESERVE OUT Release (02h)
PERSISTENT RESERVE OUT Clear (03h)
PERSISTENT RESERVE OUT Preempt (04h)
PERSISTENT RESERVE OUT Register AND Ignore Existing Key (06h)
PERSISTENT RESERVE OUT Register (00h)
Notes: Windows can use physical disks to form a storage pool. From the storage pool, Windows can define virtual disks called storage spaces. Failover Cluster can make the pool of physical disks, the storage spaces they define, and the data they contain highly available. In addition to the standard HCT qualification physical disks should also pass the "Microsoft Cluster Configuration Validation Wizard" (ClusPrep) tool.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.OffloadedDataTransfer
Windows Offloaded Data Transfer
Related Requirements |
Device.Storage.Hd.OffloadedDataTransfer.CopyOffload |
Device.Storage.Hd.OffloadedDataTransfer.CopyOffload
If Copy Offload is supported these requirements must be implemented
Target Feature |
Device.Storage.Hd.OffloadedDataTransfer |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Industry standard spec requirements:
Targets that support Windows Copy Offload feature must implement T10 XCOPY Lite specification (11-059r8):
Supported VPD Pages VPD page (Must include ECOP VPD Page (Page Code 8Fh) in the Supported VPD page list)
ECOP VPD page or ECOP VPD Page (Page Code 8Fh) + Block Device ROD Limits ECOP descriptor (0000h)
Block Limit VPD Page (Page Code B0h)
According to T10 11-059r8 spec, Windows adopts 83h OP Code + 10 Service Action Code for POPULATE TOKEN and 83h OP Code + 11 Service Action Code for WRITE USING TOKEN commands.
According to T10 11-059r8 spec, Windows adopts 84h OP Code + 07 Service Action Code for RECEIVE ROD TOKEN INFORMATION command. Response service action field and command parameters shall be compliant with T10 XCOPY Lite spec (11-059r8)
Windows Design Spec requirements:
During the target device enumeration, Windows will send down an Inquiry for Supported VPD Pages VPD page. If 8F is included in Supported VPD page list, Windows will inquiry for ECOP VPD page and BLOCK LIMITs VPD page.
Implementation and Error Handling with Parameters of ECOP VPD page
The MAXIMUM RANGE DESCRIPTORS - If the number of Block Device Range Descriptors of a POPULATE TOKEN or WRITE USING TOKEN command exceeds the MAXIMUM RANGE DESCRIPTORS, copy manager shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to TOO MANY SEGMENT DESCRIPTORS.
The MAXIMUM INACTIVITY TIMER (MAXIMUM IAT) - If the INACTIVITY TIMEOUT of a POPULATE TOKEN command exceeds the MAXIMUM INACTIVITY TIMER, copy manager shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST.
The MAXIMUM TOKEN TRANSFER SIZE -
If the sum of the NUMBER OF LOGICAL BLOCKS fields in all block device range descriptors of the WRITE USING TOKEN command is greater than the MAXIMUM TOKEN TRANSFER SIZE, copy manager shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST.
If the sum of the NUMBER OF LOGICAL BLOCKS fields in all block device range descriptors of the POPULATE TOKEN is greater than the MAXIMUM TOKEN TRANSFER SIZE, copy manager shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST.
Implementation and Error Handling with Parameters of Block Limits VPD page
The MAXIMUM TRANSFER LENGTH field indicates the maximum transfer length in blocks that the copy manager accepts for a single BLOCK DEVICE RANGE DESCRIPTOR. If a copy manager receives a request for a NUMBER OF LOGICAL BLOCKS exceeding this maximum, then the copy manager shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST.
Storage array must support both synchronous and asynchronous POPULATE TOKEN and WRITE USING TOKEN according to T10 11-059r8, 11-078r4 and 11-204r0 spec.
Storage array must complete synchronous POPULATE TOKEN and WRITE USING TOKEN commands in a very short time (4 seconds) without causing any SCSI command timeout.
User Experience Requirements:
Fall back to Legacy Copy - Windows copy offload operation shall be able to fall back legacy copy operation when a copy offload error or limitation is reported.
Drag and drop copy experience - must be able support drag and drop copy with copy offload capable storage target device.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.PersistentReservation
Related Requirements |
Device.Storage.Hd.PersistentReservation.ClusterFailover |
Device.Storage.Hd.PersistentReservation.ClusterFailover
Cluster Failover for RAID Array systems
Target Feature |
Device.Storage.Hd.PersistentReservation |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Required: All Microsoft MPIO device-specific modules (DSMs) must be Windows Hardware Certification-qualified and support registering and unregistering persistent reservations across all paths.Design Notes:
All host bus adaptors (HBA) used on failover cluster nodes can use only a Windows Hardware Certification-qualified miniport driver based on the Storport miniport model.
All multipath I/O solutions leveraged on highly available failover clusters must be based on Microsoft MPIO.
It is recommended that in addition to the standard HCT qualification all solutions are also validated with the "Microsoft Cluster Configuration Validation Wizard" (ClusPrep) tool.
FC, iSCSI, and particularly serial-attached SCSI (SAS) failover cluster solutions cannot be built on RAID HBAs where cache and/or RAID configuration is machine/node specific. The RAID set information and hardware cache must reside in a single shared point that lives in an external storage controller.
SAS, FC, and iSCSI have no restrictions as to the number of nodes they support (which currently is 8nodes).
Note: Legacy parallel-SCSI server clusters were restricted to a maximum size of 2nodes.
Only SAS devices using the Serial SCSI Protocol (SSP) transport will be supported on failover clusters (including SAS JBOD or any SAS SSP RAID systems). SATA devices attached to a SAS domain must be part of a RAID system.
SATA direct attach and SATA JBOD is not supported; the system must include RAID.
If the system disks are attached to a bus type that is not a valid type for shared storage (something other then FC, iSCSI, or SAS), then the system disks and shared storage must be on separate physical controllers/host bus adaptors.
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Hd.Piton
Related Requirements |
Device.Storage.Hd.Piton.BasicFunction |
Device.Storage.Hd.Piton.BasicFunction
Devices that implement the NV-Cache command set support industry Microsoft standards
Target Feature |
Device.Storage.Hd.Piton |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Devices that implement the NV-Cache command set support industry Microsoft standards
A device or system that contains a device that implements a non-volatile memory cache and either the non-volatile memory cache (NV-Cache) command set as defined by T13 ATA-ASC or the NV Cache Manager I/O Control Codes must meet the followingcertification requirements.
This device or system is known as a device under test (DUT)
A minimum of 50-MB NV Cache must be implemented in the DUT and exposed to Windows.
The NV-Cache must be able to perform according to the following scenarios:
Scenario Block Size (512 byte aligned) Throughput
Random Read 4KB 4MB/sec
Random Write 4KB 4MB/sec
Sequential Read 64KB 16MB/sec
Sequential Write 64KB 8MB/sec (Microsoft recommends 16MB/sec)
Random Read 1MB 16MB/sec
Random Write 1MB 10MB/sec
Immediately following a transition from device power state OFF to ON the DUT must be able to service a 512 bytes IO that is pinned in the NV-Cache in less than 3 seconds. This requirement is used to ensure the boot and resume benefits of the NV-Cache are realized. This requirement does not apply to storage adapters implementing NV-Cache command set.
In normal operation, the maximum read/write latencies for data in the NV-Cache should be:
less than or equal to 3 millisecond for a random 4K block
less than or equal to 4 millisecond for a random 4.5k block
The DUT must fully comply with ATA 7.0 with all additions enumerated in "e05106r7-ACS-NV_Cache_Command_Proposal" or ATA 8.0 when ratified.
Windows must be able to perform the following tasks when the DUT is installed on a system:
Detect that the device supports the NV-Cache commands when installed.
Enter and return from NV-Cache power mode.
Pin boot LBAs to enhance boot performance.
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Hd.PortAssociation
Drives must provide port association
Related Requirements |
Device.Storage.Hd.PortAssociation.BasicFunction |
Device.Storage.Hd.PortAssociation.BasicFunction
Drives must provide port association
Target Feature |
Device.Storage.Hd.PortAssociation |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
A drive must report its port address for device identification VPD page 83h inquiry association type 1 (port association). This must be the same address the drive supplies to a SCSI Enclosure Services (SES) device and the SES device reports via SES diagnostic page 0Ah with protocol identifier set to 6h.Notes: Windows depends on drive enclosures to provide SCSI Enclosure Services (SES) capabilities such as drive slot identification and visual drive indications (commonly implemented as drive LEDs). Windows matches a drive in an enclosure with SES identification capabilities via the drive's port address. Computer hosts may be separate from drive enclosures or may be integrated into drive enclosures.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.RaidArray
Related Requirements |
Device.Storage.Hd.RaidArray.BasicFunction Device.Storage.Hd.RaidArray.BitLocker |
Device.Storage.Hd.RaidArray.BasicFunction
RAID Array Systems
Target Feature |
Device.Storage.Hd.RaidArray |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
RAID Requirements RAID systems and devices must support commands from SBC-2 (or later) regardless of the drive interface implemented. RAID controllers and RAID systems must support, at a minimum, one of: RAID1, RAID 5, RAID6 or RAID 1/0.External RAID arrays must allow a failed drive that is redundant to be replaced manually without shutting down or halting the system. This requirement includes, but is not limited to, drives in a mirror set, a physical drive being replaced by a "hot spare," and the first failed drive in a RAID level-5 array. The RAID subsystem must also allow lost data to be rebuilt without interfering with system operations. It is expected that RAID array throughput will be impacted during the rebuild.
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.RaidArray.BitLocker
BitLocker must not cause data corruption on Storage Arrays
Target Feature |
Device.Storage.Hd.RaidArray |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
BitLocker must be properly enabled to protect Data volumes on Storage Arrays
Additional Information
Business Justification |
(1) When a server is placed in an environment without adequate physical security, BitLocker protects data on the server against unauthorized access if a server is stolen; (2) When hosting service providers repurpose or decommission storage arrays, BitLocker Disk Encryption prevents data breach. |
Enforcement Date |
Aug. 15, 2011 |
Device.Storage.Hd.ReadZeroOnTrimUnmap
Related Requirements |
Device.Storage.Hd.ReadZeroOnTrimUnmap.BasicFunction |
Device.Storage.Hd.ReadZeroOnTrimUnmap.BasicFunction
The requirement applies to Hard Disk Drives
Target Feature |
Device.Storage.Hd.ReadZeroOnTrimUnmap |
Applies to |
Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
If the logical block provisioning read zeros (LBPRZ) bit is set to one, then the device server shall set all bits to zero in the Data-In Buffer for read operation on an unmapped (deallocated or anchored) LBA
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.RemovableMedia
Defines requirements that must be met if the Storage Device is Removable, i.e., it has RMB bit set to 1
Related Requirements |
Device.Storage.Hd.RemovableMedia.BasicFunction |
Device.Storage.Hd.RemovableMedia.BasicFunction
Devices with True Removable Storage Media
Target Feature |
Device.Storage.Hd.RemovableMedia |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Device with True Removable Media should report as True Removable Media (RMB=1) according to SPC-4 Revision 29, Section 6.4.2
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.Sas
Related Requirements |
Device.Storage.Hd.Sas.ComplyWithIndustrySpec |
Device.Storage.Hd.Sas.ComplyWithIndustrySpec
Serial Attached SCSI devices comply with industry specifications
Target Feature |
Device.Storage.Hd.Sas |
Applies to |
Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 |
Description
The reference for specification compliance. Where noted as Min, the baseline specification is mandatory. “Rec” indicates the preferred version of the specification. If not otherwise specified, the version listed is the minimum required. Unless otherwise indicated, all features of the cited specifications that are classified as mandatory by the standards body must be implemented.
SAS-1, SAM-3, SPC-3, Min:SBC-2, Rec: SBC-3
Serial Attached SCSI devices comply with the Serial Attached SCSI (SAS) Specification 1 or later.
-
Shall not cause more than 10% IO performance degradation when the SAS storage device is used in a MPIO configuration.
-
SAS storage device shall establish a UNIT ATTENTION subsequent to detection of the following events.
-
Power On
-
Hard Reset
-
Logical Unit Reset
-
I_T Nexus loss
-
Power loss expected
-
Power On
SAS SSD must implement following T10 (SCSI) command specification:
Read Capacity (16)
Block Limit VPD Page (Page Code B0h)
Block Device Characteristics VPD page (Page Code B1h)
Logical Block Provisioning VPD Page (Page Code B2h)
SAS SSD must meet the following requirements:
SAS SSD target device must return MEDIUM ROTATION RATE = 0001h (Non-rotating medium)
SAS SSD target device must return Read Capacity (16) command with LBPME bit set to 1 and Provisioning Type field = 0 (000b) Not Report a Provisioning Type or 1 (001b) Resource Provisioned in the Logical Block Provisioning VPD page (Page Code B2).
SAS SSD device must implement Block Limit VPD Page (Page Code B0h) and support the following parameters:
MAXIMUM UNMAP LBA COUNT
MAXIMUM UNMAP BLOCK DESCRIPTOR COUNT
OPTIMAL UNMAP GRANULARITY
UNMAP GRANULARITY ALIGNMENT
UGAVALID Bit
SAS SSD target device must implement Logical Block Provisioning VPD Page (Page Code B2h) and support the following parameters.
LBPU bit
LBPRZ bit
Provisioning Type field.
SAS SSD must support UNMAP (10) command and the LBPU bit in LBP VPD page shall set to one.
If the LBPME bit in ReadCapacity(16) return is set to one, the SAS SSD device must support Logical Block Provisioning VPD page (Page Code B2h)
If the LBPRZ bit in ReadCapacity(16) return is set to one, the SAS SSD device must set LBPRZ bit of Logical Block Provisioning VPD page to one.
Users should be able to identify the Solid State Drive in Windows Storage Optimization utility.
Windows Defragment and Optimization Drive utility should be able to operate according to the SSD’s support features
Additional Information
Business Justification |
Proposed Logo requirement will ensure SAS SSD that support UNMAP command can interoperate with Windows properly; thus lowering CSS/PSS costs. Issues and concerns: •Without a proper algorithm to identify SAS SSD, Windows file system utility will encounter many unknown risks caused by the uncertain SBC3 spec adoption issues. •Without a proper handle of UNMAP command, frequently write/delete/move operations could cause high risk of wear-leveling and reduce the life span of the SSD. Business and User scenarios: •Enable SSD’s identification and UNMAP operation design and implementation in Windows OS. •Maximize the IO efficiency and endurance of SSD device. •Enable SSD to trim disk space after files are deleted in Windows environments. •Enable file system level trim to consolidate SSD space. |
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Hd.Sata
Related Requirements |
Device.Storage.Hd.Sata.BasicFunction |
Device.Storage.Hd.Sata.BasicFunction
ATA Device Performance
Target Feature |
Device.Storage.Hd.Sata |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
SATA Devices
Requirement: SATA devices shall meet the requirements of the Serial ATA: High Speed Serialized AT Attachment, Version 2.6 or later.
Requirement: SATA devices support hot-plug functionality
Recommendation: SATA devices should implement interface power management
Recommendation: SATA devices should implement Native Command Queuing (NCQ) support
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.Sata.HybridInformation
This feature is for all devices that support the Hybrid Information feature.
Related Requirements |
Device.Storage.Hd.Sata.HybridInformation.BasicFunction |
Device.Storage.Hd.Sata.HybridInformation.BasicFunction
SATAIO Hybrid Drive Requirements
Target Feature |
Device.Storage.Hd.Sata.HybridInformation |
Applies to |
Windows 8.1 Client x86, x64 |
Description
The following functionalities and requirements have to be supported by the device and refer to hybrid devices in general:
If a drive reports itself as a hybrid drive, it must be comprised of a spinning disk and at least one non-volatile cache component within a single physical device.
Self-Pinning on Boot
The device shall implement a mechanism to self-pin boot files, i.e. anything prior to Windows becoming active, into the top priority level of the cache. Specifically, the drive shall self-pin in this fashion from power on until the Hybrid Information Log Page is read. The drive should cease self-pinning to the top priority after 160 MB of data has been pinned. All other self-pinning the drive performs shall occur at priority 0.
Cache Size
The hybrid cache has to provide at least 12 GB (12x230 Bytes) of useable capacity to the host.
6 priority levels (0 through 5)
The device must support at least 6 priority levels. No data placed in the cache by the host shall be evicted from ranges 1 through 5 by the device, unless Windows specifies it through calls to evict, demotebysize or trim, or issues further I/Os with priority > 0 to a full cache (i.e. cache churning).
Cache Page Replacement
The drive shall repurpose cache pages of lower priorities to satisfy I/Os at higher priorities, starting with the lowest priority. For example, if the cache is full with 25% at priority 0, 50% at priority 2, and 25% at priority 3 and a priority 3 read/write occurs that is not in cache, a priority 0 cache page should be repurposed to accommodate the priority 3 LBA that was read. Once all priority 0 cache pages are repurposed, priority 1 and 2 pages will be repurposed respectively. If no lower priority pages are available, priority 3 should repurpose pages first that are chosen by a LRU-like algorithm.
Update Priority On IO (Read/Write)
Priorities associated with LBAs in the cache must be updated on any subsequent read or write to that LBA, from any valid priority to any valid priority. In addition, if a read or write is issued to an LBA range that currently does NOT reside in cache, then it shall be placed in the cache at the specified priority (provided there is room in the cache or there are blocks of lower priority that can be evicted – in case of a full cache).
Trim
The device shall support trim as defined in the Windows 8 Hardware Certification Requirements under Device.Storage.Hd.Trim.BasicFunction.
Non-volatile Cache Performance:
Sequential Read:>= 200 MB/s3,200 I/Ops @ 64 KB
Sequential Write:>= 80 MB/s1,280 I/Ops @ 64 KB
Random Read:>= 10 MB/s2,560 I/Ops @ 4 KB (Queue Depth = 1)
>= 20 MB/s5,120 I/Ops @ 4 KB (Queue Depth = 8)
Random Write:>= 5 MB/s1,280 I/Ops @ 4KB (Queue Depth = 1)
>= 10 MB/s2,560 I/Ops @ 4KB (Queue Depth = 8)
Latency:
Setting dirty high and dirty low thresholds shall complete within 1.5ms.
This command can be completed asynchronously.
I/O that carries priority information should not be significantly slower than I/O without priority information. A read or write that has a priority assigned must not incur a latency penalty larger than 10% of an identical I/O without priority information. Achieving this on 95% of all I/Os is acceptable with the penalty never exceeding 100% of a non-priority I/O.
HybridDemoteBySize and HybridChangePriorityByLBARange must return within 5ms. A possible asynchronous implementation of these commands is acceptable.
The following functionalities and requirements have to be supported by the device and refer to the Hybrid Information Feature (Version 14, Oct. 29, 2012) worked on by SATAIO:
13.7.5.4.11 MaxPriority Behavior
The MaxPriority Behavior bit must be set to 0.
13.3.15 Enable/Disable Hybrid Information
13.6.5.4.13 Hybrid Control
Enable/Disable Caching Medium
Windows must have the ability to enable and disable the hybrid cache. Upon disabling the hybrid cache, all dirty data in the cache has to be synchronized with the final storage medium.
Dirty Low Threshold
Dirty High Threshold
Dirty data should be synchronized in ascending order of priority, i.e. priority 0 dirty data should be synchronized before priority 1 dirty data is synchronized.
13.6.5.4.7 Hybrid Demote By Size
Hybrid Information feature related Logs
The device must enable Windows to read the hybrid log pages and return sensible information. In other words, General Purpose Logging is required and the version number shall be set to 0001h. Specifically:
13.7.9 Word 0x12 of “General Purpose Log Directory” shall be set to “1”, indicating that “NCQ NON-DATA” log is supported.
13.7.10 Word 0x13 of “General Purpose Log Directory” shall be set to “1”, indicating that “NCQ SEND AND RECEIVE” log is supported.
13.7.12 Word 0x14 of “General Purpose Log Directory” shall be set to “1”, indicating that “NCQ HYBRID INFORMATION” log is supported. Windows has to be able to determine the following:
Caching Medium Health Status
Dirty Low Threshold
Dirty High Threshold
Maximum Hybrid Priority Level
Max Priority Behavior
NVM size
Max Eviction Commands.
Max Eviction Data Blocks
For each Priority level:
consumed NVM size fraction,
consumed Mapping Resources Fraction
consumed NVM Size for Dirty Data Fraction
consumed Mapping Resources for dirty data fraction
13.6.5.4.1 Hybrid Evict
The LBA range specified by the Evict command shall be targeted to the primary medium like a regular write. The host will ensure consistency – if necessary – by issuing a subsequent flush command.
13.6.5.4.10 Hybrid Change By LBA Range
If Hybrid Change By LBA Range is called on an LBA that currently does not reside in the caching medium, the device shall not fetch it from disk.
Additional Information
Business Justification |
By providing the aforementioned functionality and hardware support, Windows will be capable to properly take advantage of the non-volatile cache that exists on hybrid devices. A large non-volatile cache of 12 GB will allow Windows to reduce flash wear, since less churn will occur in the NVC. Additionally, hibernate and hiberboot scenarios can be supported very well without negatively affecting scenarios such as application launch and run-time / write caching. Relatively fine-grained cache management becomes possible through the support of ChangePriorityByLBARange. Not only app launch, resume and boot performance is improved – due to less cache misses – but also flash longevity and endurance. Updating priorities on all I/Os (reads & writes), for example, allows Windows to only update LBA ranges that are intended to change priority level in the cache. All other cache contents do not have to be touched, which keeps metadata updates on the device to a minimum, thus prolonging the flash’s life expectancy. Trim has a similar effect, whereby a trimmed region can simply be discarded by the device, as opposed to moving the region to priority 0 and have it synchronized. The absence of trim would incur more flash I/O and wear, as well as disk I/O for synchronization that could be avoided. Bitlocker will be positively affected by the Evict command, since data can be synchronized periodically during encryption as opposed to – potentially – forcing the entire flash area onto the disk platter at the end of a Bitlocker conversion cycle, or alternatively, completely disabling the entire hybrid feature and disabling the cache for the duration of the encryption. |
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Hd.Scsi
Related Requirements |
Device.Storage.Hd.Scsi.Connectors Device.Storage.Hd.Scsi.ParallelInterface |
Device.Storage.Hd.Scsi.Connectors
SCSI Connectors
Target Feature |
Device.Storage.Hd.Scsi |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
SCSI Connectors If an external connector is implemented, it must meet the requirements in SCSI or a later specification. The SCSI connector must not use the same connector type as any other non-SCSI connector on the system. All external parallel SCSI connectors must be labeled with ANSI-approved icon for the bus. For internal and external configurations, the SCSI bus cable must be plugged into shrouded and keyed connectors on the host adapter and devices. This ensures that the cable is properly positioned so the user cannot plug in cables incorrectly. For internal configurations, pin-1 orientation must be designated on one edge of the ribbon cable and also on the keyed connector for the SCSI peripheral device.
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.Scsi.ParallelInterface
Parallel SCSI Interface
Target Feature |
Device.Storage.Hd.Scsi |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Parallel SCSI Interface
Parallel SCSI devices and adapters comply with SCSI Parallel Interface-4 (SPI-4) or later.
Termination: Automatic termination circuit and SCSI terminators meet SPI-4 standard or later. Parallel SCSI host controllers and adapters must use automatic termination that allows a user to add external devices without removing the server case. Terminators used in the SCSI host adapter must be regulated terminators, which are also known as active, SCSI SPI-4, or Boulay terminators. SCSI termination built onto internal cables must also meet the SPI-4 specification.
Terminator power must be supplied to the SCSI bus with overcurrent protection. The host adapter must supply terminator power (TERMPWR) to the SCSI bus for system-board implementations by using PCI or another expansion bus. All terminators on the external SCSI bus must be powered from the TERMPWR lines in the SCSI bus. In addition, the circuit that supplies TERMPWR must have overcurrent protection built into it.
External removable disks, hard drives, and CD/DVD optical drives must provide automatic termination or an accessible on-board termination switch. At a minimum, a mechanical means must be provided for setting termination and the switch must be accessible to the user without opening the device chassis.
All SCSI devices supporting hot plugging must comply with annex D of SPI-4, which addresses SCSI device insertion and removal, with and without command activity.
Differential devices must support DIFFSENS as defined in SPI-4 standard or later.
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.Scsi.ReliabilityCounters
Basic reliability counter functionality for disks which implement the SCSI command sets.
Related Requirements |
Device.Storage.Hd.Scsi.ReliabilityCounters.BasicFunction |
Device.Storage.Hd.Scsi.ReliabilityCounters.BasicFunction
Basic reliability counter functionality for disks which implement the SCSI command sets.
Target Feature |
Device.Storage.Hd.Scsi.ReliabilityCounters |
Applies to |
Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
All SCSI drives must provide valid data for the below log sense page (LOG SENSE 4Dh) parameters as per the SCSI Primary Commands 4 (SPC-4) and SCSI Block Commands 3 (SBC-3) specifications.
Start-Stop Cycle Counter (0Eh)
Manufacture Date (0001h)
Read Error Counter (03h)
Total (0002h)
Total Errors Corrected (0003h)
Total Uncorrected Errors (0006h)
Temperature (0Dh)
Temperature (0000h)
Reference Temperature (0001h)
Write Error Counter (02h)
Total (0002h)
Total Errors Corrected (0003h)
Total Uncorrected Errors (0006h)
Background Scan (15h)
Background Scan Status (0000h)
Drives which physically move recording media and/or read-write devices, such as hard disk drives, must provide valid data for the below log sense page (LOG SENSE 4Dh) parameters as per the SCSI Primary Commands 4 (SPC-4) specification.
Start-Stop Cycle Counter (0Eh)
Specified Cycle Count Over Device Lifetime (0003h)
Accumulated Start-Stop Cycles (0004h)
Specified Load-Unload Count Over Device Lifetime (0005h)
Accumulated Load-Unload Cycles (0006h)
Solid-state drives must provide valid data for the below log sense page (LOG SENSE 4Dh) parameter as per the SCSI Block Commands 3 (SBC-3) specification.
Solid State Media (11h)
Percentage Used Endurance Indicator (0001h)
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.ScsiProtocol
Related Requirements |
Device.Storage.Hd.ScsiProtocol.ReferenceSpec Device.Storage.Hd.ScsiProtocol.SamCompliance Device.Storage.Hd.ScsiProtocol.SpcCompliance |
Device.Storage.Hd.ScsiProtocol.ReferenceSpec
Reference to Specifications
Target Feature |
Device.Storage.Hd.ScsiProtocol |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Where noted as Min, the baseline specification is mandatory. Rec indicates the preferred version of the specification. If not otherwise specified, the version listed is the minimum required. Unless otherwise indicated, all features of the cited specifications that are classified as mandatory by the standards body must be implemented.SPI-4, SAM-3, Min:SPC-2, Rec: SPC-3, Min: SBC, Rec: SBC-2
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.ScsiProtocol.SamCompliance
SCSI Architecture Model SAM-3
Target Feature |
Device.Storage.Hd.ScsiProtocol |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
SCSI Architecture Model SAM-3SCSI Devices must comply with SCSI Architecture Model SAM-3 or later (except as noted in SBP-2 for 1394 devices), including the following requirements:
All devices must support LUN reset. In particular, if two LUNs L0 and L1 under the same target have outstanding commands, a LUN reset to L0 must clear any outstanding commands to L0 only.
Following a reset, all devices must return an appropriate unit attention condition to any initiator currently having access to the logical unit.
All FC, iSCSI, SCSI, and SAS devices must support multiple initiators.
MODE SELECT commands that change parameters must cause a unit attention condition to be raised for any other initiator consistent with SAM-3.
LUN 0 must be implemented for all targets. At a minimum, LUN 0 must respond to INQUIRY and all multi-LUN targets must support the REPORT LUNS commands.
If any LUN is added or removed that is accessible to the initiator(s), the device must report a unit attention condition of (06/3F/0E) REPORT LUNS DATA HAS CHANGED MODE SELECT. Commands that change parameters must cause a unit attention condition to be raised for any other initiator that would be impacted by the change.
Any unrecognized SCSI command or incorrectly formed command descriptor block (CDB) must result in an immediate CHECK CONDITION reported back to the initiator.
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.ScsiProtocol.SpcCompliance
SCSI Primary Commands (SPC-3, SPC-4 and SBC-3)
Target Feature |
Device.Storage.Hd.ScsiProtocol |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
SCSI Primary Commands-3 (SPC-3), SCSI Primary Commands-4 (SPC-4) and SCSI Block Commands-3 (SBC-3)
Devices must comply with SCSI Primary Commands: support commands listed as mandatory in the SCSI Primary Commands (SPC-3 or later). In addition, each device type must implement the mandatory command set for that type (SBC-3 for block devices and so on).
For SCSI INQUIRY and REPORT LUNS commands:
All devices must support the SCSI INQUIRY command.
Multi-LUN devices must always respond to an INQUIRY command sent to LUN 0 even if LUN 0 is not implemented. This can be indicated by returning the Device Type Qualifier of 3.
All multi-LUN devices must support the REPORT LUNS command as defined in SPC-2 or later.
Windows supports only single-level logical unit numbers up to 255; see SAM-3. Use of any other format will be incorrectly interpreted, and the device may not be available or data corruption will occur.
All standard INQUIRY data must be correctly set for the device capabilities.
VERSION Field must be 04 or greater. For SAS, this field must be 05 or greater.
Drives with attached media changers must set the MChgnr bit in the standard inquiry data.
Multi-LUN units must return valid REPORT LUNS data for LUN 0.
If LUN 0 is not an accessible PERIPHERAL DEVICE TYPE, the PERIPHERAL QUALIFIER shall be returned as 1. SCSIport will not enumerate the entire target device if a qualifier of 3 is used. It is strongly recommended that LUN 0 not be type 0 because it must be exposed to all initiators. Type 0 is permitted only if the array can map different logical units to LUN 0 for each initiator.
If a device has more than one port, MultiP bit must be set and page 83h descriptors must correctly reflect the port information.
Vital Product Data (VPD) pages:
Page 00h (Supported Pages VPD Page) is required.
Page B1h (Block Device Characteristics VPD Page) is required.
Page 80h (Unit Serial Number VPD Page) is required.
Page 83h (Device Identification VPD Page) is required. For VPD Page 83, at least one type-3 or one type-2 descriptor must be returned for each logical unit, the value must use Code Set 1 (Binary), the value must be unique for that logical unit, and it must be the same value regardless of the path or port responding to the request. Appropriate descriptors for multiport devices are required in addition to that mandatory descriptor. Devices that support aliases must also support the corresponding descriptor types. Vendor-specific device identifiers, if present, must use type 0 and must follow the specified format, including correct page length;
Vendor-specific identifiers are not a substitute for the mandatory type 2/3 descriptors. All device identifiers must conform to formatting rules set forth in SPC-3 or later, even if the device claims only conformance to a previous release.
Device must comply with SPC-3 section 7.6.3 Device Identification VPD page 83h.
At least one identification descriptor must have the IDENTIFIER TYPE field set to:
2h (EUI-64-based) as defined in 7.6.3.5
3h (NAA); or as defined in 7.6.3.6
8h (SCSI name string) at defined in 7.6.3.11
SCSI Mode Sense Command and Pages
MODE SENSE (6) is mandatory for all devices except RBC devices, which implement MODE SENSE (10). The DBD bit must be supported.
Mode Page 3Fh (Return all pages mode page) is mandatory.
Device type-specific pages listed in the device-specific sections of this document.
Additional commands for all devices are as follows:
All devices must support the TEST UNIT READY and REQUEST SENSE commands.
Block Storage (Disk and RAID) Devices
Block storage (disk and RAID) devices must comply with the following requirements:
SCSI block commands (SBC) or later (RBC for 1394). These requirements apply to any device reporting as Device Type 0, including logical units exposed by a RAID controller or subsystem.
Block Devices must support the SCSI START STOP UNIT command to decrease power consumption.
READ CAPACITY (10) command. If a device has more than 2^32 - 1 sectors, a value of 0xFFFFFFFF must be returned for the RETURNED LOGICAL BLOCK ADDRESS field and the READ CAPACITY (16) command must be supported (see below).
Any change to capacity must set a unit attention condition of CAPACITY DATA HAS CHANGED for all initiators with access to the logical unit.
READ(10).
WRITE(10). Support for force unit access (FUA) is mandatory for individual physical disk drives or RAID controllers that contain volatile (non-battery-backed) cache memory and must cause the data sent with this command to be committed to physical media before the command completes.
REASSIGN BLOCKS (hard disks only). RAID controllers that handle bad block replacement should succeed this command.
VERIFY (10).
START STOP UNIT. This command must not perform any other action, such as path failover.
SYNCHRONIZE CACHE (10) (no optional fields are used). For a physical disk drive, this command causes all data in the write cache to commit to physical media if write caching is enabled. Failure to follow this can result in data corruption.
Mode pages:
Mode Page 08h (Caching mode page) with the following bits must contain valid information: WCE (Write Cache Enable), CACHE SEGMENT SIZE, and NUMBER OF CACHE SEGMENTS (optional). RBC devices support Page 6 instead of Page 8 (WCD, WRITED, FORMATD, and LOCKD bits).
If a device supports disabling write caching through the use of the WCE bit, this bit must also be reported as changeable and be supported by a MODE SELECT operation which modifies it. The status of the write caching must be visible by reading Mode Page 8. Vendors can implement caching policies outside of the limited SBC ones, and disabling of write cache does not need to be through this mode page.
Mode Page 0Ah (Control mode page) is required.
Mode Page 1Ah (Power Condition mode page) is required
Disk devices that support greater than 2-TB logical units (including 1394 disks). Devices must conform to SPC-3 and must implement all of the following in accordance with the SCSI Block Commands-2 (SBC-2) specification:
READ CAPACITY (16)
READ (16)
WRITE (16) FUA (bit must be supported if a volatile cache is present on the device)
VERIFY (16)
REASSIGN BLOCKS. LONGLBA field must be supported.
Erasable SCSI Disk Devices
Erasable SCSI disk devices must also support the following commands or features:
ERASE: Full-side and selected-block erase.
Format requirements reported with FORMAT command.
MODE SENSE (6) Total spare blocks available, write protect status.
PREVENT ALLOW MEDIUM REMOVAL and START STOP UNIT.
REASSIGN BLOCKS and READ DEFECT DATA (10).
WRITE without pre-erase, for erasable optical only.
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.ThinProvisioning
Related Requirements |
Device.Storage.Hd.ThinProvisioning.BasicFunction |
Device.Storage.Hd.ThinProvisioning.BasicFunction
Thin Provisioning
Target Feature |
Device.Storage.Hd.ThinProvisioning |
Applies to |
Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
Industry standard spec requirements:
Targets that support thin provisioning feature must implement following T10 SPC4 and SBC3 specification:
Supported VPD Page VPD Page (Page Code 00h)
Block Limit VPD Page (Page Code B0h)
Logical Block Provisioning VPD Page (Page Code B2h)
Logical Block Provisioning Log Page (Page Code 0Ch)
Windows Design Spec requirements:
Target devices with thin provisioning feature must meet the following requirements.
Must return Inquiry command for Supported VPD Page VPD Page with B0h and B2h.
Must return LBPU bit set to one and Provisioning Type field = 3 (010b) of Logical Block Provisioning VPD page (Page Code B2).
Must implement Block Limit VPD Page (Page Code B0h) and support the following parameters.
MAXIMUM UNMAP LBA COUNT
MAXIMUM UNMAP BLOCK DESCRIPTOR COUNT
OPTIMAL UNMAP GRANULARITY
UNMAP GRANULARITY ALIGNMENT
UGAVALID Bit
Must implement Logical Block Provisioning VPD Page (Page Code B2h) and support the following parameters.
Threshold Exponent
LBPU bit
LBPRZ bit
Provisioning Type field
Thin Provisioning target devices should support Log sense command to retrieve Logical Block Provisioning Log Page (Page Code 0Ch) - for adding the following information into the threshold notification system event log.
Used LBA mapping resources of a Thin Provisioning LUN.
Available LBA mapping resources to the Thin Provisioning LUN.
Storage array must support UNMAP (10) command, the LBPU bit in LBP VPD page shall set to one.
Must support Get LBA Status (16) command according to T10 SBC3 spec.
If the LBPME bit in ReadCapacity(16) return is set to one or B2h is reported in the Supported VPD Page VPD Page, the storage array must support Logical Block Provisioning VPD page (Page Code B2h)
If the LBPRZ bit in ReadCapacity(16) return is set to one, the storage array must set LBPRZ bit of Logical Block Provisioning VPD page to one.
Storage array must support threshold notification (TN), temporary resource exhaustion (TRE) and permanent resource exhaustion (PRE) through the following sense key, additional sense code and additional sense code qualifier returns as SPC4 and SBC3 specs.
TN- Sense Key/ASC/ASCQ (06/38/07)
TRE- Sense Key/ASC/ASCQ (02/04/14)
PRE- Sense Key/ASC/ASCQ (07/27/07)
User Experience Requirements:
Must be able to set threshold through vendors' storage management utility and monitor system event log when the thin provisioning soft threshold is reached.
Must support Log Sense command to retrieve LBP log page for reporting available LBA mapping resource and used LBA mapping resource information to the thin provisioning LUN, if Log Page (Page Code OCh) is implemented.
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.Trim
Related Requirements |
Device.Storage.Hd.Trim.BasicFunction |
Device.Storage.Hd.Trim.BasicFunction
ATA Trim and SCSI Unmap Functionality
Target Feature |
Device.Storage.Hd.Trim |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
If the device implements ATA non-NCQ Trim or SCSI Unmap support:
The Trim implementation shall comply with ATA ACS2 Section 7.10 (Data Set Management Commands).
The SCSI Unmap command implementation shall comply with T10 SBC3 Section 5.28 (UNMAP command).
All IO and Trim/Unmap commands shall be completed in less than 500 ms.
98.5% of IO commands shall be completed in less than 100 ms.
If the RZAT bit is set on a SATA device or the LBPRZ bit is set on a SCSI device, then the device shall return all '0's to a Read command before the trimmed block(s) is(are) re-written.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.Uas
Related Requirements |
Device.Storage.Hd.Uas.Compliance |
Device.Storage.Hd.Uas.Compliance
USB UAS Storage Devices
Target Feature |
Device.Storage.Hd.Uas |
Applies to |
Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
USB UASP Storage devices must also be compliant with the USB UASP v1.0 and SPC4, SBC3 USB UASP Storage devices must support the following:
Mode page code: 0x08 Mode subpage code : 00
Block Limits page - 0xB0 SPC3 6.5.3
Support at least 16 streams
Support task management commands
Note: for further information on mode pages see SPC4: D.6 Mode page codes
Support SPC, SBC version descriptors
Support/report R02. R04 version descriptors
Device must report FIXED if it is not a true removable media (RMB=0)
Note: for further information on mode pages see SPC4: D.6 Mode page codes Data Devices must perform as indicated:
Minimum sequential write speed: 100MB/s
Minimum sequential read speed: 110MB/s
Additional Requirement: If the device supports UASP on XHCI and then it must support UASP on EHCI.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.UasOnEHCI
Related Requirements |
Device.Storage.Hd.UasOnEHCI.BasicFunction |
Device.Storage.Hd.UasOnEHCI.BasicFunction
USB UAS Storage Devices
Target Feature |
Device.Storage.Hd.UasOnEHCI |
Applies to |
Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2012 x64 |
Description
If the device supports UASP on XHCI and then it must support UASP on EHCI.
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.Usb
Related Requirements |
Device.Storage.Hd.Usb.Compatibility |
Device.Storage.Hd.Usb.Compatibility
USB Compatibility
Target Feature |
Device.Storage.Hd.Usb |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
USB Compatibility
All USB storage devices must meet the requirements of the Universal Serial Bus Mass Storage Class Specification Overview, V1.2 Revision. This includes all USB Mass Storage class documents, including Bulk Only, Control/Bulk/Interrupt, Bootability, and UFI Command specifications.
BOT1.0, SPC-2, SBC-2
USB 3.0 devices must retain backward compatibility at the Type-A connector to allow Superspeed devices to be used, albeit at a lower speed, with USB 2.0 PCs and allow high speed devices with their existing cables to be connected to the USB 3.0 Superspeed Type-A connectors.
USB storage devices must comply with USB 3.0 - Section 11 Interoperability and Power Delivery specs. The following table lists the compatibility matrix for USB3.0 and USB2.0. The implication of identifying a host port as supporting USB3.0 is that both hardware and software support for USB3.0 is in place; otherwise the port shall only be identified as a USB2.0 port.
USB Host Port |
USB Device Capability |
Connected Mode |
USB 2.0 |
USB 2.0 |
USB 2.0 high-speed, full-speed, or low-speed |
USB 3.0 |
USB 2.0 high-speed |
|
USB 3.0 |
USB 2.0 |
USB 2.0 high-speed, full-speed, or low-speed |
USB 3.0 |
USB 3.0 SuperSpeed |
USB Storage Devices must comply with certification requirement for USB devices and USB Storage Devices
Note: Please refer to USB3.0 spec section 3.1.4 USB 3.0 Architecture summary
USB3.0 Super-speed - 5 Gb/s
USB2.0 high-speed - 480 Mb/s
Full-speed - 12 Mb/s
Low-speed - 1.5 Mb/s
Additional Information
Enforcement Date |
Jun. 01, 2007 |
Device.Storage.Hd.Usb3
Related Requirements |
Device.Storage.Hd.Usb3.Compliance |
Device.Storage.Hd.Usb3.Compliance
USB 3.0 Storage Devices
Target Feature |
Device.Storage.Hd.Usb3 |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
USB 3.0 Storage devices support industry specifications as indicated below
All USB 3.0 Storage devices must be compliant with the USB 3.0 Version 1.0 specification
Provide unique product identification through each storage end point (BOT, UASP)
USB VID/PID
Data Devices must perform as indicated:
Minimum sequential write speed: 60MB/s
Minimum sequential read speed: 90MB/s
Additional Information
Enforcement Date |
Mar. 01, 2012 |
Device.Storage.Hd.WindowsToGoCapableUSBDrive
Windows To Go Capable USB Drive feature
Related Requirements |
Device.Storage.Hd.WindowsToGoCapableUSBDrive.WindowsToGoCapableUSBDrive |
Device.Storage.Hd.WindowsToGoCapableUSBDrive.WindowsToGoCapableUSBDrive
Windows To Go Capable USB Drive
Target Feature |
Device.Storage.Hd.WindowsToGoCapableUSBDrive |
Applies to |
Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 |
Description
USB boot devices must be USB 3.0 and meet these industry specifications:
USB 3.0 Version 1.0 specification
USB BOT specification
SCSI Block Commands 3 (SBC-3) Specification
USB boot devices must:
Boot Windows
Operate at SuperSpeed when connected to a USB 3.0 port
Successfully enter and resume from Sleep (S3) and Hibernate (S4)
Include in the MS OS Descriptor extended property the value "WindowsBootCapable" DWORD value 1
Be at least 32 GB in size (20 GB usable)
Provide unique, consistent product identification
USB VID/PID
Inquiry Serial Number
Inquiry Model Number
Report FIXED (RMB=0)
Implement the Block Device Characteristics VPD page
Not implement IEEE-1667
Not expose more than one LUN during boot
Not support the USB Attached SCSI (UAS) protocol
If the WTG drive exposes multiple functions to the OS:
The device must be designed as a composite USB device
Composite devices must set DeviceClass, Subclass, and Protocol to 0 in the composite node's device descriptors
Must not implement any functions other than WTG Storage and Smartcard
The Storage function must be the first function exposed
Support the following mode pages
Mode page code: 0x08 Mode subpage code : 00
Meet the following performance requirements:
Random 4 KB Write IOPs >= 200 (Rotational drives exempt)
Random 4 KB Read IOPs >= 2000 (Rotational drives exempt)
Read/Write perf should scale linearly in mixed workload random access read/write
Sequential write speed >= 80 MB/s
Sequential read speed >= 80 MB/s
Max I/O Latency < 500 milliseconds
Maximum of 16 seconds sum-total of user-perceivable I/O latencies over any 1 hour period of a user-representative workload, where a user-perceivable I/O is defined as having a latency of at least 100 millisecond
Additional Information
Enforcement Date |
Jun. 26, 2013 |
Device.Storage.Optical
Related Requirements |
Device.Storage.Optical.CdRawRecording Device.Storage.Optical.CommandPerformance Device.Storage.Optical.DriveDefinition Device.Storage.Optical.Features Device.Storage.Optical.MmcVersion Device.Storage.Optical.Profiles Device.Storage.Optical.RealTimeStreaming |
Device.Storage.Optical.CdRawRecording
Optical Drives must support CD RAW Recording
Target Feature |
Device.Storage.Optical |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Optical drives must support CD RAW Recording Mode for CD-R and CD-RW profiles.
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Optical.CommandPerformance
Optical Drives must complete Performance Command within allowed time frames
Target Feature |
Device.Storage.Optical |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Optical Drives must complete all commands within the maximum allowed times according to the following table.
COMMAND |
Basic certification requirement (msec) |
Exception (exception criteria/ msec) |
GET CONFIGURATION |
20 |
|
GET EVENT STATUS NOTIFICATION |
20 |
|
GET PERFORMANCE |
20 |
|
INQUIRY |
20 |
|
MECHANISM STATUS |
20 |
|
MODE SELECT |
20 |
|
MODE SENSE |
20 |
|
PREVENT ALLOW MEDIUM REMOVAL |
20 |
|
READ TOC PMA ATIP |
20 |
|
READ BUFFER CAPACITY |
20 |
|
READ CAPACITY |
20 |
|
READ CD1,2,4 |
500 |
|
READ DISC INFORMATION |
50 |
|
READ FORMAT CAPACITIES |
20 |
|
READ TRACK INFORMATION |
20 |
|
REQUEST SENSE (when not following a command failed with error status) |
20 |
|
SEND OPC INFORMATION |
60000 |
For dual layer media, i.e. DVD+R DL, DVD-R DL, BD-RE DL / 70000 |
SET READ AHEAD |
20 |
|
SET STREAMING |
20 |
|
START STOP UNIT (Immed=1b) |
20 |
|
START STOP UNIT (Eject, Immed=0b) |
7000 |
|
START STOP UNIT (Inject, Immed=0b, until media is ready) |
25000 |
DVD-RAM / 40000For dual layer media, i.e. DVD+R DL, DVD-R DL, BD-RE DL / 30000 |
SYNCHRONIZE CACHE (Immed=1b) |
20 |
|
SYNCHRONIZE CACHE (Immed=0b) |
15000 |
|
TEST UNIT READY |
20 |
|
BLANK (Immed=1b) |
20 |
|
BLANK (Immed=0b) |
N/A |
|
CLOSE TRACK SESSION (Immed=1b) |
20 |
|
CLOSE TRACK SESSION (Immed=0b, close logical track or session, do not finalize disc) |
65000 |
DVD+R DL, DVD-R DL / 300000DVD-R SL, DVD-RW / 180000 |
CLOSE TRACK SESSION (Immed=0b, finalize disc) |
65000 |
DVD+R DL, 300000DVD-R SL, DVD-R DL DVD-RW / 900000 |
FORMAT UNIT (Immediate) |
20 |
|
LOAD/UNLOAD MEDIUM |
N/A |
|
READ101,2,4 |
500 |
DVD-RAM / 800 |
READ12 (not streaming)1,2,4 |
500 |
DVD-RAM / 800 |
READ12 (streaming)1,2,4 |
100 |
CD at 1X / 500; CD at 2x / 350; CD at 4x / 200 |
READ DISC STRUCTURE6 |
20 |
|
READ MEDIA SERIAL NUMBER2 |
500 |
|
REPORT KEY |
20 |
|
RESERVE TRACK |
N/A |
|
SEND CUE SHEET |
N/A |
|
SEND DISC STRUCTURE |
N/A |
|
SEND KEY |
20 |
|
SET CD SPEED |
20 |
|
WRITE 10 (FUA=0) 1,3 |
50 |
|
WRITE 12 (FUA=0) 1,3 |
50 |
|
WRITE BUFFER |
N/A |
|
ERASE |
N/A |
|
READ BUFFER |
N/A |
|
READ CD MSF1,2,4 |
500 |
|
REPAIR TRACK |
N/A |
|
SEEK10 |
N/A |
|
VERIFY 10 |
N/A |
|
WRITE AND VERIFY 10 |
N/A |
"Command completion time" is defined as the time between a command leaving the Microsoft port / miniport driver and the command completion being returned to the Microsoft port / miniport driver. If the command is failed with error status, this time also includes the subsequent Request Sense command leaving the Microsoft port / miniport driver and the Request Sense command completion being returned to the Microsoft port / miniport driver.All the command execution time performance measurement should be performed on media conforming to media physical layer standard specification from associated committees - i.e. DVD Forum, BDA, DVD+RW Alliance. Also, they should be performed under normal temperature and humidity operational condition as declared in the device specification.Note: Read-Only drives will be retired from the Windows certification Program on June 01, 2010. Hence, certification requirements and tests will cease to exist for Read-Only drives on June 01, 2010. Partners who wish to receive Windows certification on systems with Read-Only drives would still be a able to. However, the Read-Only drive would fall under the "unclassified" category of devices. 1: Transfer length for the read and write performance tests is equal or smaller to a single ECC block (32 or 64 KB depending of the current media type, i.e. 64KB for CD and BD, 32KB for DVD).2: Performance tests may be exercised at any speed reported as supported by the device, including 1x media speed if so reported as supported.3: Drive must make use of write buffer and shall not delay command completion by any form of media access. If write buffer is full, drive must fail the write command with long write in progress sense information (02h/04h/08h). 4: The first hundred read I/O commands after media arrival or resume from StandBy power state or Set Cd Speed or Set Streaming are permitted a delay up to a cumulative total of 60 000 msec to complete to allow for additional spin-up time. These commands individually may take any duration up to a limit of 7 000 msec, but the cumulative time to complete all hundred commands shall not exceed 60 000 msec. Only the time between when a read command is sent to the device and that read command is completed by the device is accounted for, the time between two successive read commands is not accounted for (i.e. host delays are not measured).6: The list of disc structure codes is limited to; physical format information (Format = 0x00, Address = 0), DVD-RAM medium status (Format = 0x09, Address = 0), DVD+RW write inhibit DCB (Format = 0x30 Address = 0x57444300), write protection status (Format = 0xC0 Address = 0)7:Dual Layer Write profile will be required on 1 June 2010 for Blu-Ray drives of 9.5 mm height and smaller as well as DVD drives 7mm height and smaller. This ends the previous exception for these form factors.
Additional Information
Enforcement Date |
Jun. 01, 2010 |
Device.Storage.Optical.DriveDefinition
How Optical Drives are Defined for certification
Target Feature |
Device.Storage.Optical |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
To be an Optical Drive, the device must be defined as CD (Compact Disc) device, DVD (Digital Versatile Disc or Digital Video Disc) device, BD (Blu-Ray Disc) device or any device which identifies itself as Peripheral Device Type 5 per INCITS's T10's command set SCSI Primary Commands, SPC (any revision).
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Optical.Features
Required Optical Drive Features
Target Feature |
Device.Storage.Optical |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Optical Drives must support the required Features listed below
Core Feature
Profile List Feature
Mandatory features per profile
Removable medium feature from Mt. Fuji 7
Reporting correct tray status
Power management feature
Morphing Feature
Drive Serial Number Feature
DVD CSS Feature (0106h)
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Optical.MmcVersion
Optical Drives must comply with MMC
Target Feature |
Device.Storage.Optical |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Optical Drives must conform to INCITS's T10's command set, MultiMedia Command Set - 6 (MMC-6), when published. Because the publication of MMC-6 has been delayed, Optical Drives must in the interim conform to the combination of INCITS's T10's command set MultiMedia Command Set - 5 (MMC-5) and SFF's Mt. Fuji Commands for Multimedia Devices Version 7 (INF-8090i v7) until publication of MMC-6. If and when MMC-5 and INF-8090i v7 contradict each other, and the following requirements do not specify explicitly the required behavior, compliance to MMC-5 is required (with the exception of features newly defined in INF-8090i v7).
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Optical.Profiles
Required Optical Drive Profiles
Target Feature |
Device.Storage.Optical |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Optical Drives must support the required profiles as listed below
CD-ROM
DVD-ROM
Removable Disk
CD-R
CD-RW
DVD-R Sequential Recording
DVD-RW Restricted Overwrite
DVD-R Dual Layer Sequential Recording
DVD+RW
DVD+R
DVD+R DL
Additional Information
Enforcement Date |
Jun. 01, 2010 |
Device.Storage.Optical.RealTimeStreaming
Optical Drives must support Real Time Streaming
Target Feature |
Device.Storage.Optical |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Optical Drives must support Real Time Streaming as required according to Profile requirements. For all recordable and rewritable profiles, the following fields shall be set accordingly: Stream Writing (SW)=1b and Write Speed Performance Descriptor (WSPD)=1b.
Additional Information
Enforcement Date |
Jun. 01, 2006 |
Device.Storage.Optical.BluRayReader
Related Requirements |
Device.Storage.Optical.BluRayReader.Profiles |
Device.Storage.Optical.BluRayReader.Profiles
Required Profiles for BluRay Readers
Target Feature |
Device.Storage.Optical.BluRayReader |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
BluRay Reader drives must support BD-ROM profile.
Additional Information
Enforcement Date |
Jun. 01, 2010 |
Device.Storage.Optical.BluRayWriter
Related Requirements |
Device.Storage.Optical.BluRayWriter.Profiles |
Device.Storage.Optical.BluRayWriter.Profiles
Required Profiles for BluRay Writers
Target Feature |
Device.Storage.Optical.BluRayWriter |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64 Windows 8.1 Client x86, x64 Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
BluRay Drives that can write must support BD-ROM, BD-R Sequential Recording and BD-RE profiles.
Additional Information
Enforcement Date |
Jun. 01, 2010 |
Device.Storage.Optical.Sata
Related Requirements |
Device.Storage.Optical.Sata.AsynchronousNotification |
Device.Storage.Optical.Sata.AsynchronousNotification
Asynchronous Notification is Required for all SATA connected drives.
Target Feature |
Device.Storage.Optical.Sata |
Applies to |
Windows 7 Client x86, x64 Windows 8 Client x86, x64, ARM (Windows RT) Windows 8.1 Client x86, x64, ARM (Windows RT 8.1) Windows Server 2012 R2 x64 Windows Server 2008 x86, x64, Windows Server 2008 Release 2 x64 Windows Server 2012 x64 |
Description
Optical Drives that connect via the SATA bus must support Asynchronous Notification.
Additional Information
Enforcement Date |
Jun. 01, 2010 |