On Sat, Sep 02, 2017 at 09:15:37AM +0100, Ard Biesheuvel wrote: > On 2 September 2017 at 07:41, Greg KH <gregkh@xxxxxxxxxxxxxxxxxxx> wrote: > > On Sat, Aug 19, 2017 at 04:17:39PM +0100, Ard Biesheuvel wrote: > >> In preparation of adding support for the Chaoskey USB stick to the > >> UEFI stub, import the USB I/O protocol declarations and related types > >> to linux/efi.h. > >> > >> Signed-off-by: Ard Biesheuvel <ard.biesheuvel@xxxxxxxxxx> > >> --- > >> include/linux/efi.h | 66 +++++++++++++++++++++++++++++++++++++++++++++++++++++ > >> 1 file changed, 66 insertions(+) > >> > >> diff --git a/include/linux/efi.h b/include/linux/efi.h > >> index 12e05118657c..253749cd9b62 100644 > >> --- a/include/linux/efi.h > >> +++ b/include/linux/efi.h > >> @@ -22,6 +22,7 @@ > >> #include <linux/pstore.h> > >> #include <linux/range.h> > >> #include <linux/reboot.h> > >> +#include <linux/usb/ch9.h> > >> #include <linux/uuid.h> > >> #include <linux/screen_info.h> > >> > >> @@ -622,6 +623,7 @@ void efi_native_runtime_setup(void); > >> #define EFI_MEMORY_ATTRIBUTES_TABLE_GUID EFI_GUID(0xdcfa911d, 0x26eb, 0x469f, 0xa2, 0x20, 0x38, 0xb7, 0xdc, 0x46, 0x12, 0x20) > >> #define EFI_CONSOLE_OUT_DEVICE_GUID EFI_GUID(0xd3b36f2c, 0xd551, 0x11d4, 0x9a, 0x46, 0x00, 0x90, 0x27, 0x3f, 0xc1, 0x4d) > >> #define APPLE_PROPERTIES_PROTOCOL_GUID EFI_GUID(0x91bd12fe, 0xf6c3, 0x44fb, 0xa5, 0xb7, 0x51, 0x22, 0xab, 0x30, 0x3a, 0xe0) > >> +#define EFI_USB_IO_PROTOCOL_GUID EFI_GUID(0x2b2f68d6, 0x0cd2, 0x44cf, 0x8e, 0x8b, 0xbb, 0xa2, 0x0b, 0x1b, 0x5b, 0x75) > >> > >> #define EFI_IMAGE_SECURITY_DATABASE_GUID EFI_GUID(0xd719b2cb, 0x3d3a, 0x4596, 0xa3, 0xbc, 0xda, 0xd0, 0x0e, 0x67, 0x65, 0x6f) > >> #define EFI_SHIM_LOCK_GUID EFI_GUID(0x605dab50, 0xe046, 0x4300, 0xab, 0xb6, 0x3d, 0xd8, 0x10, 0xdd, 0x8b, 0x23) > >> @@ -1569,4 +1571,68 @@ struct linux_efi_random_seed { > >> u8 bits[]; > >> }; > >> > >> +typedef enum { > >> + EfiUsbDataIn, > >> + EfiUsbDataOut, > >> + EfiUsbNoData > >> +} efi_usb_data_direction_t; > >> + > >> +#define EFI_USB_NOERROR 0x0000 > >> +#define EFI_USB_ERR_NOTEXECUTE 0x0001 > >> +#define EFI_USB_ERR_STALL 0x0002 > >> +#define EFI_USB_ERR_BUFFER 0x0004 > >> +#define EFI_USB_ERR_BABBLE 0x0008 > >> +#define EFI_USB_ERR_NAK 0x0010 > >> +#define EFI_USB_ERR_CRC 0x0020 > >> +#define EFI_USB_ERR_TIMEOUT 0x0040 > >> +#define EFI_USB_ERR_BITSTUFF 0x0080 > >> +#define EFI_USB_ERR_SYSTEM 0x0100 > >> + > >> +typedef struct { > >> + u8 request_type; > >> + u8 request; > >> + u16 value; > >> + u16 index; > >> + u16 length; > >> +} efi_usb_device_request_t; > > > > A typedef? > > > > Yes, we have plenty of those already in linux/efi.h for types defined > by the UEFI spec. But Linux doesn't use typedefs, no need to spread horrid coding styles of other operating systems into linux-only header files :) > > Also, those values are little-endian, right? And finally, they are > > crossing the user/kernel boundry, so they should be using the __ variant > > of the variable type, right? > > > > These are only used in code that runs in UEFI context, i.e., before > the decompressor runs and before ExitBootServices(). So none of these > concerns apply, AFAICT. So why do you need to define this structure at all, if it is only used in UEFI and not Linux? And again, they are little endian, right? > > And finally, why does efi.h care about device specific stuff like this? > > Are you going to want to add all different types of efi devices here in > > the future? That does not seem wise from a maintaince point-of-view... > > > > No. But having the ability to talk to USB devices in the firmware > context may be useful (given patch #2), although it would be *much* > better if the firmware had its own driver for the Chaoskey (and we > implemented one as well in the Tianocore project) patch 2 doesn't use these structures, so why are you defining them? Don't add things to the kernel that aren't used, that's just asking for trouble. thanks, greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-efi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html