2 Definition of the command set of USB Mass Storage Specification
3 for Bootability, Revision 1.0.
5 Copyright (c) 2007 - 2008, Intel Corporation
6 All rights reserved. This program and the accompanying materials
7 are licensed and made available under the terms and conditions of the BSD License
8 which accompanies this distribution. The full text of the license may be found at
9 http://opensource.org/licenses/bsd-license.php
11 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
16 #ifndef _EFI_USB_MASS_BOOT_H_
17 #define _EFI_USB_MASS_BOOT_H_
23 // The opcodes of various USB boot commands:
24 // INQUIRY/REQUEST_SENSE are "No Timeout Commands" as specified
25 // by Multi-Media Commands (MMC) set.
26 // Others are "Group 1 Timeout Commands". That is,
27 // they should be retried if driver is ready.
29 USB_BOOT_INQUIRY_OPCODE
= 0x12,
30 USB_BOOT_REQUEST_SENSE_OPCODE
= 0x03,
31 USB_BOOT_MODE_SENSE10_OPCODE
= 0x5A,
32 USB_BOOT_READ_CAPACITY_OPCODE
= 0x25,
33 USB_BOOT_TEST_UNIT_READY_OPCODE
= 0x00,
34 USB_BOOT_READ10_OPCODE
= 0x28,
35 USB_BOOT_WRITE10_OPCODE
= 0x2A,
37 USB_SCSI_MODE_SENSE6_OPCODE
= 0x1A,
40 // The Sense Key part of the sense data. Sense data has three levels:
41 // Sense key, Additional Sense Code and Additional Sense Code Qualifier
43 USB_BOOT_SENSE_NO_SENSE
= 0x00, ///< No sense key
44 USB_BOOT_SENSE_RECOVERED
= 0x01, ///< Last command succeed with recovery actions
45 USB_BOOT_SENSE_NOT_READY
= 0x02, ///< Device not ready
46 USB_BOOT_SNESE_MEDIUM_ERROR
= 0X03, ///< Failed probably because flaw in the media
47 USB_BOOT_SENSE_HARDWARE_ERROR
= 0X04, ///< Non-recoverable hardware failure
48 USB_BOOT_SENSE_ILLEGAL_REQUEST
= 0X05, ///< Illegal parameters in the request
49 USB_BOOT_SENSE_UNIT_ATTENTION
= 0X06, ///< Removable medium may have been changed
50 USB_BOOT_SENSE_DATA_PROTECT
= 0X07, ///< Write protected
51 USB_BOOT_SENSE_BLANK_CHECK
= 0X08, ///< Blank/non-blank medium while reading/writing
52 USB_BOOT_SENSE_VENDOR
= 0X09, ///< Vendor specific sense key
53 USB_BOOT_SENSE_ABORTED
= 0X0B, ///< Command aborted by the device
54 USB_BOOT_SENSE_VOLUME_OVERFLOW
= 0x0D, ///< Partition overflow
55 USB_BOOT_SENSE_MISCOMPARE
= 0x0E, ///< Source data mis-match while verfying.
57 USB_BOOT_ASC_NOT_READY
= 0x04,
58 USB_BOOT_ASC_NO_MEDIA
= 0x3A,
59 USB_BOOT_ASC_MEDIA_CHANGE
= 0x28,
62 // Supported PDT codes, or Peripheral Device Type
64 USB_PDT_DIRECT_ACCESS
= 0x00, ///< Direct access device
65 USB_PDT_CDROM
= 0x05, ///< CDROM
66 USB_PDT_OPTICAL
= 0x07, ///< Non-CD optical disks
67 USB_PDT_SIMPLE_DIRECT
= 0x0E, ///< Simplified direct access device
70 // Other parameters, Max carried size is 512B * 128 = 64KB
72 USB_BOOT_IO_BLOCKS
= 128,
75 // Retry mass command times, set by experience
77 USB_BOOT_COMMAND_RETRY
= 5,
78 USB_BOOT_INIT_MEDIA_RETRY
= 5,
81 // Wait for unit ready command, set by experience
83 USB_BOOT_RETRY_UNIT_READY_STALL
= 500 * USB_MASS_1_MILLISECOND
,
86 // Mass command timeout, refers to specification[USB20-9.2.6.1]
88 // USB2.0 Spec define the up-limit timeout 5s for all command. USB floppy,
89 // USB CD-Rom and iPod devices are much slower than USB key when reponse
90 // most of commands, So we set 5s as timeout here.
92 USB_BOOT_GENERAL_CMD_TIMEOUT
= 5 * USB_MASS_1_SECOND
96 // The required commands are INQUIRY, READ CAPACITY, TEST UNIT READY,
97 // READ10, WRITE10, and REQUEST SENSE. The BLOCK_IO protocol uses LBA
98 // so it isn't necessary to issue MODE SENSE / READ FORMAT CAPACITY
99 // command to retrieve the disk gemotrics.
104 UINT8 Lun
; ///< Lun (high 3 bits)
109 } USB_BOOT_INQUIRY_CMD
;
112 UINT8 Pdt
; ///< Peripheral Device Type (low 5 bits)
113 UINT8 Removable
; ///< Removable Media (highest bit)
115 UINT8 AddLen
; ///< Additional length
119 UINT8 ProductRevision
[4];
120 } USB_BOOT_INQUIRY_DATA
;
127 } USB_BOOT_READ_CAPACITY_CMD
;
132 } USB_BOOT_READ_CAPACITY_DATA
;
139 } USB_BOOT_TEST_UNIT_READY_CMD
;
146 UINT8 ParaListLenMsb
;
147 UINT8 ParaListLenLsb
;
150 } USB_BOOT_MODE_SENSE10_CMD
;
153 UINT8 ModeDataLenMsb
;
154 UINT8 ModeDataLenLsb
;
158 } USB_BOOT_MODE_SENSE10_PARA_HEADER
;
162 UINT8 Lun
; ///< Lun (High 3 bits)
163 UINT8 Lba
[4]; ///< Logical block address
165 UINT8 TransferLen
[2]; ///< Transfer length
168 } USB_BOOT_READ10_CMD
;
175 UINT8 TransferLen
[2];
178 } USB_BOOT_WRITE10_CMD
;
182 UINT8 Lun
; ///< Lun (High 3 bits)
184 UINT8 AllocLen
; ///< Allocation length
187 } USB_BOOT_REQUEST_SENSE_CMD
;
192 UINT8 SenseKey
; ///< Sense key (low 4 bits)
194 UINT8 AddLen
; ///< Additional Sense length, 10
196 UINT8 ASC
; ///< Additional Sense Code
197 UINT8 ASCQ
; ///< Additional Sense Code Qualifier
199 } USB_BOOT_REQUEST_SENSE_DATA
;
208 } USB_SCSI_MODE_SENSE6_CMD
;
215 } USB_SCSI_MODE_SENSE6_PARA_HEADER
;
219 // Convert a LUN number to that in the command
221 #define USB_BOOT_LUN(Lun) ((Lun) << 5)
224 // Get the removable, PDT, and sense key bits from the command data
226 #define USB_BOOT_REMOVABLE(RmbByte) (((RmbByte) & BIT7) != 0)
227 #define USB_BOOT_PDT(Pdt) ((Pdt) & 0x1f)
228 #define USB_BOOT_SENSE_KEY(Key) ((Key) & 0x0f)
231 Get the parameters for the USB mass storage media.
233 This function get the parameters for the USB mass storage media,
234 It is used both to initialize the media during the Start() phase
235 of Driver Binding Protocol and to re-initialize it when the media is
236 changed. Althought the RemoveableMedia is unlikely to change,
237 it is also included here.
239 @param UsbMass The device to retrieve disk gemotric.
241 @retval EFI_SUCCESS The disk gemotric is successfully retrieved.
242 @retval Other Failed to get the parameters.
247 IN USB_MASS_DEVICE
*UsbMass
251 Execute TEST UNIT READY command to check if the device is ready.
253 @param UsbMass The device to test
255 @retval EFI_SUCCESS The device is ready.
256 @retval Others Device not ready.
261 IN USB_MASS_DEVICE
*UsbMass
265 Detect whether the removable media is present and whether it has changed.
267 @param UsbMass The device to check.
269 @retval EFI_SUCCESS The media status is successfully checked.
270 @retval Other Failed to detect media.
275 IN USB_MASS_DEVICE
*UsbMass
279 Read some blocks from the device.
281 @param UsbMass The USB mass storage device to read from
282 @param Lba The start block number
283 @param TotalBlock Total block number to read
284 @param Buffer The buffer to read to
286 @retval EFI_SUCCESS Data are read into the buffer
287 @retval Others Failed to read all the data
292 IN USB_MASS_DEVICE
*UsbMass
,
299 Write some blocks to the device.
301 @param UsbMass The USB mass storage device to write to
302 @param Lba The start block number
303 @param TotalBlock Total block number to write
304 @param Buffer Pointer to the source buffer for the data.
306 @retval EFI_SUCCESS Data are written into the buffer
307 @retval Others Failed to write all the data
312 IN USB_MASS_DEVICE
*UsbMass
,
319 Use the USB clear feature control transfer to clear the endpoint stall condition.
321 @param UsbIo The USB I/O Protocol instance
322 @param EndpointAddr The endpoint to clear stall for
324 @retval EFI_SUCCESS The endpoint stall condition is cleared.
325 @retval Others Failed to clear the endpoint stall condition.
329 UsbClearEndpointStall (
330 IN EFI_USB_IO_PROTOCOL
*UsbIo
,
331 IN UINT8 EndpointAddr