On Thu, 25 Apr 2024 at 10:46, Rafael J. Wysocki <rafael@xxxxxxxxxx> wrote: > > - Fix bit offset computation in MASK_VAL() macro used for applying > a bitmask to a new CPPC register value (Jarred White). Honestly, that code should never have used GENMASK() in the first place. When a helper macro is more complicated than just doing the obvious thing without it, it's not a helper macro any more. Doing GENMASK(((reg)->bit_width) - 1, 0) is literally more work than just doing the obvious thing ((1ul << (reg)->bit_width) - 1) and using that "helper" macro was actually more error-prone too as shown by this example, because of the whole "inclusive or not" issue. BUT! Even with that simpler model, that's still entirely buggy, since 'val' is 64-bit, and these GENMASK tricks only work on 'long'. Which happens to be ok on x86-64, of course, and maybe in practice all fields are less than 32 bits in width anyway so maybe it even works on 32-bit, but this all smells HORRIBLY WRONG. And no, the fix is *NOT* to make that GENVAL() mindlessly just be GENVAL_ULL(). That fixes the immediate bug, but it shows - once again - how mindlessly using "helper macros" is not the right thing to do. When that macro now has had TWO independent bugs, how about you just write it out with explicit types and without any broken "helpers": static inline u64 MASK_VAL(const struct cpc_reg *reg, u64 val) { u64 mask = (1ull << reg->bit_width)-1; return (val >> reg->bit_offset) & mask; } which is a few more lines, but doesn't that make it a whole lot more readable? And maybe this time, it's not a buggy mess? Linus