Commit 59dcdaf9 authored by Felipe Balbi's avatar Felipe Balbi Committed by Sasha Levin

usb: musb: cppi41: allow it to work again

[ Upstream commit b0a688dd ]

since commit 33c300cb ("usb: musb: dsps:
don't fake of_node to musb core") we have been
preventing CPPI 4.1 from probing due to NULL
of_node. We can't revert said commit otherwise
a different regression would show up, so the fix
is to look for the parent device's (glue layer's)
of_node instead, since that's the thing which
is actually described in DTS.
Signed-off-by: default avatarFelipe Balbi <balbi@ti.com>
Signed-off-by: default avatarSasha Levin <sasha.levin@oracle.com>
parent c8759ce7
...@@ -600,7 +600,7 @@ static int cppi41_dma_controller_start(struct cppi41_dma_controller *controller) ...@@ -600,7 +600,7 @@ static int cppi41_dma_controller_start(struct cppi41_dma_controller *controller)
{ {
struct musb *musb = controller->musb; struct musb *musb = controller->musb;
struct device *dev = musb->controller; struct device *dev = musb->controller;
struct device_node *np = dev->of_node; struct device_node *np = dev->parent->of_node;
struct cppi41_dma_channel *cppi41_channel; struct cppi41_dma_channel *cppi41_channel;
int count; int count;
int i; int i;
...@@ -650,7 +650,7 @@ static int cppi41_dma_controller_start(struct cppi41_dma_controller *controller) ...@@ -650,7 +650,7 @@ static int cppi41_dma_controller_start(struct cppi41_dma_controller *controller)
musb_dma->status = MUSB_DMA_STATUS_FREE; musb_dma->status = MUSB_DMA_STATUS_FREE;
musb_dma->max_len = SZ_4M; musb_dma->max_len = SZ_4M;
dc = dma_request_slave_channel(dev, str); dc = dma_request_slave_channel(dev->parent, str);
if (!dc) { if (!dc) {
dev_err(dev, "Failed to request %s.\n", str); dev_err(dev, "Failed to request %s.\n", str);
ret = -EPROBE_DEFER; ret = -EPROBE_DEFER;
...@@ -680,7 +680,7 @@ struct dma_controller *dma_controller_create(struct musb *musb, ...@@ -680,7 +680,7 @@ struct dma_controller *dma_controller_create(struct musb *musb,
struct cppi41_dma_controller *controller; struct cppi41_dma_controller *controller;
int ret = 0; int ret = 0;
if (!musb->controller->of_node) { if (!musb->controller->parent->of_node) {
dev_err(musb->controller, "Need DT for the DMA engine.\n"); dev_err(musb->controller, "Need DT for the DMA engine.\n");
return NULL; return NULL;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment