Add module parameters rxe_must_check_icrc and rxe_must_generat_icrc which default to 1 and which suppresses checking/generating ICRC if set to 0. The parameter is displayed in /sys as "check_icrc" or "generate_icrc". Signed-off-by: Bob Pearson <rpearsonhpe@xxxxxxxxx> --- drivers/infiniband/sw/rxe/rxe.c | 9 +++++++++ drivers/infiniband/sw/rxe/rxe.h | 4 ++++ drivers/infiniband/sw/rxe/rxe_net.c | 3 ++- drivers/infiniband/sw/rxe/rxe_recv.c | 8 +++++--- 4 files changed, 20 insertions(+), 4 deletions(-) diff --git a/drivers/infiniband/sw/rxe/rxe.c b/drivers/infiniband/sw/rxe/rxe.c index 8e0f9c489cab..08de3ef9f1f2 100644 --- a/drivers/infiniband/sw/rxe/rxe.c +++ b/drivers/infiniband/sw/rxe/rxe.c @@ -15,6 +15,15 @@ MODULE_LICENSE("Dual BSD/GPL"); bool rxe_initialized; +/* If set to false these parameters disable checking and/or generating + * the packet ICRC + */ +bool rxe_must_check_icrc = true; +module_param_named(check_icrc, rxe_must_check_icrc, bool, 0660); + +bool rxe_must_generate_icrc = true; +module_param_named(generate_icrc, rxe_must_generate_icrc, bool, 0660); + /* free resources for a rxe device all objects created for this device must * have been destroyed */ diff --git a/drivers/infiniband/sw/rxe/rxe.h b/drivers/infiniband/sw/rxe/rxe.h index 1bb3fb618bf5..a5083a924a6f 100644 --- a/drivers/infiniband/sw/rxe/rxe.h +++ b/drivers/infiniband/sw/rxe/rxe.h @@ -13,6 +13,7 @@ #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt #include <linux/module.h> +#include <linux/moduleparam.h> #include <linux/skbuff.h> #include <rdma/ib_verbs.h> @@ -39,6 +40,9 @@ #define RXE_ROCE_V2_SPORT (0xc000) +extern bool rxe_must_check_icrc; +extern bool rxe_must_generate_icrc; + extern bool rxe_initialized; void rxe_set_mtu(struct rxe_dev *rxe, unsigned int dev_mtu); diff --git a/drivers/infiniband/sw/rxe/rxe_net.c b/drivers/infiniband/sw/rxe/rxe_net.c index 3860281a3a90..4d109e5b33ff 100644 --- a/drivers/infiniband/sw/rxe/rxe_net.c +++ b/drivers/infiniband/sw/rxe/rxe_net.c @@ -434,7 +434,8 @@ int rxe_xmit_packet(struct rxe_qp *qp, struct rxe_pkt_info *pkt, goto drop; } - rxe_icrc_generate(skb, pkt); + if (rxe_must_generate_icrc) + rxe_icrc_generate(skb, pkt); if (pkt->mask & RXE_LOOPBACK_MASK) { memcpy(SKB_TO_PKT(skb), pkt, sizeof(*pkt)); diff --git a/drivers/infiniband/sw/rxe/rxe_recv.c b/drivers/infiniband/sw/rxe/rxe_recv.c index 8582b3163e2c..01d425b3991e 100644 --- a/drivers/infiniband/sw/rxe/rxe_recv.c +++ b/drivers/infiniband/sw/rxe/rxe_recv.c @@ -382,9 +382,11 @@ void rxe_rcv(struct sk_buff *skb) if (unlikely(err)) goto drop; - err = rxe_icrc_check(skb); - if (unlikely(err)) - goto drop; + if (rxe_must_check_icrc) { + err = rxe_icrc_check(skb); + if (unlikely(err)) + goto drop; + } rxe_counter_inc(rxe, RXE_CNT_RCVD_PKTS); -- 2.30.2