Re: [RFC/PATCH v3] usb: usb3.0 ch9 definitions

From: Brokhman Tatyana
Date: Fri Oct 08 2010 - 08:35:55 EST



> On Thu, Oct 07, 2010 at 08:34:28PM +0200, Brokhman Tatyana wrote:
>> Adding SuperSpeed usb definitions as defined by ch9 of the USB3.0 spec.
>> This patch is a preparation for adding SuperSpeed support to the gadget
>> framework.
>>
>> Signed-off-by: Brokhman Tatyana <tlinder@xxxxxxxxxxxxxx>
>
> Is this still a [RFC] or is it something that you think should be
> applied to the tree?

You are right. It's not an RFC any more.
(Sorry, it's a first time for me.)

>> ---
>> include/linux/usb/ch9.h | 58
>> ++++++++++++++++++++++++++++++++++++++++++++++-
>> 1 files changed, 57 insertions(+), 1 deletions(-)
>>
>> diff --git a/include/linux/usb/ch9.h b/include/linux/usb/ch9.h
>> index da2ed77..a779b86 100644
>> --- a/include/linux/usb/ch9.h
>> +++ b/include/linux/usb/ch9.h
>> @@ -123,8 +123,23 @@
>> #define USB_DEVICE_A_ALT_HNP_SUPPORT 5 /* (otg) other RH port does */
>> #define USB_DEVICE_DEBUG_MODE 6 /* (special devices only) */
>>
>> +/*
>> + * New Feature Selectors as added by USB 3.0
>> + * See USB 3.0 spec Table 9-6
>> + */
>> +#define USB_DEVICE_U1_ENABLE 48 /* dev may initiate U1 transition */
>> +#define USB_DEVICE_U2_ENABLE 49 /* dev may initiate U2 transition*/
>> +#define USB_DEVICE_LTM_ENABLE 50 /* dev may send LTM*/
>> +#define USB_INTRF_FUNC_SUSPEND 0 /* function suspend*/
>> +
>> +#define USB_INTR_FUNC_SUSPEND_OPT_MASK 0xFF00
>> +
>> #define USB_ENDPOINT_HALT 0 /* IN/OUT will STALL */
>>
>> +/* Bit array elements as returned by the USB_REQ_GET_STATUS request. */
>> +#define USB_DEV_STAT_U1_ENABLED 2 /* transition into U1 state */
>> +#define USB_DEV_STAT_U2_ENABLED 3 /* transition into U2 state */
>> +#define USB_DEV_STAT_LTM_ENABLED 4 /* Latency tolerance messages*/
>>
>> /**
>> * struct usb_ctrlrequest - SETUP data for a USB device control request
>> @@ -675,6 +690,7 @@ struct usb_bos_descriptor {
>> __u8 bNumDeviceCaps;
>> } __attribute__((packed));
>>
>> +#define USB_DT_BOS_SIZE 5
>> /*-------------------------------------------------------------------------*/
>>
>> /* USB_DT_DEVICE_CAPABILITY: grouped with BOS */
>> @@ -712,16 +728,56 @@ struct usb_wireless_cap_descriptor { /* Ultra Wide
>> Band */
>> __u8 bReserved;
>> } __attribute__((packed));
>>
>> +/* USB 2.0 Extension descriptor */
>> #define USB_CAP_TYPE_EXT 2
>>
>> struct usb_ext_cap_descriptor { /* Link Power Management */
>> __u8 bLength;
>> __u8 bDescriptorType;
>> __u8 bDevCapabilityType;
>> - __u8 bmAttributes;
>> + __u32 bmAttributes;
>> #define USB_LPM_SUPPORT (1 << 1) /* supports LPM */
>> } __attribute__((packed));
>
> This structure just got bigger? How is that going to affect existing
> users of it? And shoudn't that be in __le32 format instead of __u32?

I didn't find any existing users of this structure.
I'll update it to _le32

>
>>
>> +#define USB_DT_USB_EXT_CAP_SIZE 7
>> +
>> +/*
>> + * SuperSpeed USB Capability descriptor: Defines the set of SuperSpeed
>> USB
>> + * specific device level capabilities
>> + */
>> +#define USB_SS_CAP_TYPE 3
>> +struct usb_ss_cap_descriptor { /* Link Power Management */
>> + __u8 bLength;
>> + __u8 bDescriptorType;
>> + __u8 bDevCapabilityType;
>> + __u8 bmAttributes;
>> +#define USB_LTM_SUPPORT (1 << 1) /* supports LTM */
>> + __u16 wSpeedSupported;
>
> __le16?

ok.

>
>> +#define USB_LOW_SPEED_OPERATION (1) /* Low speed operation */
>> +#define USB_FULL_SPEED_OPERATION (1 << 1) /* Full speed operation */
>> +#define USB_HIGH_SPEED_OPERATION (1 << 2) /* High speed operation */
>> +#define USB_5GBPS_OPERATION (1 << 3) /* Operation at 5Gbps */
>> + __u8 bFunctionalitySupport;
>> + __u8 bU1devExitLat;
>> + __u16 bU2DevExitLat;
>
> __le16? I'm guessing these fields haven't actually been used for
> anything?

Actually __bU2DevExitLat is not bitwise field so it can remain __u16. And
no, their values have been used for nothing but testing the descriptor.

>
>> +} __attribute__((packed));
>> +
>> +#define USB_DT_USB_SS_CAP_SIZE 10
>> +
>> +/*
>> + * Container ID Capability descriptor: Defines the instance unique ID
>> used to
>> + * identify the instance across all operating modes
>> + */
>> +#define CONTAINER_ID_TYPE 4
>> +struct usb_ss_container_id_descriptor {
>> + __u8 bLength;
>> + __u8 bDescriptorType;
>> + __u8 bDevCapabilityType;
>> + __u8 bReserved;
>> + __u8 ContainerID[16]; /* 128-bit number */
>
> Is this number in any specific endian format? If so, you're going to
> have a hard time handling it as an array of bytes, aren't you? How is
> this going to be managed?

It's not mentioned to be in any specific endian format. This is a 128-bit
number that is unique to a device instance and is used to uniquely
identify the device instance across all modes of operations.
Note that container ID is optional for all USB30 devices except for hubs.
We implemented SuperSpeed support in the gadget framework only so it
wasn't used by us. We defined it in order for this patch to be complete
with all USB30 required definitions.

>
> thanks,
>
> greg k-h
>


--
Sent by an consultant of the Qualcomm Innovation Center, Inc.
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum.


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/