Skip to content

Commit 083476a

Browse files
committed
Merge branch 'ynl-couple-of-unrelated-fixes'
Stanislav Fomichev says: ==================== ynl: couple of unrelated fixes - spelling of xdp-features - s/xdp_zc_max_segs/xdp-zc-max-segs/ - expose xdp-zc-max-segs - add /* private: */ - regenerate headers - print xdp_zc_max_segs from sample ==================== Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Jakub Kicinski <[email protected]>
2 parents f5fbd32 + 26fdb67 commit 083476a

File tree

9 files changed

+24
-4
lines changed

9 files changed

+24
-4
lines changed

Documentation/netlink/specs/netdev.yaml

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@ definitions:
1414
-
1515
name: basic
1616
doc:
17-
XDP feautues set supported by all drivers
17+
XDP features set supported by all drivers
1818
(XDP_ABORTED, XDP_DROP, XDP_PASS, XDP_TX)
1919
-
2020
name: redirect
@@ -63,7 +63,7 @@ attribute-sets:
6363
enum: xdp-act
6464
enum-as-flags: true
6565
-
66-
name: xdp_zc_max_segs
66+
name: xdp-zc-max-segs
6767
doc: max fragment count supported by ZC driver
6868
type: u32
6969
checks:
@@ -83,6 +83,7 @@ operations:
8383
attributes:
8484
- ifindex
8585
- xdp-features
86+
- xdp-zc-max-segs
8687
dump:
8788
reply: *dev-all
8889
-

include/uapi/linux/netdev.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@
1111

1212
/**
1313
* enum netdev_xdp_act
14-
* @NETDEV_XDP_ACT_BASIC: XDP feautues set supported by all drivers
14+
* @NETDEV_XDP_ACT_BASIC: XDP features set supported by all drivers
1515
* (XDP_ABORTED, XDP_DROP, XDP_PASS, XDP_TX)
1616
* @NETDEV_XDP_ACT_REDIRECT: The netdev supports XDP_REDIRECT
1717
* @NETDEV_XDP_ACT_NDO_XMIT: This feature informs if netdev implements
@@ -34,6 +34,7 @@ enum netdev_xdp_act {
3434
NETDEV_XDP_ACT_RX_SG = 32,
3535
NETDEV_XDP_ACT_NDO_XMIT_SG = 64,
3636

37+
/* private: */
3738
NETDEV_XDP_ACT_MASK = 127,
3839
};
3940

tools/include/uapi/linux/netdev.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@
1111

1212
/**
1313
* enum netdev_xdp_act
14-
* @NETDEV_XDP_ACT_BASIC: XDP feautues set supported by all drivers
14+
* @NETDEV_XDP_ACT_BASIC: XDP features set supported by all drivers
1515
* (XDP_ABORTED, XDP_DROP, XDP_PASS, XDP_TX)
1616
* @NETDEV_XDP_ACT_REDIRECT: The netdev supports XDP_REDIRECT
1717
* @NETDEV_XDP_ACT_NDO_XMIT: This feature informs if netdev implements
@@ -34,6 +34,7 @@ enum netdev_xdp_act {
3434
NETDEV_XDP_ACT_RX_SG = 32,
3535
NETDEV_XDP_ACT_NDO_XMIT_SG = 64,
3636

37+
/* private: */
3738
NETDEV_XDP_ACT_MASK = 127,
3839
};
3940

tools/net/ynl/Makefile

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,7 @@
33
SUBDIRS = lib generated samples
44

55
all: $(SUBDIRS)
6+
./ynl-regen.sh -f -p $(PWD)/../../../
67

78
$(SUBDIRS):
89
@if [ -f "$@/Makefile" ] ; then \

tools/net/ynl/generated/netdev-user.c

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -50,6 +50,7 @@ struct ynl_policy_attr netdev_dev_policy[NETDEV_A_DEV_MAX + 1] = {
5050
[NETDEV_A_DEV_IFINDEX] = { .name = "ifindex", .type = YNL_PT_U32, },
5151
[NETDEV_A_DEV_PAD] = { .name = "pad", .type = YNL_PT_IGNORE, },
5252
[NETDEV_A_DEV_XDP_FEATURES] = { .name = "xdp-features", .type = YNL_PT_U64, },
53+
[NETDEV_A_DEV_XDP_ZC_MAX_SEGS] = { .name = "xdp-zc-max-segs", .type = YNL_PT_U32, },
5354
};
5455

5556
struct ynl_policy_nest netdev_dev_nest = {
@@ -91,6 +92,11 @@ int netdev_dev_get_rsp_parse(const struct nlmsghdr *nlh, void *data)
9192
return MNL_CB_ERROR;
9293
dst->_present.xdp_features = 1;
9394
dst->xdp_features = mnl_attr_get_u64(attr);
95+
} else if (type == NETDEV_A_DEV_XDP_ZC_MAX_SEGS) {
96+
if (ynl_attr_validate(yarg, attr))
97+
return MNL_CB_ERROR;
98+
dst->_present.xdp_zc_max_segs = 1;
99+
dst->xdp_zc_max_segs = mnl_attr_get_u32(attr);
94100
}
95101
}
96102

tools/net/ynl/generated/netdev-user.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -47,10 +47,12 @@ struct netdev_dev_get_rsp {
4747
struct {
4848
__u32 ifindex:1;
4949
__u32 xdp_features:1;
50+
__u32 xdp_zc_max_segs:1;
5051
} _present;
5152

5253
__u32 ifindex;
5354
__u64 xdp_features;
55+
__u32 xdp_zc_max_segs;
5456
};
5557

5658
void netdev_dev_get_rsp_free(struct netdev_dev_get_rsp *rsp);

tools/net/ynl/samples/netdev.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -38,6 +38,8 @@ static void netdev_print_device(struct netdev_dev_get_rsp *d, unsigned int op)
3838
printf(" %s", netdev_xdp_act_str(1 << i));
3939
}
4040

41+
printf(" xdp-zc-max-segs=%u", d->xdp_zc_max_segs);
42+
4143
name = netdev_op_str(op);
4244
if (name)
4345
printf(" (ntf: %s)", name);

tools/net/ynl/ynl-gen-c.py

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2125,6 +2125,7 @@ def render_uapi(family, cw):
21252125

21262126
if const.get('render-max', False):
21272127
cw.nl()
2128+
cw.p('/* private: */')
21282129
if const['type'] == 'flags':
21292130
max_name = c_upper(name_pfx + 'mask')
21302131
max_val = f' = {enum.get_mask()},'

tools/net/ynl/ynl-regen.sh

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -4,15 +4,18 @@
44
TOOL=$(dirname $(realpath $0))/ynl-gen-c.py
55

66
force=
7+
search=
78

89
while [ ! -z "$1" ]; do
910
case "$1" in
1011
-f ) force=yes; shift ;;
12+
-p ) search=$2; shift 2 ;;
1113
* ) echo "Unrecognized option '$1'"; exit 1 ;;
1214
esac
1315
done
1416

1517
KDIR=$(dirname $(dirname $(dirname $(dirname $(realpath $0)))))
18+
pushd ${search:-$KDIR} >>/dev/null
1619

1720
files=$(git grep --files-with-matches '^/\* YNL-GEN \(kernel\|uapi\|user\)')
1821
for f in $files; do
@@ -30,3 +33,5 @@ for f in $files; do
3033
$TOOL --mode ${params[2]} --${params[3]} --spec $KDIR/${params[0]} \
3134
$args -o $f
3235
done
36+
37+
popd >>/dev/null

0 commit comments

Comments
 (0)