Commit c2d919cd authored by Jakub Kicinski's avatar Jakub Kicinski

Merge branch 'tools-ynl-gen-fill-in-the-gaps-in-support-of-legacy-families'

Jakub Kicinski says:

====================
tools: ynl-gen: fill in the gaps in support of legacy families

Fill in the gaps in YNL C code gen so that we can generate user
space code for all genetlink families for which we have specs.

The two major changes we need are support for fixed headers and
support for recursive nests.

For fixed header support - place the struct for the fixed header
directly in the request struct (and don't bother generating access
helpers). The member of a fixed header can't be too complex, and
also are by definition not optional so the user has to fill them in.
The YNL core needs a bit of a tweak to understand that the attrs
may now start at a fixed offset, which is not necessarily equal
to sizeof(struct genlmsghdr).

Dealing with nested sets is much harder. Previously we'd gen
the nested structs as:

 struct outer {
   struct inner inner;
 };

If structs are recursive (e.g. inner contains outer again)
we must break this chain and allocate one of the structs
dynamically (store a pointer rather than full struct).
====================

Link: https://lore.kernel.org/r/20231213231432.2944749-1-kuba@kernel.orgSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parents 8f674972 7b5fe80e
...@@ -191,12 +191,12 @@ ynl_ext_ack_check(struct ynl_sock *ys, const struct nlmsghdr *nlh, ...@@ -191,12 +191,12 @@ ynl_ext_ack_check(struct ynl_sock *ys, const struct nlmsghdr *nlh,
str ? " (" : ""); str ? " (" : "");
start = mnl_nlmsg_get_payload_offset(ys->nlh, start = mnl_nlmsg_get_payload_offset(ys->nlh,
sizeof(struct genlmsghdr)); ys->family->hdr_len);
end = mnl_nlmsg_get_payload_tail(ys->nlh); end = mnl_nlmsg_get_payload_tail(ys->nlh);
off = ys->err.attr_offs; off = ys->err.attr_offs;
off -= sizeof(struct nlmsghdr); off -= sizeof(struct nlmsghdr);
off -= sizeof(struct genlmsghdr); off -= ys->family->hdr_len;
n += ynl_err_walk(ys, start, end, off, ys->req_policy, n += ynl_err_walk(ys, start, end, off, ys->req_policy,
&bad_attr[n], sizeof(bad_attr) - n, NULL); &bad_attr[n], sizeof(bad_attr) - n, NULL);
...@@ -217,14 +217,14 @@ ynl_ext_ack_check(struct ynl_sock *ys, const struct nlmsghdr *nlh, ...@@ -217,14 +217,14 @@ ynl_ext_ack_check(struct ynl_sock *ys, const struct nlmsghdr *nlh,
bad_attr[0] ? ", " : (str ? " (" : "")); bad_attr[0] ? ", " : (str ? " (" : ""));
start = mnl_nlmsg_get_payload_offset(ys->nlh, start = mnl_nlmsg_get_payload_offset(ys->nlh,
sizeof(struct genlmsghdr)); ys->family->hdr_len);
end = mnl_nlmsg_get_payload_tail(ys->nlh); end = mnl_nlmsg_get_payload_tail(ys->nlh);
nest_pol = ys->req_policy; nest_pol = ys->req_policy;
if (tb[NLMSGERR_ATTR_MISS_NEST]) { if (tb[NLMSGERR_ATTR_MISS_NEST]) {
off = mnl_attr_get_u32(tb[NLMSGERR_ATTR_MISS_NEST]); off = mnl_attr_get_u32(tb[NLMSGERR_ATTR_MISS_NEST]);
off -= sizeof(struct nlmsghdr); off -= sizeof(struct nlmsghdr);
off -= sizeof(struct genlmsghdr); off -= ys->family->hdr_len;
n += ynl_err_walk(ys, start, end, off, ys->req_policy, n += ynl_err_walk(ys, start, end, off, ys->req_policy,
&miss_attr[n], sizeof(miss_attr) - n, &miss_attr[n], sizeof(miss_attr) - n,
......
...@@ -44,6 +44,7 @@ struct ynl_error { ...@@ -44,6 +44,7 @@ struct ynl_error {
struct ynl_family { struct ynl_family {
/* private: */ /* private: */
const char *name; const char *name;
size_t hdr_len;
const struct ynl_ntf_info *ntf_info; const struct ynl_ntf_info *ntf_info;
unsigned int ntf_info_size; unsigned int ntf_info_size;
}; };
......
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment