octeontx2-af: Fix mapping for NIX block from CGX connection
[ Upstream commit2e7bc57b97
] Firmware configures NIX block mapping for all MAC blocks. The current implementation reads the configuration and creates the mapping between RVU PF and NIX blocks. But this configuration is only valid for silicons that support multiple blocks. For all other silicons, all MAC blocks map to NIX0. This patch corrects the mapping by adding a check for the same. Fixes:c5a73b632b
("octeontx2-af: Map NIX block from CGX connection") Signed-off-by: Hariprasad Kelam <hkelam@marvell.com> Signed-off-by: Sunil Goutham <sgoutham@marvell.com> Reviewed-by: Simon Horman <simon.horman@corigine.com> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
Родитель
d58d718136
Коммит
eeaf264cd4
|
@ -23,6 +23,7 @@
|
|||
#define PCI_DEVID_OCTEONTX2_LBK 0xA061
|
||||
|
||||
/* Subsystem Device ID */
|
||||
#define PCI_SUBSYS_DEVID_98XX 0xB100
|
||||
#define PCI_SUBSYS_DEVID_96XX 0xB200
|
||||
#define PCI_SUBSYS_DEVID_CN10K_A 0xB900
|
||||
|
||||
|
@ -614,6 +615,16 @@ static inline u16 rvu_nix_chan_cpt(struct rvu *rvu, u8 chan)
|
|||
return rvu->hw->cpt_chan_base + chan;
|
||||
}
|
||||
|
||||
static inline bool is_rvu_supports_nix1(struct rvu *rvu)
|
||||
{
|
||||
struct pci_dev *pdev = rvu->pdev;
|
||||
|
||||
if (pdev->subsystem_device == PCI_SUBSYS_DEVID_98XX)
|
||||
return true;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
/* Function Prototypes
|
||||
* RVU
|
||||
*/
|
||||
|
|
|
@ -111,7 +111,7 @@ static void rvu_map_cgx_nix_block(struct rvu *rvu, int pf,
|
|||
p2x = cgx_lmac_get_p2x(cgx_id, lmac_id);
|
||||
/* Firmware sets P2X_SELECT as either NIX0 or NIX1 */
|
||||
pfvf->nix_blkaddr = BLKADDR_NIX0;
|
||||
if (p2x == CMR_P2X_SEL_NIX1)
|
||||
if (is_rvu_supports_nix1(rvu) && p2x == CMR_P2X_SEL_NIX1)
|
||||
pfvf->nix_blkaddr = BLKADDR_NIX1;
|
||||
}
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче