Commit 06f9b6e5 authored by Huang Rui's avatar Huang Rui Committed by Felipe Balbi

usb: dwc3: fix wrong bit mask in dwc3_event_devt

Around DWC USB3 2.30a release another bit has been added to the
Device-Specific Event (DEVT) Event Information (EvtInfo) bitfield.

Because of that, what used to be 8 bits long, has become 9 bits long.

Per dwc3 2.30a+ spec in the Device-Specific Event (DEVT), the field of
Event Information Bits(EvtInfo) uses [24:16] bits, and it has 9 bits
not 8 bits. And the following reserved field uses [31:25] bits not
[31:24] bits, and it has 7 bits.

So in dwc3_event_devt, the bit mask should be:
event_info	[24:16]		9 bits
reserved31_25	[31:25]		7 bits

This patch makes sure that newer core releases will work fine with
Linux and that we will decode the event information properly on new
core releases.

[ balbi@ti.com : improve commit log a bit ]

Cc: <stable@vger.kernel.org>
Signed-off-by: default avatarHuang Rui <ray.huang@amd.com>
Signed-off-by: default avatarFelipe Balbi <balbi@ti.com>
parent 798a2468
...@@ -815,15 +815,15 @@ struct dwc3_event_depevt { ...@@ -815,15 +815,15 @@ struct dwc3_event_depevt {
* 12 - VndrDevTstRcved * 12 - VndrDevTstRcved
* @reserved15_12: Reserved, not used * @reserved15_12: Reserved, not used
* @event_info: Information about this event * @event_info: Information about this event
* @reserved31_24: Reserved, not used * @reserved31_25: Reserved, not used
*/ */
struct dwc3_event_devt { struct dwc3_event_devt {
u32 one_bit:1; u32 one_bit:1;
u32 device_event:7; u32 device_event:7;
u32 type:4; u32 type:4;
u32 reserved15_12:4; u32 reserved15_12:4;
u32 event_info:8; u32 event_info:9;
u32 reserved31_24:8; u32 reserved31_25:7;
} __packed; } __packed;
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment