1 /** @file
2   Definitions of functions for Driver Binding Protocol and Block I/O Protocol,
3   and other internal definitions.
4 
5 Copyright (c) 2007 - 2011, Intel Corporation. All rights reserved.<BR>
6 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
10 
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.
13 
14 **/
15 
16 #ifndef _EFI_USBMASS_IMPL_H_
17 #define _EFI_USBMASS_IMPL_H_
18 
19 #define  USB_MASS_SIGNATURE    SIGNATURE_32 ('U', 's', 'b', 'M')
20 
21 #define USB_MASS_DEVICE_FROM_BLOCK_IO(a) \
22         CR (a, USB_MASS_DEVICE, BlockIo, USB_MASS_SIGNATURE)
23 
24 #define USB_MASS_DEVICE_FROM_DISK_INFO(a) \
25         CR (a, USB_MASS_DEVICE, DiskInfo, USB_MASS_SIGNATURE)
26 
27 
28 extern EFI_COMPONENT_NAME_PROTOCOL   gUsbMassStorageComponentName;
29 extern EFI_COMPONENT_NAME2_PROTOCOL  gUsbMassStorageComponentName2;
30 
31 //
32 // Functions for Driver Binding Protocol
33 //
34 
35 /**
36   Check whether the controller is a supported USB mass storage.
37 
38   @param  This                   The USB mass storage driver binding protocol.
39   @param  Controller             The controller handle to check.
40   @param  RemainingDevicePath    The remaining device path.
41 
42   @retval EFI_SUCCESS            The driver supports this controller.
43   @retval other                  This device isn't supported.
44 
45 **/
46 EFI_STATUS
47 EFIAPI
48 USBMassDriverBindingSupported (
49   IN EFI_DRIVER_BINDING_PROTOCOL  *This,
50   IN EFI_HANDLE                   Controller,
51   IN EFI_DEVICE_PATH_PROTOCOL     *RemainingDevicePath
52   );
53 
54 /**
55   Starts the USB mass storage device with this driver.
56 
57   This function consumes USB I/O Portocol, intializes USB mass storage device,
58   installs Block I/O Protocol, and submits Asynchronous Interrupt
59   Transfer to manage the USB mass storage device.
60 
61   @param  This                  The USB mass storage driver binding protocol.
62   @param  Controller            The USB mass storage device to start on
63   @param  RemainingDevicePath   The remaining device path.
64 
65   @retval EFI_SUCCESS           This driver supports this device.
66   @retval EFI_UNSUPPORTED       This driver does not support this device.
67   @retval EFI_DEVICE_ERROR      This driver cannot be started due to device Error.
68   @retval EFI_OUT_OF_RESOURCES  Can't allocate memory resources.
69   @retval EFI_ALREADY_STARTED   This driver has been started.
70 
71 **/
72 EFI_STATUS
73 EFIAPI
74 USBMassDriverBindingStart (
75   IN EFI_DRIVER_BINDING_PROTOCOL  *This,
76   IN EFI_HANDLE                   Controller,
77   IN EFI_DEVICE_PATH_PROTOCOL     *RemainingDevicePath
78   );
79 
80 /**
81   Stop controlling the device.
82 
83   @param  This                   The USB mass storage driver binding
84   @param  Controller             The device controller controlled by the driver.
85   @param  NumberOfChildren       The number of children of this device
86   @param  ChildHandleBuffer      The buffer of children handle.
87 
88   @retval EFI_SUCCESS            The driver stopped from controlling the device.
89   @retval EFI_DEVICE_ERROR       The device could not be stopped due to a device error.
90   @retval EFI_UNSUPPORTED        Block I/O Protocol is not installed on Controller.
91   @retval Others                 Failed to stop the driver
92 
93 **/
94 EFI_STATUS
95 EFIAPI
96 USBMassDriverBindingStop (
97   IN  EFI_DRIVER_BINDING_PROTOCOL *This,
98   IN  EFI_HANDLE                  Controller,
99   IN  UINTN                       NumberOfChildren,
100   IN  EFI_HANDLE                  *ChildHandleBuffer
101   );
102 
103 //
104 // Functions for Block I/O Protocol
105 //
106 
107 /**
108   Reset the block device.
109 
110   This function implements EFI_BLOCK_IO_PROTOCOL.Reset().
111   It resets the block device hardware.
112   ExtendedVerification is ignored in this implementation.
113 
114   @param  This                   Indicates a pointer to the calling context.
115   @param  ExtendedVerification   Indicates that the driver may perform a more exhaustive
116                                  verification operation of the device during reset.
117 
118   @retval EFI_SUCCESS            The block device was reset.
119   @retval EFI_DEVICE_ERROR       The block device is not functioning correctly and could not be reset.
120 
121 **/
122 EFI_STATUS
123 EFIAPI
124 UsbMassReset (
125   IN EFI_BLOCK_IO_PROTOCOL    *This,
126   IN BOOLEAN                  ExtendedVerification
127   );
128 
129 /**
130   Reads the requested number of blocks from the device.
131 
132   This function implements EFI_BLOCK_IO_PROTOCOL.ReadBlocks().
133   It reads the requested number of blocks from the device.
134   All the blocks are read, or an error is returned.
135 
136   @param  This                   Indicates a pointer to the calling context.
137   @param  MediaId                The media ID that the read request is for.
138   @param  Lba                    The starting logical block address to read from on the device.
139   @param  BufferSize             The size of the Buffer in bytes.
140                                  This must be a multiple of the intrinsic block size of the device.
141   @param  Buffer                 A pointer to the destination buffer for the data. The caller is
142                                  responsible for either having implicit or explicit ownership of the buffer.
143 
144   @retval EFI_SUCCESS            The data was read correctly from the device.
145   @retval EFI_DEVICE_ERROR       The device reported an error while attempting to perform the read operation.
146   @retval EFI_NO_MEDIA           There is no media in the device.
147   @retval EFI_MEDIA_CHANGED      The MediaId is not for the current media.
148   @retval EFI_BAD_BUFFER_SIZE    The BufferSize parameter is not a multiple of the intrinsic block size of the device.
149   @retval EFI_INVALID_PARAMETER  The read request contains LBAs that are not valid,
150                                  or the buffer is not on proper alignment.
151 
152 **/
153 EFI_STATUS
154 EFIAPI
155 UsbMassReadBlocks (
156   IN EFI_BLOCK_IO_PROTOCOL    *This,
157   IN UINT32                   MediaId,
158   IN EFI_LBA                  Lba,
159   IN UINTN                    BufferSize,
160   OUT VOID                    *Buffer
161   );
162 
163 /**
164   Writes a specified number of blocks to the device.
165 
166   This function implements EFI_BLOCK_IO_PROTOCOL.WriteBlocks().
167   It writes a specified number of blocks to the device.
168   All blocks are written, or an error is returned.
169 
170   @param  This                   Indicates a pointer to the calling context.
171   @param  MediaId                The media ID that the write request is for.
172   @param  Lba                    The starting logical block address to be written.
173   @param  BufferSize             The size of the Buffer in bytes.
174                                  This must be a multiple of the intrinsic block size of the device.
175   @param  Buffer                 Pointer to the source buffer for the data.
176 
177   @retval EFI_SUCCESS            The data were written correctly to the device.
178   @retval EFI_WRITE_PROTECTED    The device cannot be written to.
179   @retval EFI_NO_MEDIA           There is no media in the device.
180   @retval EFI_MEDIA_CHANGED      The MediaId is not for the current media.
181   @retval EFI_DEVICE_ERROR       The device reported an error while attempting to perform the write operation.
182   @retval EFI_BAD_BUFFER_SIZE    The BufferSize parameter is not a multiple of the intrinsic
183                                  block size of the device.
184   @retval EFI_INVALID_PARAMETER  The write request contains LBAs that are not valid,
185                                  or the buffer is not on proper alignment.
186 
187 **/
188 EFI_STATUS
189 EFIAPI
190 UsbMassWriteBlocks (
191   IN EFI_BLOCK_IO_PROTOCOL    *This,
192   IN UINT32                   MediaId,
193   IN EFI_LBA                  Lba,
194   IN UINTN                    BufferSize,
195   IN VOID                     *Buffer
196   );
197 
198 /**
199   Flushes all modified data to a physical block device.
200 
201   This function implements EFI_BLOCK_IO_PROTOCOL.FlushBlocks().
202   USB mass storage device doesn't support write cache,
203   so return EFI_SUCCESS directly.
204 
205   @param  This                   Indicates a pointer to the calling context.
206 
207   @retval EFI_SUCCESS            All outstanding data were written correctly to the device.
208   @retval EFI_DEVICE_ERROR       The device reported an error while attempting to write data.
209   @retval EFI_NO_MEDIA           There is no media in the device.
210 
211 **/
212 EFI_STATUS
213 EFIAPI
214 UsbMassFlushBlocks (
215   IN EFI_BLOCK_IO_PROTOCOL  *This
216   );
217 
218 //
219 // EFI Component Name Functions
220 //
221 
222 /**
223   Retrieves a Unicode string that is the user readable name of the driver.
224 
225   This function retrieves the user readable name of a driver in the form of a
226   Unicode string. If the driver specified by This has a user readable name in
227   the language specified by Language, then a pointer to the driver name is
228   returned in DriverName, and EFI_SUCCESS is returned. If the driver specified
229   by This does not support the language specified by Language,
230   then EFI_UNSUPPORTED is returned.
231 
232   @param  This                  A pointer to the EFI_COMPONENT_NAME2_PROTOCOL or
233                                 EFI_COMPONENT_NAME_PROTOCOL instance.
234   @param  Language              A pointer to a Null-terminated ASCII string
235                                 array indicating the language. This is the
236                                 language of the driver name that the caller is
237                                 requesting, and it must match one of the
238                                 languages specified in SupportedLanguages. The
239                                 number of languages supported by a driver is up
240                                 to the driver writer. Language is specified
241                                 in RFC 4646 or ISO 639-2 language code format.
242   @param  DriverName            A pointer to the Unicode string to return.
243                                 This Unicode string is the name of the
244                                 driver specified by This in the language
245                                 specified by Language.
246 
247   @retval EFI_SUCCESS           The Unicode string for the Driver specified by
248                                 This and the language specified by Language was
249                                 returned in DriverName.
250   @retval EFI_INVALID_PARAMETER Language is NULL.
251   @retval EFI_INVALID_PARAMETER DriverName is NULL.
252   @retval EFI_UNSUPPORTED       The driver specified by This does not support
253                                 the language specified by Language.
254 
255 **/
256 EFI_STATUS
257 EFIAPI
258 UsbMassStorageGetDriverName (
259   IN  EFI_COMPONENT_NAME_PROTOCOL  *This,
260   IN  CHAR8                        *Language,
261   OUT CHAR16                       **DriverName
262   );
263 
264 
265 /**
266   Retrieves a Unicode string that is the user readable name of the controller
267   that is being managed by a driver.
268 
269   This function retrieves the user readable name of the controller specified by
270   ControllerHandle and ChildHandle in the form of a Unicode string. If the
271   driver specified by This has a user readable name in the language specified by
272   Language, then a pointer to the controller name is returned in ControllerName,
273   and EFI_SUCCESS is returned.  If the driver specified by This is not currently
274   managing the controller specified by ControllerHandle and ChildHandle,
275   then EFI_UNSUPPORTED is returned.  If the driver specified by This does not
276   support the language specified by Language, then EFI_UNSUPPORTED is returned.
277 
278   @param  This                  A pointer to the EFI_COMPONENT_NAME2_PROTOCOL or
279                                 EFI_COMPONENT_NAME_PROTOCOL instance.
280   @param  ControllerHandle      The handle of a controller that the driver
281                                 specified by This is managing.  This handle
282                                 specifies the controller whose name is to be
283                                 returned.
284   @param  ChildHandle           The handle of the child controller to retrieve
285                                 the name of.  This is an optional parameter that
286                                 may be NULL.  It will be NULL for device
287                                 drivers.  It will also be NULL for a bus drivers
288                                 that wish to retrieve the name of the bus
289                                 controller.  It will not be NULL for a bus
290                                 driver that wishes to retrieve the name of a
291                                 child controller.
292   @param  Language              A pointer to a Null-terminated ASCII string
293                                 array indicating the language.  This is the
294                                 language of the driver name that the caller is
295                                 requesting, and it must match one of the
296                                 languages specified in SupportedLanguages. The
297                                 number of languages supported by a driver is up
298                                 to the driver writer. Language is specified in
299                                 RFC 4646 or ISO 639-2 language code format.
300   @param  ControllerName        A pointer to the Unicode string to return.
301                                 This Unicode string is the name of the
302                                 controller specified by ControllerHandle and
303                                 ChildHandle in the language specified by
304                                 Language from the point of view of the driver
305                                 specified by This.
306 
307   @retval EFI_SUCCESS           The Unicode string for the user readable name in
308                                 the language specified by Language for the
309                                 driver specified by This was returned in
310                                 DriverName.
311   @retval EFI_INVALID_PARAMETER ControllerHandle is NULL.
312   @retval EFI_INVALID_PARAMETER ChildHandle is not NULL and it is not a valid
313                                 EFI_HANDLE.
314   @retval EFI_INVALID_PARAMETER Language is NULL.
315   @retval EFI_INVALID_PARAMETER ControllerName is NULL.
316   @retval EFI_UNSUPPORTED       The driver specified by This is not currently
317                                 managing the controller specified by
318                                 ControllerHandle and ChildHandle.
319   @retval EFI_UNSUPPORTED       The driver specified by This does not support
320                                 the language specified by Language.
321 
322 **/
323 EFI_STATUS
324 EFIAPI
325 UsbMassStorageGetControllerName (
326   IN  EFI_COMPONENT_NAME_PROTOCOL                     *This,
327   IN  EFI_HANDLE                                      ControllerHandle,
328   IN  EFI_HANDLE                                      ChildHandle        OPTIONAL,
329   IN  CHAR8                                           *Language,
330   OUT CHAR16                                          **ControllerName
331   );
332 
333 #endif
334