[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20230816234303.3786178-1-kuba@kernel.org>
Date: Wed, 16 Aug 2023 16:42:49 -0700
From: Jakub Kicinski <kuba@...nel.org>
To: netdev@...r.kernel.org
Cc: hawk@...nel.org,
ilias.apalodimas@...aro.org,
aleksander.lobakin@...el.com,
linyunsheng@...wei.com,
almasrymina@...gle.com,
Jakub Kicinski <kuba@...nel.org>
Subject: [RFC net-next 00/13] net: page_pool: add netlink-based introspection
As the page pool functionality grows we will be increasingly
constrained by the lack of any uAPI. This series is a first
step towards such a uAPI, it creates a way for users to query
information about page pools and associated statistics.
I'm purposefully exposing only the information which I'd
find useful when monitoring production workloads.
For the SET part (which to be clear isn't addressed by this
series at all) I think we'll need to turn to something more
along the lines of "netdev-level policy". Instead of configuring
page pools, which are somewhat ephemeral, and hard to change
at runtime, we should set the "expected page pool parameters"
at the netdev level, and have the driver consult those when
instantiating pools. My ramblings from yesterday about Queue API
may make this more or less clear...
https://lore.kernel.org/all/20230815171638.4c057dcd@kernel.org/
Jakub Kicinski (13):
net: page_pool: split the page_pool_params into fast and slow
net: page_pool: avoid touching slow on the fastpath
net: page_pool: factor out uninit
net: page_pool: id the page pools
net: page_pool: record pools per netdev
net: page_pool: stash the NAPI ID for easier access
eth: link netdev to pp
net: page_pool: add nlspec for basic access to page pools
net: page_pool: implement GET in the netlink API
net: page_pool: add netlink notifications for state changes
net: page_pool: report when page pool was destroyed
net: page_pool: expose page pool stats via netlink
tools: netdev: regen after page pool changes
Documentation/netlink/specs/netdev.yaml | 158 +++++++
Documentation/networking/page_pool.rst | 5 +-
drivers/net/ethernet/broadcom/bnxt/bnxt.c | 1 +
.../net/ethernet/mellanox/mlx5/core/en_main.c | 1 +
drivers/net/ethernet/microsoft/mana/mana_en.c | 1 +
include/linux/list.h | 20 +
include/linux/netdevice.h | 4 +
include/net/page_pool/helpers.h | 8 +-
include/net/page_pool/types.h | 43 +-
include/uapi/linux/netdev.h | 37 ++
net/core/Makefile | 2 +-
net/core/netdev-genl-gen.c | 41 ++
net/core/netdev-genl-gen.h | 11 +
net/core/page_pool.c | 56 ++-
net/core/page_pool_priv.h | 12 +
net/core/page_pool_user.c | 409 +++++++++++++++++
tools/include/uapi/linux/netdev.h | 37 ++
tools/net/ynl/generated/netdev-user.c | 415 ++++++++++++++++++
tools/net/ynl/generated/netdev-user.h | 169 +++++++
19 files changed, 1391 insertions(+), 39 deletions(-)
create mode 100644 net/core/page_pool_priv.h
create mode 100644 net/core/page_pool_user.c
--
2.41.0
Powered by blists - more mailing lists