Signed-off-by: Madalin Bucur <madalin.bu...@nxp.com>
---
 drivers/net/ethernet/freescale/dpaa/Kconfig    |  6 ++++++
 drivers/net/ethernet/freescale/dpaa/dpaa_eth.c | 23 +++++++++++++++++++++++
 2 files changed, 29 insertions(+)

diff --git a/drivers/net/ethernet/freescale/dpaa/Kconfig 
b/drivers/net/ethernet/freescale/dpaa/Kconfig
index 670e039..308fc21 100644
--- a/drivers/net/ethernet/freescale/dpaa/Kconfig
+++ b/drivers/net/ethernet/freescale/dpaa/Kconfig
@@ -18,4 +18,10 @@ config FSL_DPAA_ETH_FRIENDLY_IF_NAME
          The DPAA Ethernet netdevices are created for each FMan port available
          on a certain board. Enable this to get interface names derived from
          the underlying FMan hardware for a simple identification.
+config FSL_DPAA_ETH_COMMON_BPOOL
+       bool "Use a common buffer pool set for all the interfaces"
+       ---help---
+         The DPAA Ethernet netdevices require buffer pools for storing the 
buffers
+         used by the FMan hardware for reception. One can use a single buffer 
pool
+         set for all interfaces or a dedicated buffer pool set for each 
interface.
 endif # FSL_DPAA_ETH
diff --git a/drivers/net/ethernet/freescale/dpaa/dpaa_eth.c 
b/drivers/net/ethernet/freescale/dpaa/dpaa_eth.c
index 55e89b7..5e8c3df 100644
--- a/drivers/net/ethernet/freescale/dpaa/dpaa_eth.c
+++ b/drivers/net/ethernet/freescale/dpaa/dpaa_eth.c
@@ -158,6 +158,11 @@ struct fm_port_fqs {
        struct dpaa_fq *rx_errq;
 };
 
+#ifdef CONFIG_FSL_DPAA_ETH_COMMON_BPOOL
+/* These bpools are shared by all the dpaa interfaces */
+static u8 dpaa_common_bpids[DPAA_BPS_NUM];
+#endif
+
 /* All the dpa bps in use at any moment */
 static struct dpaa_bp *dpaa_bp_array[BM_MAX_NUM_OF_POOLS];
 
@@ -2527,6 +2532,12 @@ static int dpaa_eth_probe(struct platform_device *pdev)
        for (i = 0; i < DPAA_BPS_NUM; i++) {
                int err;
 
+#ifdef CONFIG_FSL_DPAA_ETH_COMMON_BPOOL
+               /* if another interface probed the bps reuse those */
+               dpaa_bps[i] = (dpaa_common_bpids[i] != FSL_DPAA_BPID_INV) ?
+                               dpaa_bpid2pool(dpaa_common_bpids[i]) : NULL;
+               if (!dpaa_bps[i]) {
+#endif
                dpaa_bps[i] = dpaa_bp_alloc(dev);
                if (IS_ERR(dpaa_bps[i]))
                        return PTR_ERR(dpaa_bps[i]);
@@ -2542,6 +2553,11 @@ static int dpaa_eth_probe(struct platform_device *pdev)
                        priv->dpaa_bps[i] = NULL;
                        goto bp_create_failed;
                }
+#ifdef CONFIG_FSL_DPAA_ETH_COMMON_BPOOL
+               }
+               dpaa_common_bpids[i] = dpaa_bps[i]->bpid;
+               dpaa_bps[i] = (dpaa_bpid2pool(dpaa_common_bpids[i]));
+#endif
                priv->dpaa_bps[i] = dpaa_bps[i];
        }
 
@@ -2716,6 +2732,13 @@ static int __init dpaa_load(void)
        dpaa_rx_extra_headroom = fman_get_rx_extra_headroom();
        dpaa_max_frm = fman_get_max_frm();
 
+#ifdef CONFIG_FSL_DPAA_ETH_COMMON_BPOOL
+       /* set initial invalid values, first interface probe will set correct
+        * values that will be shared by the other interfaces
+        */
+       memset(dpaa_common_bpids, FSL_DPAA_BPID_INV, sizeof(dpaa_common_bpids));
+#endif
+
        err = platform_driver_register(&dpaa_driver);
        if (err < 0)
                pr_err("Error, platform_driver_register() = %d\n", err);
-- 
2.1.0

Reply via email to