On Tue, Jun 8, 2021 at 12:20 AM Kumar Kartikeya Dwivedi <memxor@xxxxxxxxx> wrote: > > So we're not really creating a qdisc here, we're just tying the filter (which in > the current semantics exists only while attached) to the bpf_link. The filter is > the attachment, so tying its lifetime to bpf_link makes sense. When you destroy > the bpf_link, the filter goes away too, which means classification at that > hook (parent/class) in the qdisc stops working. This is why creating the filter > from the bpf_link made sense to me. I see why you are creating TC filters now, because you are trying to force the lifetime of a bpf target to align with the bpf program itself. The deeper reason seems to be that a cls_bpf filter looks so small that it appears to you that it has nothing but a bpf_prog, right? I offer two different views here: 1. If you view a TC filter as an instance as a netdev/qdisc/action, they are no different from this perspective. Maybe the fact that a TC filter resides in a qdisc makes a slight difference here, but like I mentioned, it actually makes sense to let TC filters be standalone, qdisc's just have to bind with them, like how we bind TC filters with standalone TC actions. These are all updated independently, despite some of them residing in another. There should not be an exceptional TC filter which can not be updated via `tc filter` command. 2. For cls_bpf specifically, it is also an instance, like all other TC filters. You can update it in the same way: tc filter change [...] The only difference is a bpf program can attach to such an instance. So you can view the bpf program attached to cls_bpf as a property of it. From this point of view, there is no difference with XDP to netdev, where an XDP program attached to a netdev is also a property of netdev. A netdev can still function without XDP. Same for cls_bpf, it can be just a nop returns TC_ACT_SHOT (or whatever) if no ppf program is attached. Thus, the lifetime of a bpf program can be separated from the target it attaches too, like all other bpf_link targets. bpf_link is just a supplement to `tc filter change cls_bpf`, not to replace it. This is actually simpler, you do not need to worry about whether netdev is destroyed when you detach the XDP bpf_link anyway, same for cls_bpf filters. Likewise, TC filters don't need to worry about bpf_links associated. Thanks.