From: Ido Schimmel <idosch@idosch.org>
To: Jakub Kicinski <kuba@kernel.org>
Cc: "Song Liu" <songliubraving@fb.com>,
"Sergey Ryazanov" <ryazanov.s.a@gmail.com>,
"Michael S. Tsirkin" <mst@redhat.com>,
"Vladimir Oltean" <vladimir.oltean@nxp.com>,
"Alexei Starovoitov" <ast@kernel.org>,
"Russell King" <linux@armlinux.org.uk>,
"Andrei Vagin" <avagin@gmail.com>,
"Tony Nguyen" <anthony.l.nguyen@intel.com>,
"Thomas Petazzoni" <thomas.petazzoni@bootlin.com>,
"Ioana Ciornei" <ioana.ciornei@nxp.com>,
"Arthur Kiyanovski" <akiyano@amazon.com>,
"Leon Romanovsky" <leon@kernel.org>,
"Jonathan Corbet" <corbet@lwn.net>,
linux-rdma@vger.kernel.org, linux-doc@vger.kernel.org,
"John Fastabend" <john.fastabend@gmail.com>,
"Noam Dagan" <ndagan@amazon.com>,
nikolay@nvidia.com, "Cong Wang" <cong.wang@bytedance.com>,
"Martin Habets" <habetsm.xilinx@gmail.com>,
"Lorenzo Bianconi" <lorenzo@kernel.org>,
"Maciej Fijalkowski" <maciej.fijalkowski@intel.com>,
"Jesper Dangaard Brouer" <hawk@kernel.org>,
"Johannes Berg" <johannes.berg@intel.com>,
"KP Singh" <kpsingh@kernel.org>,
"Andrii Nakryiko" <andrii@kernel.org>,
"Claudiu Manoil" <claudiu.manoil@nxp.com>,
"Alexander Lobakin" <alexandr.lobakin@intel.com>,
"Yonghong Song" <yhs@fb.com>,
"Shay Agroskin" <shayagr@amazon.com>,
"Marcin Wojtas" <mw@semihalf.com>,
petrm@nvidia.com, "Daniel Borkmann" <daniel@iogearbox.net>,
"David Arinzon" <darinzon@amazon.com>,
"David Ahern" <dsahern@kernel.org>,
"Toke Høiland-Jørgensen" <toke@redhat.com>,
virtualization@lists.linux-foundation.org,
linux-kernel@vger.kernel.org, "Martin KaFai Lau" <kafai@fb.com>,
"Edward Cree" <ecree.xilinx@gmail.com>,
"Yajun Deng" <yajun.deng@linux.dev>,
netdev@vger.kernel.org, "Saeed Bishara" <saeedb@amazon.com>,
"Michal Swiatkowski" <michal.swiatkowski@linux.intel.com>,
bpf@vger.kernel.org, "Saeed Mahameed" <saeedm@nvidia.com>,
"David S. Miller" <davem@davemloft.net>
Subject: Re: [PATCH v2 net-next 21/26] ice: add XDP and XSK generic per-channel statistics
Date: Sun, 28 Nov 2021 19:54:53 +0200 [thread overview]
Message-ID: <YaPCbaMVaVlxXcHC@shredder> (raw)
In-Reply-To: <20211126111431.4a2ed007@kicinski-fedora-pc1c0hjn.dhcp.thefacebook.com>
+Petr, Nik
On Fri, Nov 26, 2021 at 11:14:31AM -0800, Jakub Kicinski wrote:
> On Fri, 26 Nov 2021 19:47:17 +0100 Toke Høiland-Jørgensen wrote:
> > > Fair. In all honesty I said that hoping to push for a more flexible
> > > approach hidden entirely in BPF, and not involving driver changes.
> > > Assuming the XDP program has more fine grained stats we should be able
> > > to extract those instead of double-counting. Hence my vague "let's work
> > > with apps" comment.
> > >
> > > For example to a person familiar with the workload it'd be useful to
> > > know if program returned XDP_DROP because of configured policy or
> > > failure to parse a packet. I don't think that sort distinction is
> > > achievable at the level of standard stats.
> > >
> > > The information required by the admin is higher level. As you say the
> > > primary concern there is "how many packets did XDP eat".
> >
> > Right, sure, I am also totally fine with having only a somewhat
> > restricted subset of stats available at the interface level and make
> > everything else be BPF-based. I'm hoping we can converge of a common
> > understanding of what this "minimal set" should be :)
> >
> > > Speaking of which, one thing that badly needs clarification is our
> > > expectation around XDP packets getting counted towards the interface
> > > stats.
> >
> > Agreed. My immediate thought is that "XDP packets are interface packets"
> > but that is certainly not what we do today, so not sure if changing it
> > at this point would break things?
>
> I'd vote for taking the risk and trying to align all the drivers.
I agree. I think IFLA_STATS64 in RTM_NEWLINK should contain statistics
of all the packets seen by the netdev. The breakdown into software /
hardware / XDP should be reported via RTM_NEWSTATS.
Currently, for soft devices such as VLANs, bridges and GRE, user space
only sees statistics of packets forwarded by software, which is quite
useless when forwarding is offloaded from the kernel to hardware.
Petr is working on exposing hardware statistics for such devices via
rtnetlink. Unlike XDP (?), we need to be able to let user space enable /
disable hardware statistics as we have a limited number of hardware
counters and they can also reduce the bandwidth when enabled. We are
thinking of adding a new RTM_SETSTATS for that:
# ip stats set dev swp1 hw_stats on
For query, something like (under discussion):
# ip stats show dev swp1 // all groups
# ip stats show dev swp1 group link
# ip stats show dev swp1 group offload // all sub-groups
# ip stats show dev swp1 group offload sub-group cpu
# ip stats show dev swp1 group offload sub-group hw
Like other iproute2 commands, these follow the nesting of the
RTM_{NEW,GET}STATS uAPI.
Looking at patch #1 [1], I think that whatever you decide to expose for
XDP can be queried via:
# ip stats show dev swp1 group xdp
# ip stats show dev swp1 group xdp sub-group regular
# ip stats show dev swp1 group xdp sub-group xsk
Regardless, the following command should show statistics of all the
packets seen by the netdev:
# ip -s link show dev swp1
There is a PR [2] for node_exporter to use rtnetlink to fetch netdev
statistics instead of the old proc interface. It should be possible to
extend it to use RTM_*STATS for more fine-grained statistics.
[1] https://lore.kernel.org/netdev/20211123163955.154512-2-alexandr.lobakin@intel.com/
[2] https://github.com/prometheus/node_exporter/pull/2074
_______________________________________________
Virtualization mailing list
Virtualization@lists.linux-foundation.org
https://lists.linuxfoundation.org/mailman/listinfo/virtualization
next prev parent reply other threads:[~2021-11-28 17:55 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20211123163955.154512-1-alexandr.lobakin@intel.com>
[not found] ` <20211123163955.154512-22-alexandr.lobakin@intel.com>
2021-11-24 0:52 ` [PATCH v2 net-next 21/26] ice: add XDP and XSK generic per-channel statistics Daniel Borkmann
2021-11-25 11:56 ` Toke Høiland-Jørgensen
[not found] ` <20211125170708.127323-1-alexandr.lobakin@intel.com>
[not found] ` <20211125094440.6c402d63@kicinski-fedora-pc1c0hjn.dhcp.thefacebook.com>
[not found] ` <20211125204007.133064-1-alexandr.lobakin@intel.com>
2021-11-26 12:30 ` Toke Høiland-Jørgensen
[not found] ` <20211126100611.514df099@kicinski-fedora-pc1c0hjn.dhcp.thefacebook.com>
2021-11-26 18:47 ` Toke Høiland-Jørgensen
[not found] ` <20211126111431.4a2ed007@kicinski-fedora-pc1c0hjn.dhcp.thefacebook.com>
2021-11-28 17:54 ` Ido Schimmel [this message]
2021-11-26 22:27 ` Daniel Borkmann
2021-11-29 11:51 ` Toke Høiland-Jørgensen
[not found] ` <20211123163955.154512-9-alexandr.lobakin@intel.com>
2021-11-24 11:33 ` [PATCH v2 net-next 08/26] mvpp2: provide .ndo_get_xdp_stats() callback Russell King (Oracle)
2021-11-24 11:36 ` Russell King (Oracle)
[not found] ` <20211123163955.154512-8-alexandr.lobakin@intel.com>
2021-11-24 11:39 ` [PATCH v2 net-next 07/26] mvneta: add " Russell King (Oracle)
2021-11-28 22:23 ` [PATCH v2 net-next 00/26] net: introduce and use generic XDP stats David Ahern
[not found] ` <20211123163955.154512-2-alexandr.lobakin@intel.com>
2021-11-30 2:36 ` [PATCH v2 net-next 01/26] rtnetlink: introduce generic XDP statistics David Ahern
[not found] ` <20211130155612.594688-1-alexandr.lobakin@intel.com>
2021-11-30 16:17 ` [PATCH v2 net-next 00/26] net: introduce and use generic XDP stats Toke Høiland-Jørgensen
[not found] ` <20211130090716.4a557036@kicinski-fedora-pc1c0hjn.dhcp.thefacebook.com>
2021-11-30 17:56 ` David Ahern
[not found] ` <20211130081207.228f42ba@kicinski-fedora-pc1c0hjn.dhcp.thefacebook.com>
[not found] ` <20211130163454.595897-1-alexandr.lobakin@intel.com>
[not found] ` <20211130090449.58a8327d@kicinski-fedora-pc1c0hjn.dhcp.thefacebook.com>
2021-11-30 17:38 ` David Ahern
2021-12-01 15:21 ` Jamal Hadi Salim
2021-11-30 17:45 ` David Ahern
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=YaPCbaMVaVlxXcHC@shredder \
--to=idosch@idosch.org \
--cc=akiyano@amazon.com \
--cc=alexandr.lobakin@intel.com \
--cc=andrii@kernel.org \
--cc=anthony.l.nguyen@intel.com \
--cc=ast@kernel.org \
--cc=avagin@gmail.com \
--cc=bpf@vger.kernel.org \
--cc=claudiu.manoil@nxp.com \
--cc=cong.wang@bytedance.com \
--cc=corbet@lwn.net \
--cc=daniel@iogearbox.net \
--cc=darinzon@amazon.com \
--cc=davem@davemloft.net \
--cc=dsahern@kernel.org \
--cc=ecree.xilinx@gmail.com \
--cc=habetsm.xilinx@gmail.com \
--cc=hawk@kernel.org \
--cc=ioana.ciornei@nxp.com \
--cc=johannes.berg@intel.com \
--cc=john.fastabend@gmail.com \
--cc=kafai@fb.com \
--cc=kpsingh@kernel.org \
--cc=kuba@kernel.org \
--cc=leon@kernel.org \
--cc=linux-doc@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-rdma@vger.kernel.org \
--cc=linux@armlinux.org.uk \
--cc=lorenzo@kernel.org \
--cc=maciej.fijalkowski@intel.com \
--cc=michal.swiatkowski@linux.intel.com \
--cc=mst@redhat.com \
--cc=mw@semihalf.com \
--cc=ndagan@amazon.com \
--cc=netdev@vger.kernel.org \
--cc=nikolay@nvidia.com \
--cc=petrm@nvidia.com \
--cc=ryazanov.s.a@gmail.com \
--cc=saeedb@amazon.com \
--cc=saeedm@nvidia.com \
--cc=shayagr@amazon.com \
--cc=songliubraving@fb.com \
--cc=thomas.petazzoni@bootlin.com \
--cc=toke@redhat.com \
--cc=virtualization@lists.linux-foundation.org \
--cc=vladimir.oltean@nxp.com \
--cc=yajun.deng@linux.dev \
--cc=yhs@fb.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).