提交 76f4af8e 编写于 作者: A Alan Stern 提交者: Greg Kroah-Hartman

[PATCH] USB: g_file_storage: Consolidate min()s

This patch simplifies the g_file_storage driver by consolidating a bunch
of min() calculations at a single spot.
Signed-off-by: NAlan Stern <stern@rowland.harvard.edu>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 020f46a3
...@@ -1312,7 +1312,7 @@ static int class_setup_req(struct fsg_dev *fsg, ...@@ -1312,7 +1312,7 @@ static int class_setup_req(struct fsg_dev *fsg,
} }
VDBG(fsg, "get max LUN\n"); VDBG(fsg, "get max LUN\n");
*(u8 *) req->buf = fsg->nluns - 1; *(u8 *) req->buf = fsg->nluns - 1;
value = min(w_length, (u16) 1); value = 1;
break; break;
} }
} }
...@@ -1360,7 +1360,6 @@ static int standard_setup_req(struct fsg_dev *fsg, ...@@ -1360,7 +1360,6 @@ static int standard_setup_req(struct fsg_dev *fsg,
int value = -EOPNOTSUPP; int value = -EOPNOTSUPP;
u16 w_index = ctrl->wIndex; u16 w_index = ctrl->wIndex;
u16 w_value = ctrl->wValue; u16 w_value = ctrl->wValue;
u16 w_length = ctrl->wLength;
/* Usually this just stores reply data in the pre-allocated ep0 buffer, /* Usually this just stores reply data in the pre-allocated ep0 buffer,
* but config change events will also reconfigure hardware. */ * but config change events will also reconfigure hardware. */
...@@ -1374,7 +1373,7 @@ static int standard_setup_req(struct fsg_dev *fsg, ...@@ -1374,7 +1373,7 @@ static int standard_setup_req(struct fsg_dev *fsg,
case USB_DT_DEVICE: case USB_DT_DEVICE:
VDBG(fsg, "get device descriptor\n"); VDBG(fsg, "get device descriptor\n");
value = min(w_length, (u16) sizeof device_desc); value = sizeof device_desc;
memcpy(req->buf, &device_desc, value); memcpy(req->buf, &device_desc, value);
break; break;
#ifdef CONFIG_USB_GADGET_DUALSPEED #ifdef CONFIG_USB_GADGET_DUALSPEED
...@@ -1382,7 +1381,7 @@ static int standard_setup_req(struct fsg_dev *fsg, ...@@ -1382,7 +1381,7 @@ static int standard_setup_req(struct fsg_dev *fsg,
VDBG(fsg, "get device qualifier\n"); VDBG(fsg, "get device qualifier\n");
if (!fsg->gadget->is_dualspeed) if (!fsg->gadget->is_dualspeed)
break; break;
value = min(w_length, (u16) sizeof dev_qualifier); value = sizeof dev_qualifier;
memcpy(req->buf, &dev_qualifier, value); memcpy(req->buf, &dev_qualifier, value);
break; break;
...@@ -1401,8 +1400,6 @@ static int standard_setup_req(struct fsg_dev *fsg, ...@@ -1401,8 +1400,6 @@ static int standard_setup_req(struct fsg_dev *fsg,
req->buf, req->buf,
w_value >> 8, w_value >> 8,
w_value & 0xff); w_value & 0xff);
if (value >= 0)
value = min(w_length, (u16) value);
break; break;
case USB_DT_STRING: case USB_DT_STRING:
...@@ -1411,8 +1408,6 @@ static int standard_setup_req(struct fsg_dev *fsg, ...@@ -1411,8 +1408,6 @@ static int standard_setup_req(struct fsg_dev *fsg,
/* wIndex == language code */ /* wIndex == language code */
value = usb_gadget_get_string(&stringtab, value = usb_gadget_get_string(&stringtab,
w_value & 0xff, req->buf); w_value & 0xff, req->buf);
if (value >= 0)
value = min(w_length, (u16) value);
break; break;
} }
break; break;
...@@ -1438,7 +1433,7 @@ static int standard_setup_req(struct fsg_dev *fsg, ...@@ -1438,7 +1433,7 @@ static int standard_setup_req(struct fsg_dev *fsg,
break; break;
VDBG(fsg, "get configuration\n"); VDBG(fsg, "get configuration\n");
*(u8 *) req->buf = fsg->config; *(u8 *) req->buf = fsg->config;
value = min(w_length, (u16) 1); value = 1;
break; break;
case USB_REQ_SET_INTERFACE: case USB_REQ_SET_INTERFACE:
...@@ -1466,14 +1461,14 @@ static int standard_setup_req(struct fsg_dev *fsg, ...@@ -1466,14 +1461,14 @@ static int standard_setup_req(struct fsg_dev *fsg,
} }
VDBG(fsg, "get interface\n"); VDBG(fsg, "get interface\n");
*(u8 *) req->buf = 0; *(u8 *) req->buf = 0;
value = min(w_length, (u16) 1); value = 1;
break; break;
default: default:
VDBG(fsg, VDBG(fsg,
"unknown control req %02x.%02x v%04x i%04x l%u\n", "unknown control req %02x.%02x v%04x i%04x l%u\n",
ctrl->bRequestType, ctrl->bRequest, ctrl->bRequestType, ctrl->bRequest,
w_value, w_index, w_length); w_value, w_index, ctrl->wLength);
} }
return value; return value;
...@@ -1485,6 +1480,7 @@ static int fsg_setup(struct usb_gadget *gadget, ...@@ -1485,6 +1480,7 @@ static int fsg_setup(struct usb_gadget *gadget,
{ {
struct fsg_dev *fsg = get_gadget_data(gadget); struct fsg_dev *fsg = get_gadget_data(gadget);
int rc; int rc;
int w_length = ctrl->wLength;
++fsg->ep0_req_tag; // Record arrival of a new request ++fsg->ep0_req_tag; // Record arrival of a new request
fsg->ep0req->context = NULL; fsg->ep0req->context = NULL;
...@@ -1498,8 +1494,9 @@ static int fsg_setup(struct usb_gadget *gadget, ...@@ -1498,8 +1494,9 @@ static int fsg_setup(struct usb_gadget *gadget,
/* Respond with data/status or defer until later? */ /* Respond with data/status or defer until later? */
if (rc >= 0 && rc != DELAYED_STATUS) { if (rc >= 0 && rc != DELAYED_STATUS) {
rc = min(rc, w_length);
fsg->ep0req->length = rc; fsg->ep0req->length = rc;
fsg->ep0req->zero = (rc < ctrl->wLength && fsg->ep0req->zero = (rc < w_length &&
(rc % gadget->ep0->maxpacket) == 0); (rc % gadget->ep0->maxpacket) == 0);
fsg->ep0req_name = (ctrl->bRequestType & USB_DIR_IN ? fsg->ep0req_name = (ctrl->bRequestType & USB_DIR_IN ?
"ep0-in" : "ep0-out"); "ep0-in" : "ep0-out");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册