mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-11-01 17:08:10 +00:00
usb: cdns3: Fix for incorrect DMA mask.
This patch restores the correct DMA mask after switching back to device
mode.
The issue occurred because Device part of controller use 32 bits DMA and
Host side use 64 bits DMA. During loading XHCI driver the DMA mask
used by driver is overwritten by XHCI driver so it must be restored
to 32 bits.
Reported-by: Pawel Laszczak <pawell@cadence.com>
Signed-off-by: Roger Quadros <rogerq@ti.com>
Signed-off-by: Pawel Laszczak <pawell@cadence.com>
Fixes: 7733f6c32e
("usb: cdns3: Add Cadence USB3 DRD Driver")
Reviewed-by: Peter Chen <peter.chen@nxp.com>
Tested-by: Roger Quadros <rogerq@ti.com>
Link: https://lore.kernel.org/r/1570449803-15299-1-git-send-email-pawell@cadence.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
02ffc26df9
commit
eb21a74ada
1 changed files with 7 additions and 0 deletions
|
@ -2663,6 +2663,13 @@ static int __cdns3_gadget_init(struct cdns3 *cdns)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
|
/* Ensure 32-bit DMA Mask in case we switched back from Host mode */
|
||||||
|
ret = dma_set_mask_and_coherent(cdns->dev, DMA_BIT_MASK(32));
|
||||||
|
if (ret) {
|
||||||
|
dev_err(cdns->dev, "Failed to set dma mask: %d\n", ret);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
cdns3_drd_switch_gadget(cdns, 1);
|
cdns3_drd_switch_gadget(cdns, 1);
|
||||||
pm_runtime_get_sync(cdns->dev);
|
pm_runtime_get_sync(cdns->dev);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue