On Sat, Oct 29, 2016 at 01:59:23PM +0900, Lorenzo Colitti wrote: > On Sat, Oct 29, 2016 at 1:51 PM, Alexei Starovoitov > <alexei.starovoitov@xxxxxxxxx> wrote: > >> What's the use case for egress? > >> > >> We (android networking) are currently looking at implementing network > >> accounting via eBPF in order to replace the out-of-tree xt_qtaguid > >> code. A per-cgroup eBPF program run on all traffic would be great. But > >> when we looked at this patchset we realized it would not be useful for > >> accounting purposes because even if a packet is counted here, it might > >> still be dropped by netfilter hooks. > > > > don't use out-of-tree and instead drop using this mechanism or > > any other in-kernel method? ;) > > Getting rid of out-of-tree code is the goal, yes. We do have a > requirement that things continue to work, though. Accounting for a > packet in ip{,6}_output is not correct if that packet ends up being > dropped by iptables later on. understood. it could be solved by swapping the order of cgroup_bpf_run_filter() and NF_INET_POST_ROUTING in patch 5. It was proposed some time back, but the current patch, I think, is more symmetrical. cgroup+bpf runs after nf hook on rx and runs before it on tx. imo it's more consistent. Regardless of this choice... are you going to backport cgroupv2 to android? Because this set is v2 only. > > We (facebook infrastructure) have been using iptables and bpf networking > > together with great success. They nicely co-exist and complement each other. > > There is no need to reinvent the wheel if existing solution works. > > iptables are great for their purpose. > > That doesn't really answer my "what is the use case for egress" > question though, right? Or are you saying "we use this, but we can't > talk about how we use it"? if the question is "why patch 4 alone is not enough and patch 5 is needed"? Then it's symmetrical access. Accounting for RX only is a half done job. > > there is iptables+cBPF support. It's being used in some cases already. > > Adding eBPF support to the xt_bpf iptables code would be an option for > what we want to do, yes. I think this requires that the eBPF map to be > an fd that is available to the process that exec()s iptables, but we > could do that. yes. that's certainly doable, but sooner or later such approach will hit scalability issue when number of cgroups is large. Same issue we saw with cls_bpf and bpf_skb_under_cgroup(). Hence this patch set was needed that is centered around cgroups instead of hooks. Note, unlike, tc and nf there is no way to attach to a hook. The bpf program is attached to a cgroup. It's an important distinction vs everything that currently exists in the stack. -- To unsubscribe from this list: send the line "unsubscribe cgroups" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html