[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20231018213921.2694459-1-kuba@kernel.org>
Date: Wed, 18 Oct 2023 14:39:18 -0700
From: Jakub Kicinski <kuba@...nel.org>
To: davem@...emloft.net
Cc: netdev@...r.kernel.org,
edumazet@...gle.com,
pabeni@...hat.com,
Jakub Kicinski <kuba@...nel.org>
Subject: [PATCH net-next 0/3] netlink: add variable-length / auto integers
Add netlink support for "common" / variable-length / auto integers
which are carried at the message level as either 4B or 8B depending
on the exact value. This saves space and will hopefully decrease
the number of instances where we realize that we needed more bits
after uAPI is set is stone. It also loosens the alignment requirements,
avoiding the need for padding.
This mini-series is a fuller version of the previous RFC:
https://lore.kernel.org/netdev/20121204.130914.1457976839967676240.davem@davemloft.net/
No user included here. I have tested (and will use) it
in the upcoming page pool API but the assumption is that
it will be widely applicable. So sending without a user.
Jakub Kicinski (3):
tools: ynl-gen: make the mnl_type() method public
netlink: add variable-length / auto integers
netlink: specs: add support for auto-sized scalars
Documentation/netlink/genetlink-c.yaml | 3 +-
Documentation/netlink/genetlink-legacy.yaml | 3 +-
Documentation/netlink/genetlink.yaml | 3 +-
Documentation/userspace-api/netlink/specs.rst | 18 ++++-
include/net/netlink.h | 69 ++++++++++++++++++-
include/uapi/linux/netlink.h | 5 ++
lib/nlattr.c | 22 ++++++
net/netlink/policy.c | 14 +++-
tools/net/ynl/lib/nlspec.py | 6 ++
tools/net/ynl/lib/ynl.c | 6 ++
tools/net/ynl/lib/ynl.h | 17 +++++
tools/net/ynl/lib/ynl.py | 14 ++++
tools/net/ynl/ynl-gen-c.py | 44 ++++++------
13 files changed, 192 insertions(+), 32 deletions(-)
--
2.41.0
Powered by blists - more mailing lists