octeontx2-af: Enable inner IPv4 checksum and its error code
This patch enables the inner IPv4 checksum and defines the error code for Rx inner and outer checksum errors. Setting ERRCODE as 1 so that CQE descriptor can be embedded valid checksum error code and the driver can interpret checksum error as ERRLEV = LID + 1 and ERRCODE = 1. Signed-off-by: Jerin Jacob <jerinj@marvell.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
e2703c5f58
commit
962e1bd6b7
@ -1008,13 +1008,20 @@ int rvu_npc_init(struct rvu *rvu)
|
|||||||
rvu_write64(rvu, blkaddr, NPC_AF_PCK_DEF_OIP4,
|
rvu_write64(rvu, blkaddr, NPC_AF_PCK_DEF_OIP4,
|
||||||
(NPC_LID_LC << 8) | (NPC_LT_LC_IP << 4) | 0x0F);
|
(NPC_LID_LC << 8) | (NPC_LT_LC_IP << 4) | 0x0F);
|
||||||
|
|
||||||
|
/* Config Inner IPV4 NPC layer info */
|
||||||
|
rvu_write64(rvu, blkaddr, NPC_AF_PCK_DEF_IIP4,
|
||||||
|
(NPC_LID_LF << 8) | (NPC_LT_LF_TU_IP << 4) | 0x0F);
|
||||||
|
|
||||||
/* Enable below for Rx pkts.
|
/* Enable below for Rx pkts.
|
||||||
* - Outer IPv4 header checksum validation.
|
* - Outer IPv4 header checksum validation.
|
||||||
* - Detect outer L2 broadcast address and set NPC_RESULT_S[L2M].
|
* - Detect outer L2 broadcast address and set NPC_RESULT_S[L2M].
|
||||||
|
* - Inner IPv4 header checksum validation.
|
||||||
|
* - Set non zero checksum error code value
|
||||||
*/
|
*/
|
||||||
rvu_write64(rvu, blkaddr, NPC_AF_PCK_CFG,
|
rvu_write64(rvu, blkaddr, NPC_AF_PCK_CFG,
|
||||||
rvu_read64(rvu, blkaddr, NPC_AF_PCK_CFG) |
|
rvu_read64(rvu, blkaddr, NPC_AF_PCK_CFG) |
|
||||||
BIT_ULL(6) | BIT_ULL(2));
|
BIT_ULL(32) | BIT_ULL(24) | BIT_ULL(6) |
|
||||||
|
BIT_ULL(2) | BIT_ULL(1));
|
||||||
|
|
||||||
/* Set RX and TX side MCAM search key size.
|
/* Set RX and TX side MCAM search key size.
|
||||||
* LA..LD (ltype only) + Channel
|
* LA..LD (ltype only) + Channel
|
||||||
|
Loading…
x
Reference in New Issue
Block a user