1 From 13296e938da191216395952cf49ddda96e67359c Mon Sep 17 00:00:00 2001
2 From: Laurentiu Tudor <laurentiu.tudor@nxp.com>
3 Date: Thu, 5 Apr 2018 12:37:57 +0300
4 Subject: [PATCH] dpaa_eth: base dma mappings on the fman rx port
6 The dma transactions initiator is the rx fman port so that's the device
7 that the dma mappings should be done. Previously the mappings were done
8 through the MAC device which makes no sense because it's neither dma-able
9 nor connected in any way to smmu.
11 Signed-off-by: Laurentiu Tudor <laurentiu.tudor@nxp.com>
12 Acked-by: Madalin Bucur <madalin.bucur@nxp.com>
14 drivers/net/ethernet/freescale/dpaa/dpaa_eth.c | 18 +++++++++---------
15 1 file changed, 9 insertions(+), 9 deletions(-)
17 --- a/drivers/net/ethernet/freescale/dpaa/dpaa_eth.c
18 +++ b/drivers/net/ethernet/freescale/dpaa/dpaa_eth.c
19 @@ -2978,8 +2978,15 @@ static int dpaa_eth_probe(struct platfor
23 + mac_dev = dpaa_mac_dev_get(pdev);
24 + if (IS_ERR(mac_dev)) {
25 + dev_err(&pdev->dev, "dpaa_mac_dev_get() failed\n");
26 + err = PTR_ERR(mac_dev);
30 /* device used for DMA mapping */
31 - dev = pdev->dev.parent;
32 + dev = fman_port_get_device(mac_dev->port[RX]);
33 err = dma_coerce_mask_and_coherent(dev, DMA_BIT_MASK(40));
35 dev_err(dev, "dma_coerce_mask_and_coherent() failed\n");
36 @@ -3004,13 +3011,6 @@ static int dpaa_eth_probe(struct platfor
38 priv->msg_enable = netif_msg_init(debug, DPAA_MSG_DEFAULT);
40 - mac_dev = dpaa_mac_dev_get(pdev);
41 - if (IS_ERR(mac_dev)) {
42 - dev_err(dev, "dpaa_mac_dev_get() failed\n");
43 - err = PTR_ERR(mac_dev);
47 /* If fsl_fm_max_frm is set to a higher value than the all-common 1500,
48 * we choose conservatively and let the user explicitly set a higher
49 * MTU via ifconfig. Otherwise, the user may end up with different MTUs
50 @@ -3146,9 +3146,9 @@ delete_egress_cgr:
51 qman_release_cgrid(priv->cgr_data.cgr.cgrid);
55 dev_set_drvdata(dev, NULL);