Re: [GIT PULL] kmalloc_obj treewide refactor for v7.0-rc1
From: Kees Cook
Date: Sat Feb 21 2026 - 18:20:05 EST
On Sat, Feb 21, 2026 at 03:01:15PM -0800, Linus Torvalds wrote:
> But I think I found the real bug:
>
> #define overflows_flex_counter_type(TYPE, FAM, COUNT) \
> (!overflows_type(COUNT, typeof_flex_counter(((TYPE *)NULL)->FAM)))
>
> WTF is up with that '!' there? That seems entirely bogus. So now
> overflows_flex_counter_type() will return true in it *doesn't*
> overflow the type.
>
> So I think clang was not actually the problem. That whole code looks buggy.
I would agree. This code mutated a few times but the logic and
docs for this function are in sync ("Returns: true if @COUNT can be
represented") but I renamed it somewhere along the way in a confusing
way and then got the above quoted macro's usage wrong.
> But that actually makes me *less* happy, because it means that this
> whole patch must have been ENTIRELY untested in any shape or form.
>
> If I read this right, none of this should have successfully booted
> anywhere if you had actually tested it outside of just compile-testing
> it.
Right, I am surprised as well, since I explicitly did boot testing on
the tree-wide refactor, though I admit the most recent validation over
the last few weeks has been on the compile testing side due to tracking
down type mismatches.
FWIW, I have now been able to reproduce the objtool warning, though,
using Fedora 42's Clang 20. I'm frustrated that it didn't show with the
other builds I did, and that 0day never sent a single email about it
over the weeks that I've had my tree up for testing.
-Kees
--
Kees Cook