[ Arnd was already on the participants, but I moved him from 'Cc:' to 'To:', just because I think this is once again tangentially related to the whole "c99 base" thing ] On Wed, Feb 23, 2022 at 6:13 AM Jakob <jakobkoschel@xxxxxxxxx> wrote: > > I'm sorry for having created the confusion. I made this patch to support > the speculative safe list_for_each_entry() version but it is not actually > related to that. I do believe that this an actual bug and *could* > *potentially* be misused. I'll follow up with an example to illustrate that. Ok, so this is just a regular bug, plain and simple. The problem being that the list_for_each_entry() will iterate over each list entry - but at the end of the loop it will not point at any entry at all (it will have a pointer value that is related to the *HEAD* of the list, but that is not necessarily the same kind of entry that the list members are. Honestly, I think this kind of fix should have been done entirely separately. In fact, I think the change to list_for_each_entry() should have been done not as "fix type speculation", but as a much more interesting "fix the list iterators". The whole reason this kind of non-speculative bug can happen is that we historically didn't have C99-style "declare variables in loops". So list_for_each_entry() - and all the other ones - fundamentally always leaks the last HEAD entry out of the loop, simply because we couldn't declare the iterator variable in the loop itself. (And by "couldn't", I mean "without making for special syntax": we do exactly that in "for_each_thread ()" and friends, but they have an "end_for_each_thread()" thing at the end). So what I'd personally *really* like to see would be for us to - once again - look at using "-std=gnu99", and fix the whole "leak final invalid pointer outside the loop". Then the type speculation thing would be an entirely separate patch. Because honestly, I kind of hate the completely random type speculation patch. It fixes one particular type of loop, and not even one that seems all that special. But we still don't do "gnu99", because we had some odd problem with some ancient gcc versions that broke documented initializers. I honestly _thought_ we had gotten over that already. I think the problem cases were gcc-4.9 and older, and now we require gcc-5.1, and we could just use "--std=gnu99" for the kernel, and we could finally start using variable declarations in for-statements. Arnd - remind me, please.. Was there some other problem than just gcc-4.9? Linus