Skip to content

Commit c608f6b

Browse files
committed
Merge tag 'usb-6.2-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb
Pull USB fixes from Greg KH: "Here are some small USB fixes that resolve some reported problems. These include: - gadget driver fixes - dwc3 driver fix - typec driver fix - MAINTAINERS file update. All of these have been in linux-next with no reported problems" * tag 'usb-6.2-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb: usb: typec: ucsi: Don't attempt to resume the ports before they exist usb: gadget: udc: do not clear gadget driver.bus usb: gadget: f_uac2: Fix incorrect increment of bNumEndpoints usb: gadget: f_fs: Fix unbalanced spinlock in __ffs_ep0_queue_wait usb: dwc3: qcom: enable vbus override when in OTG dr-mode MAINTAINERS: Add myself as UVC Gadget Maintainer
2 parents dc0ce18 + f82060d commit c608f6b

21 files changed

+14
-19
lines changed

MAINTAINERS

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -21730,6 +21730,7 @@ F: include/uapi/linux/uvcvideo.h
2173021730

2173121731
USB WEBCAM GADGET
2173221732
M: Laurent Pinchart <[email protected]>
21733+
M: Daniel Scally <[email protected]>
2173321734
2173421735
S: Maintained
2173521736
F: drivers/usb/gadget/function/*uvc*

drivers/usb/dwc3/dwc3-qcom.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -901,7 +901,7 @@ static int dwc3_qcom_probe(struct platform_device *pdev)
901901
qcom->mode = usb_get_dr_mode(&qcom->dwc3->dev);
902902

903903
/* enable vbus override for device mode */
904-
if (qcom->mode == USB_DR_MODE_PERIPHERAL)
904+
if (qcom->mode != USB_DR_MODE_HOST)
905905
dwc3_qcom_vbus_override_enable(qcom, true);
906906

907907
/* register extcon to override sw_vbus on Vbus change later */

drivers/usb/fotg210/fotg210-udc.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1014,7 +1014,6 @@ static int fotg210_udc_start(struct usb_gadget *g,
10141014
int ret;
10151015

10161016
/* hook up the driver */
1017-
driver->driver.bus = NULL;
10181017
fotg210->driver = driver;
10191018

10201019
if (!IS_ERR_OR_NULL(fotg210->phy)) {

drivers/usb/gadget/function/f_fs.c

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -279,8 +279,10 @@ static int __ffs_ep0_queue_wait(struct ffs_data *ffs, char *data, size_t len)
279279
struct usb_request *req = ffs->ep0req;
280280
int ret;
281281

282-
if (!req)
282+
if (!req) {
283+
spin_unlock_irq(&ffs->ev.waitq.lock);
283284
return -EINVAL;
285+
}
284286

285287
req->zero = len < le16_to_cpu(ffs->ev.setup.wLength);
286288

drivers/usb/gadget/function/f_uac2.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1142,6 +1142,7 @@ afunc_bind(struct usb_configuration *cfg, struct usb_function *fn)
11421142
}
11431143
std_as_out_if0_desc.bInterfaceNumber = ret;
11441144
std_as_out_if1_desc.bInterfaceNumber = ret;
1145+
std_as_out_if1_desc.bNumEndpoints = 1;
11451146
uac2->as_out_intf = ret;
11461147
uac2->as_out_alt = 0;
11471148

drivers/usb/gadget/udc/bcm63xx_udc.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1830,7 +1830,6 @@ static int bcm63xx_udc_start(struct usb_gadget *gadget,
18301830
bcm63xx_select_phy_mode(udc, true);
18311831

18321832
udc->driver = driver;
1833-
driver->driver.bus = NULL;
18341833
udc->gadget.dev.of_node = udc->dev->of_node;
18351834

18361835
spin_unlock_irqrestore(&udc->lock, flags);

drivers/usb/gadget/udc/fsl_qe_udc.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2285,7 +2285,6 @@ static int fsl_qe_start(struct usb_gadget *gadget,
22852285
/* lock is needed but whether should use this lock or another */
22862286
spin_lock_irqsave(&udc->lock, flags);
22872287

2288-
driver->driver.bus = NULL;
22892288
/* hook up the driver */
22902289
udc->driver = driver;
22912290
udc->gadget.speed = driver->max_speed;

drivers/usb/gadget/udc/fsl_udc_core.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1943,7 +1943,6 @@ static int fsl_udc_start(struct usb_gadget *g,
19431943
/* lock is needed but whether should use this lock or another */
19441944
spin_lock_irqsave(&udc_controller->lock, flags);
19451945

1946-
driver->driver.bus = NULL;
19471946
/* hook up the driver */
19481947
udc_controller->driver = driver;
19491948
spin_unlock_irqrestore(&udc_controller->lock, flags);

drivers/usb/gadget/udc/fusb300_udc.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1311,7 +1311,6 @@ static int fusb300_udc_start(struct usb_gadget *g,
13111311
struct fusb300 *fusb300 = to_fusb300(g);
13121312

13131313
/* hook up the driver */
1314-
driver->driver.bus = NULL;
13151314
fusb300->driver = driver;
13161315

13171316
return 0;

drivers/usb/gadget/udc/goku_udc.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1375,7 +1375,6 @@ static int goku_udc_start(struct usb_gadget *g,
13751375
struct goku_udc *dev = to_goku_udc(g);
13761376

13771377
/* hook up the driver */
1378-
driver->driver.bus = NULL;
13791378
dev->driver = driver;
13801379

13811380
/*

0 commit comments

Comments
 (0)