USB fixes for 4.10-rc5

Here are a few small USB fixes for 4.10-rc5.
 
 Most of these are gadget/dwc2 fixes for reported issues, all of these
 have been in linux-next for a while.  The last one is a single xhci
 WARN_ON removal to handle an issue that the dwc3 driver is hitting in
 the 4.10-rc tree.  The warning is harmless and needs to be removed, and
 a "real" fix that is more complex will show up in 4.11-rc1 for this
 device.
 
 That last patch hasn't been in linux-next yet due to the weekend timing,
 but it's a "simple" WARN_ON() removal so what could go wrong?  :)
 
 Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
 -----BEGIN PGP SIGNATURE-----
 
 iG0EABECAC0WIQT0tgzFv3jCIUoxPcsxR9QN2y37KQUCWIMpoA8cZ3JlZ0Brcm9h
 aC5jb20ACgkQMUfUDdst+ynMpgCbBihuNVTIFrDO3/10zMTiC0O71NsAoNnMBA6B
 qwwmm9AuY8Ja+Ch384FD
 =+nqh
 -----END PGP SIGNATURE-----

Merge tag 'usb-4.10-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb

Pull USB fixes from Greg KH:
 "Here are a few small USB fixes for 4.10-rc5.

  Most of these are gadget/dwc2 fixes for reported issues, all of these
  have been in linux-next for a while. The last one is a single xhci
  WARN_ON removal to handle an issue that the dwc3 driver is hitting in
  the 4.10-rc tree. The warning is harmless and needs to be removed, and
  a "real" fix that is more complex will show up in 4.11-rc1 for this
  device.

  That last patch hasn't been in linux-next yet due to the weekend
  timing, but it's a "simple" WARN_ON() removal so what could go wrong?
  :)"

Famous last words.

* tag 'usb-4.10-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb:
  xhci: remove WARN_ON if dma mask is not set for platform devices
  usb: dwc2: host: fix Wmaybe-uninitialized warning
  usb: dwc2: gadget: Fix GUSBCFG.USBTRDTIM value
  usb: gadget: udc: atmel: remove memory leak
  usb: dwc3: exynos fix axius clock error path to do cleanup
  usb: dwc2: Avoid suspending if we're in gadget mode
  usb: dwc2: use u32 for DT binding parameters
  usb: gadget: f_fs: Fix iterations on endpoints.
  usb: dwc2: gadget: Fix DMA memory freeing
  usb: gadget: composite: Fix function used to free memory
This commit is contained in:
Linus Torvalds 2017-01-21 19:01:06 -08:00
commit c497f8d172
10 changed files with 31 additions and 32 deletions

View File

@ -513,8 +513,8 @@ struct dwc2_core_params {
/* Gadget parameters */ /* Gadget parameters */
bool g_dma; bool g_dma;
bool g_dma_desc; bool g_dma_desc;
u16 g_rx_fifo_size; u32 g_rx_fifo_size;
u16 g_np_tx_fifo_size; u32 g_np_tx_fifo_size;
u32 g_tx_fifo_size[MAX_EPS_CHANNELS]; u32 g_tx_fifo_size[MAX_EPS_CHANNELS];
}; };

View File

