@@ -1761,9 +1761,19 @@ static int nicvf_xdp(struct net_device *netdev, struct netdev_xdp *xdp)
switch (xdp->command) {
case XDP_SETUP_PROG:
return nicvf_xdp_setup(nic, xdp->prog);
- case XDP_QUERY_PROG:
- xdp->prog_attached = !!nic->xdp_prog;
+ case XDP_QUERY_PROG: {
+ const struct bpf_prog *xdp_prog;
+
+ xdp_prog = nic->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;
}