]> git.baikalelectronics.ru Git - kernel.git/commitdiff
octeontx2-af: nix and lbk in loop mode in 98xx
authorHarman Kalra <hkalra@marvell.com>
Wed, 25 Aug 2021 12:18:41 +0000 (17:48 +0530)
committerDavid S. Miller <davem@davemloft.net>
Wed, 25 Aug 2021 12:39:01 +0000 (13:39 +0100)
In 98xx, there are 2 NIX blocks and 4 LBK blocks present. The way
these NIX-LBK should be configured depends on the use case. By
default loopback functionality is supported in AF VF pairs which
are attached to NIX0 and NIX1 LFs alternatively to ensure load
balancing. NIX0 transmits a packet to LBK1 which will be received
by NIX1 and packet transmitted by NIX1 will get received by NIX0 via
LBK2.

There are some requirements where only one AF VF is used and respective
NIX is expected to operate in a mode where it can receive it own packet
back. This can be achieved if NIX0 sends packet to LBK0 and not LBK1.
Adding a flag in LF alloc request mailbox which can setup NIX0 to use
LBK0 and NIX1 can use LBK3.

Signed-off-by: Harman Kalra <hkalra@marvell.com>
Signed-off-by: Sunil Goutham <sgoutham@marvell.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/marvell/octeontx2/af/mbox.h
drivers/net/ethernet/marvell/octeontx2/af/rvu.h
drivers/net/ethernet/marvell/octeontx2/af/rvu_nix.c

index 487b83482df0b0a7b219495e46ec9b2c4f35f244..ac1609f7ab34cb24cd619a61574791a39b722403 100644 (file)
@@ -705,6 +705,7 @@ struct nix_lf_alloc_req {
        u64 rx_cfg;   /* See NIX_AF_LF(0..127)_RX_CFG */
        u64 way_mask;
 #define NIX_LF_RSS_TAG_LSB_AS_ADDER BIT_ULL(0)
+#define NIX_LF_LBK_BLK_SEL         BIT_ULL(1)
        u64 flags;
 };
 
index ab79232b9bf0715c1f8a7b0f575ce798c156a3f1..7a6496a023a41ba605aa9bae2811de6d1379b78d 100644 (file)
@@ -243,6 +243,7 @@ struct rvu_pfvf {
        u8      nix_blkaddr; /* BLKADDR_NIX0/1 assigned to this PF */
        u8      nix_rx_intf; /* NIX0_RX/NIX1_RX interface to NPC */
        u8      nix_tx_intf; /* NIX0_TX/NIX1_TX interface to NPC */
+       u8      lbkid;       /* NIX0/1 lbk link ID */
        u64     lmt_base_addr; /* Preseving the pcifunc's lmtst base addr*/
        unsigned long flags;
 };
index 0cac0f3f425d0e46976a0a9fd7876572c7c89391..2fbece57bb910104b6f1628662fcfcc014f64f21 100644 (file)
@@ -291,7 +291,7 @@ static bool is_valid_txschq(struct rvu *rvu, int blkaddr,
 }
 
 static int nix_interface_init(struct rvu *rvu, u16 pcifunc, int type, int nixlf,
-                             struct nix_lf_alloc_rsp *rsp)
+                             struct nix_lf_alloc_rsp *rsp, bool loop)
 {
        struct rvu_pfvf *pfvf = rvu_get_pfvf(rvu, pcifunc);
        struct rvu_hwinfo *hw = rvu->hw;
@@ -344,6 +344,25 @@ static int nix_interface_init(struct rvu *rvu, u16 pcifunc, int type, int nixlf,
                if (rvu->hw->lbk_links > 1)
                        lbkid = vf & 0x1 ? 0 : 1;
 
+               /* By default NIX0 is configured to send packet on lbk link 1
+                * (which corresponds to LBK1), same packet will receive on
+                * NIX1 over lbk link 0. If NIX1 sends packet on lbk link 0
+                * (which corresponds to LBK2) packet will receive on NIX0 lbk
+                * link 1.
+                * But if lbk links for NIX0 and NIX1 are negated, i.e NIX0
+                * transmits and receives on lbk link 0, whick corresponds
+                * to LBK1 block, back to back connectivity between NIX and
+                * LBK can be achieved (which is similar to 96xx)
+                *
+                *                      RX              TX
+                * NIX0 lbk link        1 (LBK2)        1 (LBK1)
+                * NIX0 lbk link        0 (LBK0)        0 (LBK0)
+                * NIX1 lbk link        0 (LBK1)        0 (LBK2)
+                * NIX1 lbk link        1 (LBK3)        1 (LBK3)
+                */
+               if (loop)
+                       lbkid = !lbkid;
+
                /* Note that AF's VFs work in pairs and talk over consecutive
                 * loopback channels.Therefore if odd number of AF VFs are
                 * enabled then the last VF remains with no pair.
@@ -355,6 +374,7 @@ static int nix_interface_init(struct rvu *rvu, u16 pcifunc, int type, int nixlf,
                pfvf->rx_chan_cnt = 1;
                pfvf->tx_chan_cnt = 1;
                rsp->tx_link = hw->cgx_links + lbkid;
+               pfvf->lbkid = lbkid;
                rvu_npc_set_pkind(rvu, NPC_RX_LBK_PKIND, pfvf);
                rvu_npc_install_promisc_entry(rvu, pcifunc, nixlf,
                                              pfvf->rx_chan_base,
@@ -1309,7 +1329,8 @@ int rvu_mbox_handler_nix_lf_alloc(struct rvu *rvu,
        rvu_write64(rvu, blkaddr, NIX_AF_LFX_TX_PARSE_CFG(nixlf), cfg);
 
        intf = is_afvf(pcifunc) ? NIX_INTF_TYPE_LBK : NIX_INTF_TYPE_CGX;
-       err = nix_interface_init(rvu, pcifunc, intf, nixlf, rsp);
+       err = nix_interface_init(rvu, pcifunc, intf, nixlf, rsp,
+                                !!(req->flags & NIX_LF_LBK_BLK_SEL));
        if (err)
                goto free_mem;
 
@@ -3766,6 +3787,7 @@ int rvu_mbox_handler_nix_set_hw_frs(struct rvu *rvu, struct nix_frs_cfg *req,
        struct nix_txsch *txsch;
        u64 cfg, lmac_fifo_len;
        struct nix_hw *nix_hw;
+       struct rvu_pfvf *pfvf;
        u8 cgx = 0, lmac = 0;
        u16 max_mtu;
 
@@ -3822,7 +3844,8 @@ rx_frscfg:
                link = (cgx * hw->lmac_per_cgx) + lmac;
        } else if (pf == 0) {
                /* For VFs of PF0 ingress is LBK port, so config LBK link */
-               link = hw->cgx_links;
+               pfvf = rvu_get_pfvf(rvu, pcifunc);
+               link = hw->cgx_links + pfvf->lbkid;
        }
 
        if (link < 0)