Alexei Starovoitov <alexei.starovoitov@xxxxxxxxx> writes: > On Mon, Oct 14, 2019 at 02:35:45PM +0200, Toke Høiland-Jørgensen wrote: >> Alexei Starovoitov <alexei.starovoitov@xxxxxxxxx> writes: >> >> > On Wed, Oct 09, 2019 at 10:03:43AM +0200, Toke Høiland-Jørgensen wrote: >> >> Alexei Starovoitov <alexei.starovoitov@xxxxxxxxx> writes: >> >> >> >> > Please implement proper indirect calls and jumps. >> >> >> >> I am still not convinced this will actually solve our problem; but OK, I >> >> can give it a shot. >> > >> > If you're not convinced let's talk about it first. >> > >> > Indirect calls is a building block for debugpoints. >> > Let's not call them tracepoints, because Linus banned any discusion >> > that includes that name. >> > The debugpoints is a way for BPF program to insert points in its >> > code to let external facility to do tracing and debugging. >> > >> > void (*debugpoint1)(struct xdp_buff *, int code); >> > void (*debugpoint2)(struct xdp_buff *); >> > void (*debugpoint3)(int len); >> >> So how would these work? Similar to global variables (i.e., the loader >> creates a single-entry PROG_ARRAY map for each one)? Presumably with >> some BTF to validate the argument types? >> >> So what would it take to actually support this? It doesn't quite sound >> trivial to add? > > Depends on definition of 'trivial' :) Well, I don't know... :) > The kernel has a luxury of waiting until clean solution is implemented > instead of resorting to hacks. It would be helpful if you could give an opinion on what specific features are missing in the kernel to support these indirect calls. A few high-level sentences is fine (e.g., "the verifier needs to be able to do X, and llvm/libbpf needs to have support for Y")... I'm trying to gauge whether this is something it would even make sense for me to poke into, or if I'm better off waiting for someone who actually knows what they are doing to work on this :) >> > If you disagree please explain _your_ problem again. >> > Saying that fb katran is a use case for chaining is, hrm, not correct. >> >> I never said Katran was the driver for this. I just used Katran as one >> of the "prior art" examples for my "how are people solving running >> multiple programs on the same interface" survey. > > and they solved it. that's the point. Yes, in a way that's specific to Katran. This whole thing actually started out as an effort to make something that's (a) generically useful so everyone doesn't have to re-invent their own way of doing it, and (b) interoperable in the case where there is no direct coordination between the program authors. The ability to chain a program per return code came out of (a), and the need to not have to modify all programs involved came out of (b). >> What I want to achieve is simply the ability to run multiple independent >> XDP programs on the same interface, without having to put any >> constraints on the programs themselves. I'm not disputing that this is >> *possible* to do completely in userspace, I just don't believe the >> resulting solution will be very good. > > What makes me uneasy about the whole push for program chaining > is that tc cls_bpf supported multiple independent programs from day one. > Yet it doesn't help to run two firewalls hooked into tc ingress. > Similarly cgroup-bpf had a ton discussions on proper multi-prog api. > Everyone was eventually convinced that it's flexible and generic. > Yet people who started to use it complain that it's missing features > to make it truly usable in production. I'll go look at the cgroup-bpf API as well... Do you have any references to those complaints? -Toke