summaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/netronome/nfp
diff options
context:
space:
mode:
authorJakub Kicinski2018-01-18 04:13:32 +0100
committerDaniel Borkmann2018-01-18 22:54:26 +0100
commitca027a1c45e30d89c5cc6dcacbdcea74e1ff65fc (patch)
treeefd0d8d3cb68686132ce8adea69fddd8916e7477 /drivers/net/ethernet/netronome/nfp
parentselftest/bpf: extend the offload test with map checks (diff)
downloadkernel-qcow2-linux-ca027a1c45e30d89c5cc6dcacbdcea74e1ff65fc.tar.gz
kernel-qcow2-linux-ca027a1c45e30d89c5cc6dcacbdcea74e1ff65fc.tar.xz
kernel-qcow2-linux-ca027a1c45e30d89c5cc6dcacbdcea74e1ff65fc.zip
nfp: bpf: add short busy wait for FW replies
Scheduling out and in for every FW message can slow us down unnecessarily. Our experiments show that even under heavy load the FW responds to 99.9% messages within 200 us. Add a short busy wait before entering the wait queue. Signed-off-by: Jakub Kicinski <jakub.kicinski@netronome.com> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Diffstat (limited to 'drivers/net/ethernet/netronome/nfp')
-rw-r--r--drivers/net/ethernet/netronome/nfp/bpf/cmsg.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/drivers/net/ethernet/netronome/nfp/bpf/cmsg.c b/drivers/net/ethernet/netronome/nfp/bpf/cmsg.c
index 71e6586acc36..80d3aa0fc9d3 100644
--- a/drivers/net/ethernet/netronome/nfp/bpf/cmsg.c
+++ b/drivers/net/ethernet/netronome/nfp/bpf/cmsg.c
@@ -157,7 +157,14 @@ nfp_bpf_cmsg_wait_reply(struct nfp_app_bpf *bpf, enum nfp_bpf_cmsg_type type,
int tag)
{
struct sk_buff *skb;
- int err;
+ int i, err;
+
+ for (i = 0; i < 50; i++) {
+ udelay(4);
+ skb = nfp_bpf_reply(bpf, tag);
+ if (skb)
+ return skb;
+ }
err = wait_event_interruptible_timeout(bpf->cmsg_wq,
skb = nfp_bpf_reply(bpf, tag),