diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2020-12-15 10:48:07 +0100 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2020-12-15 10:48:07 +0100 | 
| commit | 3c41e57a1e168d879e923c5583adeae47eec9f64 (patch) | |
| tree | e6272012c4b766189be2821316a3d23d115f5195 /drivers/usb/cdns3/gadget.c | |
| parent | d14ce74f1fb376ccbbc0b05ded477ada51253729 (diff) | |
| parent | 2f5fbc4305d07725bfebaedb09e57271315691ef (diff) | |
Merge tag 'irqchip-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/maz/arm-platforms into irq/core
Pull irqchip updates for 5.11 from Marc Zyngier:
  - Preliminary support for managed interrupts on platform devices
  - Correctly identify allocation of MSIs proxyied by another device
  - Remove the fasteoi IPI flow which has been proved useless
  - Generalise the Ocelot support to new SoCs
  - Improve GICv4.1 vcpu entry, matching the corresponding KVM optimisation
  - Work around spurious interrupts on Qualcomm PDC
  - Random fixes and cleanups
Link: https://lore.kernel.org/r/20201212135626.1479884-1-maz@kernel.org
Diffstat (limited to 'drivers/usb/cdns3/gadget.c')
| -rw-r--r-- | drivers/usb/cdns3/gadget.c | 26 | 
1 files changed, 14 insertions, 12 deletions
| diff --git a/drivers/usb/cdns3/gadget.c b/drivers/usb/cdns3/gadget.c index 66c1e6723eb1..365f30fb1159 100644 --- a/drivers/usb/cdns3/gadget.c +++ b/drivers/usb/cdns3/gadget.c @@ -1114,7 +1114,7 @@ static int cdns3_ep_run_transfer(struct cdns3_endpoint *priv_ep,  	struct cdns3_device *priv_dev = priv_ep->cdns3_dev;  	struct cdns3_request *priv_req;  	struct cdns3_trb *trb; -	struct cdns3_trb *link_trb; +	struct cdns3_trb *link_trb = NULL;  	dma_addr_t trb_dma;  	u32 togle_pcs = 1;  	int sg_iter = 0; @@ -1193,10 +1193,20 @@ static int cdns3_ep_run_transfer(struct cdns3_endpoint *priv_ep,  	/* set incorrect Cycle Bit for first trb*/  	control = priv_ep->pcs ? 0 : TRB_CYCLE; +	trb->length = 0; +	if (priv_dev->dev_ver >= DEV_VER_V2) { +		u16 td_size; + +		td_size = DIV_ROUND_UP(request->length, +				       priv_ep->endpoint.maxpacket); +		if (priv_dev->gadget.speed == USB_SPEED_SUPER) +			trb->length = TRB_TDL_SS_SIZE(td_size); +		else +			control |= TRB_TDL_HS_SIZE(td_size); +	}  	do {  		u32 length; -		u16 td_size = 0;  		/* fill TRB */  		control |= TRB_TYPE(TRB_NORMAL); @@ -1208,20 +1218,12 @@ static int cdns3_ep_run_transfer(struct cdns3_endpoint *priv_ep,  			length = request->length;  		} -		if (likely(priv_dev->dev_ver >= DEV_VER_V2)) -			td_size = DIV_ROUND_UP(length, -					       priv_ep->endpoint.maxpacket); -		else if (priv_ep->flags & EP_TDLCHK_EN) +		if (priv_ep->flags & EP_TDLCHK_EN)  			total_tdl += DIV_ROUND_UP(length,  					       priv_ep->endpoint.maxpacket); -		trb->length = cpu_to_le32(TRB_BURST_LEN(priv_ep->trb_burst_size) | +		trb->length |= cpu_to_le32(TRB_BURST_LEN(priv_ep->trb_burst_size) |  					TRB_LEN(length)); -		if (priv_dev->gadget.speed == USB_SPEED_SUPER) -			trb->length |= cpu_to_le32(TRB_TDL_SS_SIZE(td_size)); -		else -			control |= TRB_TDL_HS_SIZE(td_size); -  		pcs = priv_ep->pcs ? TRB_CYCLE : 0;  		/* | 
