bus/dpaa: add virtual storage profile port init
authorHemant Agrawal <hemant.agrawal@nxp.com>
Fri, 4 Sep 2020 08:39:27 +0000 (14:09 +0530)
committerFerruh Yigit <ferruh.yigit@intel.com>
Fri, 18 Sep 2020 16:55:08 +0000 (18:55 +0200)
This patch add support to initialize the VSP ports
in the FMAN library.

Signed-off-by: Hemant Agrawal <hemant.agrawal@nxp.com>
drivers/bus/dpaa/base/fman/fman.c
drivers/bus/dpaa/include/fman.h

index 3ae29bf..39102bc 100644 (file)
@@ -145,6 +145,61 @@ fman_get_mac_index(uint64_t regs_addr_host, uint8_t *mac_idx)
        return ret;
 }
 
+static void fman_if_vsp_init(struct __fman_if *__if)
+{
+       const phandle *prop;
+       int cell_index;
+       const struct device_node *dev;
+       size_t lenp;
+       const uint8_t mac_idx[] = {-1, 0, 1, 2, 3, 4, 5, 6, 7, 0, 1};
+
+       if (__if->__if.mac_type == fman_mac_1g) {
+               for_each_compatible_node(dev, NULL,
+                       "fsl,fman-port-1g-rx-extended-args") {
+                       prop = of_get_property(dev, "cell-index", &lenp);
+                       if (prop) {
+                               cell_index = of_read_number(
+                                               &prop[0],
+                                               lenp / sizeof(phandle));
+                               if (cell_index == mac_idx[__if->__if.mac_idx]) {
+                                       prop = of_get_property(
+                                                       dev,
+                                                       "vsp-window", &lenp);
+                                       if (prop) {
+                                               __if->__if.num_profiles =
+                                                       of_read_number(
+                                                               &prop[0], 1);
+                                               __if->__if.base_profile_id =
+                                                       of_read_number(
+                                                               &prop[1], 1);
+                                       }
+                               }
+                       }
+               }
+       } else if (__if->__if.mac_type == fman_mac_10g) {
+               for_each_compatible_node(dev, NULL,
+                       "fsl,fman-port-10g-rx-extended-args") {
+                       prop = of_get_property(dev, "cell-index", &lenp);
+                       if (prop) {
+                               cell_index = of_read_number(
+                                       &prop[0], lenp / sizeof(phandle));
+                               if (cell_index == mac_idx[__if->__if.mac_idx]) {
+                                       prop = of_get_property(
+                                               dev, "vsp-window", &lenp);
+                                       if (prop) {
+                                               __if->__if.num_profiles =
+                                                       of_read_number(
+                                                               &prop[0], 1);
+                                               __if->__if.base_profile_id =
+                                                       of_read_number(
+                                                               &prop[1], 1);
+                                       }
+                               }
+                       }
+               }
+       }
+}
+
 static int
 fman_if_init(const struct device_node *dpa_node)
 {
@@ -519,6 +574,8 @@ fman_if_init(const struct device_node *dpa_node)
        if (is_shared)
                __if->__if.is_shared_mac = 1;
 
+       fman_if_vsp_init(__if);
+
        /* Parsing of the network interface is complete, add it to the list */
        DPAA_BUS_LOG(DEBUG, "Found %s, Tx Channel = %x, FMAN = %x,"
                    "Port ID = %x",
index cb7f18c..dcf4083 100644 (file)
@@ -321,6 +321,9 @@ struct fman_if {
        /* The Qman channel to schedule Tx FQs to */
        u16 tx_channel_id;
 
+       uint8_t base_profile_id;
+       uint8_t num_profiles;
+
        uint8_t is_shared_mac;
        /* The hard-coded FQIDs for this interface. Note: this doesn't cover
         * the PCD nor the "Rx default" FQIDs, which are configured via FMC