Skip to content

Commit 2c1cfa4

Browse files
committed
Merge tag 'usb-4.15-rc8' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb
Pull USB fixes from Greg KH: "Here are some small USB fixes and device ids for 4.15-rc8 Nothing major, small fixes for various devices, some resolutions for bugs found by fuzzers, and the usual handful of new device ids. All of these have been in linux-next with no reported issues" * tag 'usb-4.15-rc8' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb: Documentation: usb: fix typo in UVC gadgetfs config command usb: misc: usb3503: make sure reset is low for at least 100us uas: ignore UAS for Norelsys NS1068(X) chips USB: UDC core: fix double-free in usb_add_gadget_udc_release USB: fix usbmon BUG trigger usbip: vudc_tx: fix v_send_ret_submit() vulnerability to null xfer buffer usbip: remove kernel addresses from usb device and urb debug msgs usbip: fix vudc_rx: harden CMD_SUBMIT path to handle malicious input USB: serial: cp210x: add new device ID ELV ALC 8xxx USB: serial: cp210x: add IDs for LifeScan OneTouch Verio IQ
2 parents d5a047f + 1a2e91e commit 2c1cfa4

File tree

9 files changed

+63
-33
lines changed

9 files changed

+63
-33
lines changed

Documentation/usb/gadget-testing.txt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -693,7 +693,7 @@ such specification consists of a number of lines with an inverval value
693693
in each line. The rules stated above are best illustrated with an example:
694694

695695
# mkdir functions/uvc.usb0/control/header/h
696-
# cd functions/uvc.usb0/control/header/h
696+
# cd functions/uvc.usb0/control/
697697
# ln -s header/h class/fs
698698
# ln -s header/h class/ss
699699
# mkdir -p functions/uvc.usb0/streaming/uncompressed/u/360p

drivers/usb/gadget/udc/core.c

Lines changed: 13 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -1147,11 +1147,7 @@ int usb_add_gadget_udc_release(struct device *parent, struct usb_gadget *gadget,
11471147

11481148
udc = kzalloc(sizeof(*udc), GFP_KERNEL);
11491149
if (!udc)
1150-
goto err1;
1151-
1152-
ret = device_add(&gadget->dev);
1153-
if (ret)
1154-
goto err2;
1150+
goto err_put_gadget;
11551151

11561152
device_initialize(&udc->dev);
11571153
udc->dev.release = usb_udc_release;
@@ -1160,7 +1156,11 @@ int usb_add_gadget_udc_release(struct device *parent, struct usb_gadget *gadget,
11601156
udc->dev.parent = parent;
11611157
ret = dev_set_name(&udc->dev, "%s", kobject_name(&parent->kobj));
11621158
if (ret)
1163-
goto err3;
1159+
goto err_put_udc;
1160+
1161+
ret = device_add(&gadget->dev);
1162+
if (ret)
1163+
goto err_put_udc;
11641164

11651165
udc->gadget = gadget;
11661166
gadget->udc = udc;
@@ -1170,35 +1170,33 @@ int usb_add_gadget_udc_release(struct device *parent, struct usb_gadget *gadget,
11701170

11711171
ret = device_add(&udc->dev);
11721172
if (ret)
1173-
goto err4;
1173+
goto err_unlist_udc;
11741174

11751175
usb_gadget_set_state(gadget, USB_STATE_NOTATTACHED);
11761176
udc->vbus = true;
11771177

11781178
/* pick up one of pending gadget drivers */
11791179
ret = check_pending_gadget_drivers(udc);
11801180
if (ret)
1181-
goto err5;
1181+
goto err_del_udc;
11821182

11831183
mutex_unlock(&udc_lock);
11841184

11851185
return 0;
11861186

1187-
err5:
1187+
err_del_udc:
11881188
device_del(&udc->dev);
11891189

1190-
err4:
1190+
err_unlist_udc:
11911191
list_del(&udc->list);
11921192
mutex_unlock(&udc_lock);
11931193

1194-
err3:
1195-
put_device(&udc->dev);
11961194
device_del(&gadget->dev);
11971195

1198-
err2:
1199-
kfree(udc);
1196+
err_put_udc:
1197+
put_device(&udc->dev);
12001198

1201-
err1:
1199+
err_put_gadget:
12021200
put_device(&gadget->dev);
12031201
return ret;
12041202
}

drivers/usb/misc/usb3503.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -279,6 +279,8 @@ static int usb3503_probe(struct usb3503 *hub)
279279
if (gpio_is_valid(hub->gpio_reset)) {
280280
err = devm_gpio_request_one(dev, hub->gpio_reset,
281281
GPIOF_OUT_INIT_LOW, "usb3503 reset");
282+
/* Datasheet defines a hardware reset to be at least 100us */
283+
usleep_range(100, 10000);
282284
if (err) {
283285
dev_err(dev,
284286
"unable to request GPIO %d as reset pin (%d)\n",

drivers/usb/mon/mon_bin.c

Lines changed: 7 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1004,7 +1004,9 @@ static long mon_bin_ioctl(struct file *file, unsigned int cmd, unsigned long arg
10041004
break;
10051005

10061006
case MON_IOCQ_RING_SIZE:
1007+
mutex_lock(&rp->fetch_lock);
10071008
ret = rp->b_size;
1009+
mutex_unlock(&rp->fetch_lock);
10081010
break;
10091011

10101012
case MON_IOCT_RING_SIZE:
@@ -1231,12 +1233,16 @@ static int mon_bin_vma_fault(struct vm_fault *vmf)
12311233
unsigned long offset, chunk_idx;
12321234
struct page *pageptr;
12331235

1236+
mutex_lock(&rp->fetch_lock);
12341237
offset = vmf->pgoff << PAGE_SHIFT;
1235-
if (offset >= rp->b_size)
1238+
if (offset >= rp->b_size) {
1239+
mutex_unlock(&rp->fetch_lock);
12361240
return VM_FAULT_SIGBUS;
1241+
}
12371242
chunk_idx = offset / CHUNK_SIZE;
12381243
pageptr = rp->b_vec[chunk_idx].pg;
12391244
get_page(pageptr);
1245+
mutex_unlock(&rp->fetch_lock);
12401246
vmf->page = pageptr;
12411247
return 0;
12421248
}

drivers/usb/serial/cp210x.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -124,6 +124,7 @@ static const struct usb_device_id id_table[] = {
124124
{ USB_DEVICE(0x10C4, 0x8470) }, /* Juniper Networks BX Series System Console */
125125
{ USB_DEVICE(0x10C4, 0x8477) }, /* Balluff RFID */
126126
{ USB_DEVICE(0x10C4, 0x84B6) }, /* Starizona Hyperion */
127+
{ USB_DEVICE(0x10C4, 0x85A7) }, /* LifeScan OneTouch Verio IQ */
127128
{ USB_DEVICE(0x10C4, 0x85EA) }, /* AC-Services IBUS-IF */
128129
{ USB_DEVICE(0x10C4, 0x85EB) }, /* AC-Services CIS-IBUS */
129130
{ USB_DEVICE(0x10C4, 0x85F8) }, /* Virtenio Preon32 */
@@ -174,6 +175,7 @@ static const struct usb_device_id id_table[] = {
174175
{ USB_DEVICE(0x1843, 0x0200) }, /* Vaisala USB Instrument Cable */
175176
{ USB_DEVICE(0x18EF, 0xE00F) }, /* ELV USB-I2C-Interface */
176177
{ USB_DEVICE(0x18EF, 0xE025) }, /* ELV Marble Sound Board 1 */
178+
{ USB_DEVICE(0x18EF, 0xE030) }, /* ELV ALC 8xxx Battery Charger */
177179
{ USB_DEVICE(0x18EF, 0xE032) }, /* ELV TFD500 Data Logger */
178180
{ USB_DEVICE(0x1901, 0x0190) }, /* GE B850 CP2105 Recorder interface */
179181
{ USB_DEVICE(0x1901, 0x0193) }, /* GE B650 CP2104 PMC interface */

drivers/usb/storage/unusual_uas.h

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -143,6 +143,13 @@ UNUSUAL_DEV(0x2109, 0x0711, 0x0000, 0x9999,
143143
USB_SC_DEVICE, USB_PR_DEVICE, NULL,
144144
US_FL_NO_ATA_1X),
145145

146+
/* Reported-by: Icenowy Zheng <[email protected]> */
147+
UNUSUAL_DEV(0x2537, 0x1068, 0x0000, 0x9999,
148+
"Norelsys",
149+
"NS1068X",
150+
USB_SC_DEVICE, USB_PR_DEVICE, NULL,
151+
US_FL_IGNORE_UAS),
152+
146153
/* Reported-by: Takeo Nakayama <[email protected]> */
147154
UNUSUAL_DEV(0x357d, 0x7788, 0x0000, 0x9999,
148155
"JMicron",

drivers/usb/usbip/usbip_common.c

Lines changed: 3 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -91,7 +91,7 @@ static void usbip_dump_usb_device(struct usb_device *udev)
9191
dev_dbg(dev, " devnum(%d) devpath(%s) usb speed(%s)",
9292
udev->devnum, udev->devpath, usb_speed_string(udev->speed));
9393

94-
pr_debug("tt %p, ttport %d\n", udev->tt, udev->ttport);
94+
pr_debug("tt hub ttport %d\n", udev->ttport);
9595

9696
dev_dbg(dev, " ");
9797
for (i = 0; i < 16; i++)
@@ -124,12 +124,8 @@ static void usbip_dump_usb_device(struct usb_device *udev)
124124
}
125125
pr_debug("\n");
126126

127-
dev_dbg(dev, "parent %p, bus %p\n", udev->parent, udev->bus);
128-
129-
dev_dbg(dev,
130-
"descriptor %p, config %p, actconfig %p, rawdescriptors %p\n",
131-
&udev->descriptor, udev->config,
132-
udev->actconfig, udev->rawdescriptors);
127+
dev_dbg(dev, "parent %s, bus %s\n", dev_name(&udev->parent->dev),
128+
udev->bus->bus_name);
133129

134130
dev_dbg(dev, "have_langid %d, string_langid %d\n",
135131
udev->have_langid, udev->string_langid);
@@ -237,9 +233,6 @@ void usbip_dump_urb(struct urb *urb)
237233

238234
dev = &urb->dev->dev;
239235

240-
dev_dbg(dev, " urb :%p\n", urb);
241-
dev_dbg(dev, " dev :%p\n", urb->dev);
242-
243236
usbip_dump_usb_device(urb->dev);
244237

245238
dev_dbg(dev, " pipe :%08x ", urb->pipe);
@@ -248,11 +241,9 @@ void usbip_dump_urb(struct urb *urb)
248241

249242
dev_dbg(dev, " status :%d\n", urb->status);
250243
dev_dbg(dev, " transfer_flags :%08X\n", urb->transfer_flags);
251-
dev_dbg(dev, " transfer_buffer :%p\n", urb->transfer_buffer);
252244
dev_dbg(dev, " transfer_buffer_length:%d\n",
253245
urb->transfer_buffer_length);
254246
dev_dbg(dev, " actual_length :%d\n", urb->actual_length);
255-
dev_dbg(dev, " setup_packet :%p\n", urb->setup_packet);
256247

257248
if (urb->setup_packet && usb_pipetype(urb->pipe) == PIPE_CONTROL)
258249
usbip_dump_usb_ctrlrequest(
@@ -262,8 +253,6 @@ void usbip_dump_urb(struct urb *urb)
262253
dev_dbg(dev, " number_of_packets :%d\n", urb->number_of_packets);
263254
dev_dbg(dev, " interval :%d\n", urb->interval);
264255
dev_dbg(dev, " error_count :%d\n", urb->error_count);
265-
dev_dbg(dev, " context :%p\n", urb->context);
266-
dev_dbg(dev, " complete :%p\n", urb->complete);
267256
}
268257
EXPORT_SYMBOL_GPL(usbip_dump_urb);
269258

drivers/usb/usbip/vudc_rx.c

Lines changed: 19 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -120,6 +120,25 @@ static int v_recv_cmd_submit(struct vudc *udc,
120120
urb_p->new = 1;
121121
urb_p->seqnum = pdu->base.seqnum;
122122

123+
if (urb_p->ep->type == USB_ENDPOINT_XFER_ISOC) {
124+
/* validate packet size and number of packets */
125+
unsigned int maxp, packets, bytes;
126+
127+
maxp = usb_endpoint_maxp(urb_p->ep->desc);
128+
maxp *= usb_endpoint_maxp_mult(urb_p->ep->desc);
129+
bytes = pdu->u.cmd_submit.transfer_buffer_length;
130+
packets = DIV_ROUND_UP(bytes, maxp);
131+
132+
if (pdu->u.cmd_submit.number_of_packets < 0 ||
133+
pdu->u.cmd_submit.number_of_packets > packets) {
134+
dev_err(&udc->gadget.dev,
135+
"CMD_SUBMIT: isoc invalid num packets %d\n",
136+
pdu->u.cmd_submit.number_of_packets);
137+
ret = -EMSGSIZE;
138+
goto free_urbp;
139+
}
140+
}
141+
123142
ret = alloc_urb_from_cmd(&urb_p->urb, pdu, urb_p->ep->type);
124143
if (ret) {
125144
usbip_event_add(&udc->ud, VUDC_EVENT_ERROR_MALLOC);

drivers/usb/usbip/vudc_tx.c

Lines changed: 9 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -85,6 +85,13 @@ static int v_send_ret_submit(struct vudc *udc, struct urbp *urb_p)
8585
memset(&pdu_header, 0, sizeof(pdu_header));
8686
memset(&msg, 0, sizeof(msg));
8787

88+
if (urb->actual_length > 0 && !urb->transfer_buffer) {
89+
dev_err(&udc->gadget.dev,
90+
"urb: actual_length %d transfer_buffer null\n",
91+
urb->actual_length);
92+
return -1;
93+
}
94+
8895
if (urb_p->type == USB_ENDPOINT_XFER_ISOC)
8996
iovnum = 2 + urb->number_of_packets;
9097
else
@@ -100,8 +107,8 @@ static int v_send_ret_submit(struct vudc *udc, struct urbp *urb_p)
100107

101108
/* 1. setup usbip_header */
102109
setup_ret_submit_pdu(&pdu_header, urb_p);
103-
usbip_dbg_stub_tx("setup txdata seqnum: %d urb: %p\n",
104-
pdu_header.base.seqnum, urb);
110+
usbip_dbg_stub_tx("setup txdata seqnum: %d\n",
111+
pdu_header.base.seqnum);
105112
usbip_header_correct_endian(&pdu_header, 1);
106113

107114
iov[iovnum].iov_base = &pdu_header;

0 commit comments

Comments
 (0)