soc/qman: Don't add a new platform device for dma mapping
authorClaudiu Manoil <claudiu.manoil@nxp.com>
Wed, 16 Nov 2016 14:40:21 +0000 (16:40 +0200)
committerScott Wood <oss@buserror.net>
Wed, 23 Nov 2016 07:23:44 +0000 (01:23 -0600)
The qman portals are platform devices themselves, so they should
handle dma mappings.  Creating a dummy platform device in order to
support dma mapping operations is not justified (and not portable).
Instead, do the mapping against the first portal that has been
initialised.

Signed-off-by: Claudiu Manoil <claudiu.manoil@nxp.com>
Signed-off-by: Scott Wood <oss@buserror.net>
drivers/soc/fsl/qbman/qman.c
drivers/soc/fsl/qbman/qman_portal.c
drivers/soc/fsl/qbman/qman_priv.h

index 96b0f004e0075e7e890d9f8f5614e9a5696e841a..4ceb9a1da7ee15798f36bbbe69a0e7267f5f9beb 100644 (file)
@@ -962,8 +962,6 @@ struct qman_portal {
        u32 sdqcr;
        /* probing time config params for cpu-affine portals */
        const struct qm_portal_config *config;
-       /* needed for providing a non-NULL device to dma_map_***() */
-       struct platform_device *pdev;
        /* 2-element array. cgrs[0] is mask, cgrs[1] is snapshot. */
        struct qman_cgrs *cgrs;
        /* linked-list of CSCN handlers. */
@@ -1133,7 +1131,6 @@ static int qman_create_portal(struct qman_portal *portal,
                              const struct qman_cgrs *cgrs)
 {
        struct qm_portal *p;
-       char buf[16];
        int ret;
        u32 isdr;
 
@@ -1196,15 +1193,6 @@ static int qman_create_portal(struct qman_portal *portal,
        portal->sdqcr = QM_SDQCR_SOURCE_CHANNELS | QM_SDQCR_COUNT_UPTO3 |
                        QM_SDQCR_DEDICATED_PRECEDENCE | QM_SDQCR_TYPE_PRIO_QOS |
                        QM_SDQCR_TOKEN_SET(0xab) | QM_SDQCR_CHANNELS_DEDICATED;
-       sprintf(buf, "qportal-%d", c->channel);
-       portal->pdev = platform_device_alloc(buf, -1);
-       if (!portal->pdev)
-               goto fail_devalloc;
-       if (dma_set_mask(&portal->pdev->dev, DMA_BIT_MASK(40)))
-               goto fail_devadd;
-       ret = platform_device_add(portal->pdev);
-       if (ret)
-               goto fail_devadd;
        isdr = 0xffffffff;
        qm_out(p, QM_REG_ISDR, isdr);
        portal->irq_sources = 0;
@@ -1256,10 +1244,6 @@ fail_eqcr_empty:
 fail_affinity:
        free_irq(c->irq, portal);
 fail_irq:
-       platform_device_del(portal->pdev);
-fail_devadd:
-       platform_device_put(portal->pdev);
-fail_devalloc:
        kfree(portal->cgrs);
 fail_cgrs:
        qm_mc_finish(p);
@@ -1321,9 +1305,6 @@ static void qman_destroy_portal(struct qman_portal *qm)
        qm_dqrr_finish(&qm->p);
        qm_eqcr_finish(&qm->p);
 
-       platform_device_del(qm->pdev);
-       platform_device_put(qm->pdev);
-
        qm->config = NULL;
 }
 
@@ -1817,8 +1798,16 @@ int qman_init_fq(struct qman_fq *fq, u32 flags, struct qm_mcc_initfq *opts)
                        memset(&mcc->initfq.fqd.context_a, 0,
                                sizeof(mcc->initfq.fqd.context_a));
                } else {
-                       phys_fq = dma_map_single(&p->pdev->dev, fq, sizeof(*fq),
-                                                DMA_TO_DEVICE);
+                       struct qman_portal *p = qman_dma_portal;
+
+                       phys_fq = dma_map_single(p->config->dev, fq,
+                                                sizeof(*fq), DMA_TO_DEVICE);
+                       if (dma_mapping_error(p->config->dev, phys_fq)) {
+                               dev_err(p->config->dev, "dma_mapping failed\n");
+                               ret = -EIO;
+                               goto out;
+                       }
+
                        qm_fqd_stashing_set64(&mcc->initfq.fqd, phys_fq);
                }
        }
index 6651168333e16fc8f5d05dc73b5892010ece8682..e6da2ea78554a96234ec60596969b7a8f2e9c519 100644 (file)
@@ -30,6 +30,8 @@
 
 #include "qman_priv.h"
 
+struct qman_portal *qman_dma_portal;
+
 /* Enable portal interupts (as opposed to polling mode) */
 #define CONFIG_FSL_DPA_PIRQ_SLOW  1
 #define CONFIG_FSL_DPA_PIRQ_FAST  1
@@ -150,6 +152,10 @@ static struct qman_portal *init_pcfg(struct qm_portal_config *pcfg)
                /* all assigned portals are initialized now */
                qman_init_cgr_all();
        }
+
+       if (!qman_dma_portal)
+               qman_dma_portal = p;
+
        spin_unlock(&qman_lock);
 
        dev_info(pcfg->dev, "Portal initialised, cpu %d\n", pcfg->cpu);
@@ -310,6 +316,11 @@ static int qman_portal_probe(struct platform_device *pdev)
        spin_unlock(&qman_lock);
        pcfg->cpu = cpu;
 
+       if (dma_set_mask(dev, DMA_BIT_MASK(40))) {
+               dev_err(dev, "dma_set_mask() failed\n");
+               goto err_portal_init;
+       }
+
        if (!init_pcfg(pcfg)) {
                dev_err(dev, "portal init failed\n");
                goto err_portal_init;
index 5cf821e623a9c6ff6fbec65f6c4842ea8a379768..59b4b463d88426be58c32b1264065921c52bf714 100644 (file)
@@ -367,5 +367,6 @@ int qman_alloc_fq_table(u32 num_fqids);
 #define QM_PIRQ_VISIBLE        (QM_PIRQ_SLOW | QM_PIRQ_DQRI)
 
 extern struct qman_portal *affine_portals[NR_CPUS];
+extern struct qman_portal *qman_dma_portal;
 const struct qm_portal_config *qman_get_qm_portal_config(
                                                struct qman_portal *portal);