@ -3169,7 +3169,7 @@ void dwc2_hsotg_core_init_disconnected(struct dwc2_hsotg *hsotg,
/* keep other bits untouched (so e.g. forced modes are not lost) */ /* keep other bits untouched (so e.g. forced modes are not lost) */
usbcfg = dwc2_readl(hsotg->regs + GUSBCFG); usbcfg = dwc2_readl(hsotg->regs + GUSBCFG);
usbcfg &= ~(GUSBCFG_TOUTCAL_MASK | GUSBCFG_PHYIF16 | GUSBCFG_SRPCAP | usbcfg &= ~(GUSBCFG_TOUTCAL_MASK | GUSBCFG_PHYIF16 | GUSBCFG_SRPCAP |
GUSBCFG_HNPCAP); GUSBCFG_HNPCAP | GUSBCFG_USBTRDTIM_MASK);
if (hsotg->params.phy_type == DWC2_PHY_TYPE_PARAM_FS && if (hsotg->params.phy_type == DWC2_PHY_TYPE_PARAM_FS &&
(hsotg->params.speed == DWC2_SPEED_PARAM_FULL || (hsotg->params.speed == DWC2_SPEED_PARAM_FULL ||
@ -3749,8 +3749,8 @@ static int dwc2_hsotg_ep_enable(struct usb_ep *ep,
__func__, epctrl, epctrl_reg); __func__, epctrl, epctrl_reg);
/* Allocate DMA descriptor chain for non-ctrl endpoints */ /* Allocate DMA descriptor chain for non-ctrl endpoints */
if (using_desc_dma(hsotg)) { if (using_desc_dma(hsotg) && !hs_ep->desc_list) {
hs_ep->desc_list = dma_alloc_coherent(hsotg->dev, hs_ep->desc_list = dmam_alloc_coherent(hsotg->dev,
MAX_DMA_DESC_NUM_GENERIC * MAX_DMA_DESC_NUM_GENERIC *
sizeof(struct dwc2_dma_desc), sizeof(struct dwc2_dma_desc),
&hs_ep->desc_list_dma, GFP_ATOMIC); &hs_ep->desc_list_dma, GFP_ATOMIC);
@ -3872,7 +3872,7 @@ error1:
error2: error2:
if (ret && using_desc_dma(hsotg) && hs_ep->desc_list) { if (ret && using_desc_dma(hsotg) && hs_ep->desc_list) {
dma_free_coherent(hsotg->dev, MAX_DMA_DESC_NUM_GENERIC * dmam_free_coherent(hsotg->dev, MAX_DMA_DESC_NUM_GENERIC *
sizeof(struct dwc2_dma_desc), sizeof(struct dwc2_dma_desc),
hs_ep->desc_list, hs_ep->desc_list_dma); hs_ep->desc_list, hs_ep->desc_list_dma);
hs_ep->desc_list = NULL; hs_ep->desc_list = NULL;
@ -3902,14 +3902,6 @@ static int dwc2_hsotg_ep_disable(struct usb_ep *ep)
return -EINVAL; return -EINVAL;
} }
/* Remove DMA memory allocated for non-control Endpoints */
if (using_desc_dma(hsotg)) {
dma_free_coherent(hsotg->dev, MAX_DMA_DESC_NUM_GENERIC *
sizeof(struct dwc2_dma_desc),
hs_ep->desc_list, hs_ep->desc_list_dma);
hs_ep->desc_list = NULL;
}
epctrl_reg = dir_in ? DIEPCTL(index) : DOEPCTL(index); epctrl_reg = dir_in ? DIEPCTL(index) : DOEPCTL(index);
spin_lock_irqsave(&hsotg->lock, flags); spin_lock_irqsave(&hsotg->lock, flags);
@ -4131,7 +4123,7 @@ static void dwc2_hsotg_init(struct dwc2_hsotg *hsotg)
/* keep other bits untouched (so e.g. forced modes are not lost) */ /* keep other bits untouched (so e.g. forced modes are not lost) */
usbcfg = dwc2_readl(hsotg->regs + GUSBCFG); usbcfg = dwc2_readl(hsotg->regs + GUSBCFG);
usbcfg &= ~(GUSBCFG_TOUTCAL_MASK | GUSBCFG_PHYIF16 | GUSBCFG_SRPCAP | usbcfg &= ~(GUSBCFG_TOUTCAL_MASK | GUSBCFG_PHYIF16 | GUSBCFG_SRPCAP |
GUSBCFG_HNPCAP); GUSBCFG_HNPCAP | GUSBCFG_USBTRDTIM_MASK);
/* set the PLL on, remove the HNP/SRP and set the PHY */ /* set the PLL on, remove the HNP/SRP and set the PHY */
trdtim = (hsotg->phyif == GUSBCFG_PHYIF8) ? 9 : 5; trdtim = (hsotg->phyif == GUSBCFG_PHYIF8) ? 9 : 5;

View File

@ -4367,6 +4367,9 @@ static int _dwc2_hcd_suspend(struct usb_hcd *hcd)
if (!HCD_HW_ACCESSIBLE(hcd)) if (!HCD_HW_ACCESSIBLE(hcd))
goto unlock; goto unlock;
if (hsotg->op_state == OTG_STATE_B_PERIPHERAL)
goto unlock;
if (!hsotg->params.hibernation) if (!hsotg->params.hibernation)
goto skip_power_saving; goto skip_power_saving;
@ -4489,8 +4492,8 @@ static void dwc2_dump_urb_info(struct usb_hcd *hcd, struct urb *urb,
{ {
#ifdef VERBOSE_DEBUG #ifdef VERBOSE_DEBUG
struct dwc2_hsotg *hsotg = dwc2_hcd_to_hsotg(hcd); struct dwc2_hsotg *hsotg = dwc2_hcd_to_hsotg(hcd);
char *pipetype; char *pipetype = NULL;
char *speed; char *speed = NULL;
dev_vdbg(hsotg->dev, "%s, urb %p\n", fn_name, urb); dev_vdbg(hsotg->dev, "%s, urb %p\n", fn_name, urb);
dev_vdbg(hsotg->dev, " Device address: %d\n", dev_vdbg(hsotg->dev, " Device address: %d\n",

View File

@ -385,16 +385,16 @@ static void dwc2_set_param(struct dwc2_hsotg *hsotg, void *param,
} }
/** /**
* dwc2_set_param_u16() - Set a u16 parameter * dwc2_set_param_u32() - Set a u32 parameter
* *
* See dwc2_set_param(). * See dwc2_set_param().
*/ */
static void dwc2_set_param_u16(struct dwc2_hsotg *hsotg, u16 *param, static void dwc2_set_param_u32(struct dwc2_hsotg *hsotg, u32 *param,
bool lookup, char *property, u16 legacy, bool lookup, char *property, u16 legacy,
u16 def, u16 min, u16 max) u16 def, u16 min, u16 max)
{ {
dwc2_set_param(hsotg, param, lookup, property, dwc2_set_param(hsotg, param, lookup, property,
legacy, def, min, max, 2); legacy, def, min, max, 4);
} }
/** /**
@ -1178,12 +1178,12 @@ static void dwc2_set_parameters(struct dwc2_hsotg *hsotg,
* auto-detect if the hardware does not support the * auto-detect if the hardware does not support the
* default. * default.
*/ */
dwc2_set_param_u16(hsotg, &p->g_rx_fifo_size, dwc2_set_param_u32(hsotg, &p->g_rx_fifo_size,
true, "g-rx-fifo-size", 2048, true, "g-rx-fifo-size", 2048,
hw->rx_fifo_size, hw->rx_fifo_size,
16, hw->rx_fifo_size); 16, hw->rx_fifo_size);
dwc2_set_param_u16(hsotg, &p->g_np_tx_fifo_size, dwc2_set_param_u32(hsotg, &p->g_np_tx_fifo_size,
true, "g-np-tx-fifo-size", 1024, true, "g-np-tx-fifo-size", 1024,
hw->dev_nperio_tx_fifo_size, hw->dev_nperio_tx_fifo_size,
16, hw->dev_nperio_tx_fifo_size); 16, hw->dev_nperio_tx_fifo_size);

View File

@ -138,7 +138,8 @@ static int dwc3_exynos_probe(struct platform_device *pdev)
exynos->axius_clk = devm_clk_get(dev, "usbdrd30_axius_clk"); exynos->axius_clk = devm_clk_get(dev, "usbdrd30_axius_clk");
if (IS_ERR(exynos->axius_clk)) { if (IS_ERR(exynos->axius_clk)) {
dev_err(dev, "no AXI UpScaler clk specified\n"); dev_err(dev, "no AXI UpScaler clk specified\n");
return -ENODEV; ret = -ENODEV;
goto axius_clk_err;
} }
clk_prepare_enable(exynos->axius_clk); clk_prepare_enable(exynos->axius_clk);
} else { } else {
@ -196,6 +197,7 @@ err3:
regulator_disable(exynos->vdd33); regulator_disable(exynos->vdd33);
err2: err2:
clk_disable_unprepare(exynos->axius_clk); clk_disable_unprepare(exynos->axius_clk);
axius_clk_err:
clk_disable_unprepare(exynos->susp_clk); clk_disable_unprepare(exynos->susp_clk);
clk_disable_unprepare(exynos->clk); clk_disable_unprepare(exynos->clk);
return ret; return ret;

View File

@ -2147,7 +2147,7 @@ int composite_os_desc_req_prepare(struct usb_composite_dev *cdev,
cdev->os_desc_req->buf = kmalloc(4096, GFP_KERNEL); cdev->os_desc_req->buf = kmalloc(4096, GFP_KERNEL);
if (!cdev->os_desc_req->buf) { if (!cdev->os_desc_req->buf) {
ret = -ENOMEM; ret = -ENOMEM;
kfree(cdev->os_desc_req); usb_ep_free_request(ep0, cdev->os_desc_req);
goto end; goto end;
} }
cdev->os_desc_req->context = cdev; cdev->os_desc_req->context = cdev;

View File

@ -1806,7 +1806,7 @@ static void ffs_func_eps_disable(struct ffs_function *func)
unsigned long flags; unsigned long flags;
spin_lock_irqsave(&func->ffs->eps_lock, flags); spin_lock_irqsave(&func->ffs->eps_lock, flags);
do { while (count--) {
/* pending requests get nuked */ /* pending requests get nuked */
if (likely(ep->ep)) if (likely(ep->ep))
usb_ep_disable(ep->ep); usb_ep_disable(ep->ep);
@ -1817,7 +1817,7 @@ static void ffs_func_eps_disable(struct ffs_function *func)
__ffs_epfile_read_buffer_free(epfile); __ffs_epfile_read_buffer_free(epfile);
++epfile; ++epfile;
} }
} while (--count); }
spin_unlock_irqrestore(&func->ffs->eps_lock, flags); spin_unlock_irqrestore(&func->ffs->eps_lock, flags);
} }
@ -1831,7 +1831,7 @@ static int ffs_func_eps_enable(struct ffs_function *func)
int ret = 0; int ret = 0;
spin_lock_irqsave(&func->ffs->eps_lock, flags); spin_lock_irqsave(&func->ffs->eps_lock, flags);
do { while(count--) {
struct usb_endpoint_descriptor *ds; struct usb_endpoint_descriptor *ds;
int desc_idx; int desc_idx;
@ -1867,7 +1867,7 @@ static int ffs_func_eps_enable(struct ffs_function *func)
++ep; ++ep;
++epfile; ++epfile;
} while (--count); }
spin_unlock_irqrestore(&func->ffs->eps_lock, flags); spin_unlock_irqrestore(&func->ffs->eps_lock, flags);
return ret; return ret;
@ -3448,12 +3448,12 @@ static void ffs_func_unbind(struct usb_configuration *c,
/* cleanup after autoconfig */ /* cleanup after autoconfig */
spin_lock_irqsave(&func->ffs->eps_lock, flags); spin_lock_irqsave(&func->ffs->eps_lock, flags);
do { while (count--) {
if (ep->ep && ep->req) if (ep->ep && ep->req)
usb_ep_free_request(ep->ep, ep->req); usb_ep_free_request(ep->ep, ep->req);
ep->req = NULL; ep->req = NULL;
++ep; ++ep;
} while (--count); }
spin_unlock_irqrestore(&func->ffs->eps_lock, flags); spin_unlock_irqrestore(&func->ffs->eps_lock, flags);
kfree(func->eps); kfree(func->eps);
func->eps = NULL; func->eps = NULL;

View File

@ -1978,7 +1978,8 @@ static struct usba_ep * atmel_udc_of_init(struct platform_device *pdev,
dev_err(&pdev->dev, "of_probe: name error(%d)\n", ret); dev_err(&pdev->dev, "of_probe: name error(%d)\n", ret);
goto err; goto err;
} }
ep->ep.name = kasprintf(GFP_KERNEL, "ep%d", ep->index); sprintf(ep->name, "ep%d", ep->index);
ep->ep.name = ep->name;
ep->ep_regs = udc->regs + USBA_EPT_BASE(i); ep->ep_regs = udc->regs + USBA_EPT_BASE(i);
ep->dma_regs = udc->regs + USBA_DMA_BASE(i); ep->dma_regs = udc->regs + USBA_DMA_BASE(i);

View File

@ -280,6 +280,7 @@ struct usba_ep {
void __iomem *ep_regs; void __iomem *ep_regs;
void __iomem *dma_regs; void __iomem *dma_regs;
void __iomem *fifo; void __iomem *fifo;
char name[8];
struct usb_ep ep; struct usb_ep ep;
struct usba_udc *udc; struct usba_udc *udc;

View File

@ -165,7 +165,7 @@ static int xhci_plat_probe(struct platform_device *pdev)
return -ENODEV; return -ENODEV;
/* Try to set 64-bit DMA first */ /* Try to set 64-bit DMA first */
if (WARN_ON(!pdev->dev.dma_mask)) if (!pdev->dev.dma_mask)
/* Platform did not initialize dma_mask */ /* Platform did not initialize dma_mask */
ret = dma_coerce_mask_and_coherent(&pdev->dev, ret = dma_coerce_mask_and_coherent(&pdev->dev,
DMA_BIT_MASK(64)); DMA_BIT_MASK(64));