From: Toshiaki Makita <toshiaki.makita1@gmail.com> To: Jamal Hadi Salim <jhs@mojatatu.com>, John Fastabend <john.fastabend@gmail.com>, Alexei Starovoitov <ast@kernel.org>, Daniel Borkmann <daniel@iogearbox.net>, Martin KaFai Lau <kafai@fb.com>, Song Liu <songliubraving@fb.com>, Yonghong Song <yhs@fb.com>, "David S. Miller" <davem@davemloft.net>, Jakub Kicinski <jakub.kicinski@netronome.com>, Jesper Dangaard Brouer <hawk@kernel.org>, Cong Wang <xiyou.wangcong@gmail.com>, Jiri Pirko <jiri@resnulli.us>, Pablo Neira Ayuso <pablo@netfilter.org>, Jozsef Kadlecsik <kadlec@netfilter.org>, Florian Westphal <fw@strlen.de>, Pravin B Shelar <pshelar@ovn.org> Cc: netdev@vger.kernel.org, bpf@vger.kernel.org, William Tu <u9012063@gmail.com>, Stanislav Fomichev <sdf@fomichev.me> Subject: Re: [RFC PATCH v2 bpf-next 00/15] xdp_flow: Flow offload to XDP Date: Sun, 27 Oct 2019 22:27:01 +0900 [thread overview] Message-ID: <421d6fa7-487a-f653-f520-7050a7892ab9@gmail.com> (raw) In-Reply-To: <1c794797-db6f-83a7-30b4-aa864f798e5b@mojatatu.com> On 19/10/23 (水) 23:11:25, Jamal Hadi Salim wrote: > > Sorry - didnt read every detail of this thread so i may > be missing something. > > On 2019-10-22 12:54 p.m., John Fastabend wrote: >> Toshiaki Makita wrote: >>> On 2019/10/19 0:22, John Fastabend wrote: >>>> Toshiaki Makita wrote: >>>>> This is a PoC for an idea to offload flow, i.e. TC flower and >>>>> nftables, >>>>> to XDP. >>>>> > >> >> I don't know who this "someone" is that wants to use XDP through TC >> flower or nftables transparently. TC at least is not known for a >> great uapi. > > > The uapi is netlink. You may be talking about lack of a friendly > application library that abstracts out concepts? > >> It seems to me that it would be a relatively small project >> to write a uapi that ran on top of a canned XDP program to add >> flow rules. This could match tc cli if you wanted but why not take >> the opportunity to write a UAPI that does flow management well. >> > > Disagreement: > Unfortunately legacy utilities and apps cant just be magically wished > away. There's a lot of value in transparently making them work with > new infrastructure. My usual exaggerated pitch: 1000 books have been > written on this stuff, 100K people have RH certificates which entitle > them to be "experts"; dinasour kernels exist in data centres and > (/giggle) "enteprise". You cant just ignore all that. > > Summary: there is value in what Toshiaki is doing. > > I am disappointed that given a flexible canvas like XDP, we are still > going after something like flower... if someone was using u32 as the > abstraction it will justify it a lot more in my mind. > Tying it to OVS as well is not doing it justice. Flexibility is good for the time when very complicated or unusual flow handling is needed. OTOH, good flexibility often sacrifices good usability IMO. Configuration tends to be difficult. What I want to do here is to make XDP easy for sysadmins for typical use-cases. u32 is good for flexibility, but to me flower is easier to use. Using flower fits better in my intention. > > Agreement: > Having said that I dont think that flower/OVS should be the interface > that XDP should be aware of. Neither do i agree that kernel "real > estate" should belong to Oneway(TM) of doing things (we are still stuck > with netfilter planting the columbus flag on all networking hooks). > Let 1000 flowers bloom. > So: couldnt Toshiaki's requirement be met with writting a user space > daemon that trampolines flower to "XDP format" flow transforms? That way > in the future someone could add a u32->XDP format flow definition and we > are not doomed to forever just use flower. Userspace daemon is possible. Do you mean adding notification points in TC and listen filter modification events from userspace? If so, I'm not so positive about this, as it seems difficult to emulate TC/kernel behavior from userspace. Note that I think u32 offload can be added in the future even with current xdp_flow implementation. Toshiaki Makita
next prev parent reply other threads:[~2019-10-27 13:27 UTC|newest] Thread overview: 58+ messages / expand[flat|nested] mbox.gz Atom feed top 2019-10-18 4:07 Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 01/15] xdp_flow: Add skeleton of XDP based flow offload driver Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 02/15] xdp_flow: Add skeleton bpf program for XDP Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 03/15] bpf: Add API to get program from id Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 04/15] xdp: Export dev_check_xdp and dev_change_xdp Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 05/15] xdp_flow: Attach bpf prog to XDP in kernel after UMH loaded program Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 06/15] xdp_flow: Prepare flow tables in bpf Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 07/15] xdp_flow: Add flow entry insertion/deletion logic in UMH Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 08/15] xdp_flow: Add flow handling and basic actions in bpf prog Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 09/15] xdp_flow: Implement flow replacement/deletion logic in xdp_flow kmod Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 10/15] xdp_flow: Add netdev feature for enabling flow offload to XDP Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 11/15] xdp_flow: Implement redirect action Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 12/15] xdp_flow: Implement vlan_push action Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 13/15] bpf, selftest: Add test for xdp_flow Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 14/15] i40e: prefetch xdp->data before running XDP prog Toshiaki Makita 2019-10-18 4:07 ` [RFC PATCH v2 bpf-next 15/15] bpf, hashtab: Compare keys in long Toshiaki Makita 2019-10-18 15:22 ` [RFC PATCH v2 bpf-next 00/15] xdp_flow: Flow offload to XDP John Fastabend 2019-10-21 7:31 ` Toshiaki Makita 2019-10-22 16:54 ` John Fastabend 2019-10-22 17:45 ` Toke Høiland-Jørgensen 2019-10-24 4:27 ` John Fastabend 2019-10-24 10:13 ` Toke Høiland-Jørgensen 2019-10-27 13:19 ` Toshiaki Makita 2019-10-27 15:21 ` Toke Høiland-Jørgensen 2019-10-28 3:16 ` David Ahern 2019-10-28 8:36 ` Toke Høiland-Jørgensen 2019-10-28 10:08 ` Jesper Dangaard Brouer 2019-10-28 19:07 ` David Ahern 2019-10-28 19:05 ` David Ahern 2019-10-31 0:18 ` Toshiaki Makita 2019-10-31 12:12 ` Toke Høiland-Jørgensen 2019-11-11 7:32 ` Toshiaki Makita 2019-11-12 16:53 ` Toke Høiland-Jørgensen 2019-11-14 10:11 ` Toshiaki Makita 2019-11-14 12:41 ` Toke Høiland-Jørgensen 2019-11-18 6:41 ` Toshiaki Makita 2019-11-18 10:20 ` Toke Høiland-Jørgensen 2019-11-22 5:42 ` Toshiaki Makita 2019-11-22 11:54 ` Toke Høiland-Jørgensen 2019-11-25 10:18 ` Toshiaki Makita 2019-11-25 13:03 ` Toke Høiland-Jørgensen 2019-11-18 10:28 ` Toke Høiland-Jørgensen 2019-10-27 13:13 ` Toshiaki Makita 2019-10-27 15:24 ` Toke Høiland-Jørgensen 2019-10-27 19:17 ` David Miller 2019-10-31 0:32 ` Toshiaki Makita 2019-11-12 17:50 ` William Tu 2019-11-14 10:06 ` Toshiaki Makita 2019-11-14 17:09 ` William Tu 2019-11-15 13:16 ` Toke Høiland-Jørgensen 2019-11-12 17:38 ` William Tu 2019-10-23 14:11 ` Jamal Hadi Salim 2019-10-24 4:38 ` John Fastabend 2019-10-24 17:05 ` Jamal Hadi Salim 2019-10-27 13:27 ` Toshiaki Makita [this message] 2019-10-27 13:06 ` Toshiaki Makita 2019-10-21 11:23 ` Björn Töpel 2019-10-21 11:47 ` Toshiaki Makita
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=421d6fa7-487a-f653-f520-7050a7892ab9@gmail.com \ --to=toshiaki.makita1@gmail.com \ --cc=ast@kernel.org \ --cc=bpf@vger.kernel.org \ --cc=daniel@iogearbox.net \ --cc=davem@davemloft.net \ --cc=fw@strlen.de \ --cc=hawk@kernel.org \ --cc=jakub.kicinski@netronome.com \ --cc=jhs@mojatatu.com \ --cc=jiri@resnulli.us \ --cc=john.fastabend@gmail.com \ --cc=kadlec@netfilter.org \ --cc=kafai@fb.com \ --cc=netdev@vger.kernel.org \ --cc=pablo@netfilter.org \ --cc=pshelar@ovn.org \ --cc=sdf@fomichev.me \ --cc=songliubraving@fb.com \ --cc=u9012063@gmail.com \ --cc=xiyou.wangcong@gmail.com \ --cc=yhs@fb.com \ --subject='Re: [RFC PATCH v2 bpf-next 00/15] xdp_flow: Flow offload to XDP' \ /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
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).