Add support to qede to report bpf_prog ID during XDP_QUERY_PROG.

Signed-off-by: Martin KaFai Lau <ka...@fb.com>
Cc: Mintz Yuval <yuval.mi...@cavium.com>
Acked-by: Alexei Starovoitov <a...@fb.com>
Acked-by: Daniel Borkmann <dan...@iogearbox.net>
---
 drivers/net/ethernet/qlogic/qede/qede_filter.c | 14 ++++++++++++--
 1 file changed, 12 insertions(+), 2 deletions(-)

diff --git a/drivers/net/ethernet/qlogic/qede/qede_filter.c 
b/drivers/net/ethernet/qlogic/qede/qede_filter.c
index 13955a3bd3b3..d91555ae2936 100644
--- a/drivers/net/ethernet/qlogic/qede/qede_filter.c
+++ b/drivers/net/ethernet/qlogic/qede/qede_filter.c
@@ -1035,9 +1035,19 @@ int qede_xdp(struct net_device *dev, struct netdev_xdp 
*xdp)
        switch (xdp->command) {
        case XDP_SETUP_PROG:
                return qede_xdp_set(edev, xdp->prog);
-       case XDP_QUERY_PROG:
-               xdp->prog_attached = !!edev->xdp_prog;
+       case XDP_QUERY_PROG: {
+               const struct bpf_prog *xdp_prog;
+
+               xdp_prog = edev->xdp_prog;
+               if (xdp_prog) {
+                       xdp->prog_id = xdp_prog->aux->id;
+                       xdp->prog_attached = true;
+               } else {
+                       xdp->prog_id = 0;
+                       xdp->prog_attached = false;
+               }
                return 0;
+       }
        default:
                return -EINVAL;
        }
-- 
2.9.3

Reply via email to