usb: gadget: udc-xilinx: fix restricted __le16 degrades to integer warning

usb_ctrlrequest members wValue and wIndex are of type __le16, so to fix
this warnings we are using le16_to_cpu() macros.

Reported-by: kernel test robot <lkp@intel.com>
Closes: https://lore.kernel.org/all/202209020044.CX2PfZzM-lkp@intel.com/
Signed-off-by: Piyush Mehta <piyush.mehta@amd.com>
Link: https://lore.kernel.org/r/20230822063201.16929-2-piyush.mehta@amd.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Piyush Mehta 2023-08-22 12:01:59 +05:30 committed by Greg Kroah-Hartman
parent 2ccbe85456
commit 7f93e683bc

View File

@ -1615,13 +1615,13 @@ static void xudc_getstatus(struct xusb_udc *udc)
case USB_RECIP_INTERFACE: case USB_RECIP_INTERFACE:
break; break;
case USB_RECIP_ENDPOINT: case USB_RECIP_ENDPOINT:
epnum = udc->setup.wIndex & USB_ENDPOINT_NUMBER_MASK; epnum = le16_to_cpu(udc->setup.wIndex) & USB_ENDPOINT_NUMBER_MASK;
if (epnum >= XUSB_MAX_ENDPOINTS) if (epnum >= XUSB_MAX_ENDPOINTS)
goto stall; goto stall;
target_ep = &udc->ep[epnum]; target_ep = &udc->ep[epnum];
epcfgreg = udc->read_fn(udc->addr + target_ep->offset); epcfgreg = udc->read_fn(udc->addr + target_ep->offset);
halt = epcfgreg & XUSB_EP_CFG_STALL_MASK; halt = epcfgreg & XUSB_EP_CFG_STALL_MASK;
if (udc->setup.wIndex & USB_DIR_IN) { if (le16_to_cpu(udc->setup.wIndex) & USB_DIR_IN) {
if (!target_ep->is_in) if (!target_ep->is_in)
goto stall; goto stall;
} else { } else {
@ -1664,7 +1664,7 @@ static void xudc_set_clear_feature(struct xusb_udc *udc)
switch (udc->setup.bRequestType) { switch (udc->setup.bRequestType) {
case USB_RECIP_DEVICE: case USB_RECIP_DEVICE:
switch (udc->setup.wValue) { switch (le16_to_cpu(udc->setup.wValue)) {
case USB_DEVICE_TEST_MODE: case USB_DEVICE_TEST_MODE:
/* /*
* The Test Mode will be executed * The Test Mode will be executed
@ -1684,13 +1684,15 @@ static void xudc_set_clear_feature(struct xusb_udc *udc)
break; break;
case USB_RECIP_ENDPOINT: case USB_RECIP_ENDPOINT:
if (!udc->setup.wValue) { if (!udc->setup.wValue) {
endpoint = udc->setup.wIndex & USB_ENDPOINT_NUMBER_MASK; endpoint = le16_to_cpu(udc->setup.wIndex) &
USB_ENDPOINT_NUMBER_MASK;
if (endpoint >= XUSB_MAX_ENDPOINTS) { if (endpoint >= XUSB_MAX_ENDPOINTS) {
xudc_ep0_stall(udc); xudc_ep0_stall(udc);
return; return;
} }
target_ep = &udc->ep[endpoint]; target_ep = &udc->ep[endpoint];
outinbit = udc->setup.wIndex & USB_ENDPOINT_DIR_MASK; outinbit = le16_to_cpu(udc->setup.wIndex) &
USB_ENDPOINT_DIR_MASK;
outinbit = outinbit >> 7; outinbit = outinbit >> 7;
/* Make sure direction matches.*/ /* Make sure direction matches.*/
@ -1867,7 +1869,7 @@ static void xudc_ep0_in(struct xusb_udc *udc)
u16 count = 0; u16 count = 0;
u16 length; u16 length;
u8 *ep0rambase; u8 *ep0rambase;
u8 test_mode = udc->setup.wIndex >> 8; u8 test_mode = le16_to_cpu(udc->setup.wIndex) >> 8;
req = list_first_entry(&ep0->queue, struct xusb_req, queue); req = list_first_entry(&ep0->queue, struct xusb_req, queue);
bytes_to_tx = req->usb_req.length - req->usb_req.actual; bytes_to_tx = req->usb_req.length - req->usb_req.actual;
@ -1878,12 +1880,12 @@ static void xudc_ep0_in(struct xusb_udc *udc)
case USB_REQ_SET_ADDRESS: case USB_REQ_SET_ADDRESS:
/* Set the address of the device.*/ /* Set the address of the device.*/
udc->write_fn(udc->addr, XUSB_ADDRESS_OFFSET, udc->write_fn(udc->addr, XUSB_ADDRESS_OFFSET,
udc->setup.wValue); le16_to_cpu(udc->setup.wValue));
break; break;
case USB_REQ_SET_FEATURE: case USB_REQ_SET_FEATURE:
if (udc->setup.bRequestType == if (udc->setup.bRequestType ==
USB_RECIP_DEVICE) { USB_RECIP_DEVICE) {
if (udc->setup.wValue == if (le16_to_cpu(udc->setup.wValue) ==
USB_DEVICE_TEST_MODE) USB_DEVICE_TEST_MODE)
udc->write_fn(udc->addr, udc->write_fn(udc->addr,
XUSB_TESTMODE_OFFSET, XUSB_TESTMODE_OFFSET,