UPSTREAM: USB: gadget: bRequestType is a bitfield, not a enum
[ Upstream commit f08adf5add9a071160c68bb2a61d697f39ab0758 ]
Szymon rightly pointed out that the previous check for the endpoint
direction in bRequestType was not looking at only the bit involved, but
rather the whole value.  Normally this is ok, but for some request
types, bits other than bit 8 could be set and the check for the endpoint
length could not stall correctly.
Fix that up by only checking the single bit.
Fixes: 153a2d7e3350 ("USB: gadget: detect too-big endpoint 0 requests")
Cc: Felipe Balbi <balbi@kernel.org>
Reported-by:  Szymon Heidrich <szymon.heidrich@gmail.com>
Link: https://lore.kernel.org/r/20211214184621.385828-1-gregkh@linuxfoundation.org
Signed-off-by:
Szymon Heidrich <szymon.heidrich@gmail.com>
Link: https://lore.kernel.org/r/20211214184621.385828-1-gregkh@linuxfoundation.org
Signed-off-by:  Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by:
Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by:  Sasha Levin <sashal@kernel.org>
Change-Id: I00b653c2393a25e13c5c1a10dffa2b0ee676c873
Sasha Levin <sashal@kernel.org>
Change-Id: I00b653c2393a25e13c5c1a10dffa2b0ee676c873
Loading
Please register or sign in to comment
