On Fri, 18 Oct 2019 10:46:01 +0200 (CEST) Thomas Gleixner <tglx@xxxxxxxxxxxxx> wrote: > > > #3) BPF uses the up_read_non_owner() hackery which was only invented to > > > deal with already existing horrors and not meant to be proliferated. > > > > > > Yes, I know it's a existing facility .... > > > > I'm sure I'll regret asking this, but why is up_read_non_owner() a horror? I mean, > > I get the fundamental wrongness of having someone that's not the owner of a semaphore > > performing an 'up' on it, but is there an RT-specific reason that it's bad? Is it > > totally a blocker for using BPF with RT or is it something we should fix over time? > > RT has strict locker == unlocker semantics simply because the owner > (locker) is subject to priority inheritance and a non-owner unlock cannot > undo PI on behalf of the locker sanely. Also exposing the locker to PI if > the locker is not involved in unlocking is obviously a pointless exercise > and potentially a source of unbound priority inversion. Ok, I forgot about the PI consequences. Thanks teacher :) > > > I do think that we (RT) are going to have to co-exist with BPF, if only due to the > > increased use of XDP. I also think that other sub-systems will start to > > employ BPF for production purposes (as opposed to debug/analysis which is > > how we generally look at tracing, packet sniffing, etc.). I think we *have* to > > figure out how to co-exist. > > I'm not saying that RT does not want BPF, quite the contrary, but for the > initial merge BPF is not a hard requirement, so disabling it was the > straight forward path. > > I'm all ears to get pointers how to solve that right now. > Yeah, put it down to lack of sleep. After waking up and rereading, I first realized that we're not immediately affected since RHEL8 doesn't use BPF. But we're going to have to deal with it next year, since we'll be looking at a 5.6+ kernel which will have PREEMPT_RT and the latest BPF bells and whistles. So might as well start the conversations now. Arnaldo and I have been having lots of conversations regarding BPF, so we'll extend that and dig in on the preemption issue for now. We also need to understand the memory allocation behavior so we can hopefully move it out of atomic regions. I'm not sure how we should address the up_read_non_owner() issue at the moment. Clark -- The United States Coast Guard Ruining Natural Selection since 1790