A recent 0-day report about new __percpu related sparse warnings made me look deeper into it after I dismissed the report as bogus initially. It turned out that sparse is actually right and all of these warnings (not only the most recent ones) are valid and got ignored. Some of them for many years. The worst offender is an UP build because that maps the per CPU cpu_info to boot_cpu_data, which is regular data. As a consequence all per CPU accessors which look like legit code and are legit code in the SMP build are causing sparse to emit warnings. This series addresses this by: - Adding the missing __percpu annotations all over the place - Curing the UP madness by exposing a proper per CPU cpu_info for the price of wasting 320 byte of memory. Even if the size police will hate me for that, this cures most of the madness in one go and avoids to add more hideous macro mess similar to the completely bogus cpu_data() one which should have never been there in the first place. I know that there are people who think that size matters, but the only things which really matter in software are correctness and maintainability. The latter simply forbids to add more hideous macro mess just to avoid wasting 320 bytes of memory for something which is mostly a reminiscence of the good old days... - Fixing a few obvious non __percpu related warnings which stood out prominently. That reduces the sparse warnings in arch/x86 significantly. The remaining ones are less trivial to address: - The non-x86 specific warning vs. sighand::lock: sparse: warning: incorrect type in argument 1 (different address spaces) sparse: expected struct lockdep_map const *lock sparse: got struct lockdep_map [noderef] __rcu * - A bunch of lock scope false positives which are non-trivial to solve - A gazillion of __iomem warnings with the vast majority in the HPE/UV code which are _all_ legit because neither UV nor the other places care about the name space annotations at all. Pointer is pointer after all. - Tons of truncation warnings like this: sparse: warning: cast truncates bits from constant value (20002 becomes 2) mostly in the hypervisor space (kvm, hyperv). I did not look at those at all so I don't know whether they matter or not. I really think sparse is valuable, but all of us should spend more time on this to weed out false positives or at least have some filtering of things which are simply not solvable at the sparse level. Coming back to __percpu. As I mentioned in the original thread it's a sad state of affairs that the only way to detect the __percpu fails is sparse or some other static checker: https://lore.kernel.org/all/87bk7vuldh.ffs@tglx But that's a different problem to solve and does not invalidate the fixes which come with this series in any way. If the compiler people would have provided a way to utilize the anyway non-standard name space support in a useful way, I could have spared the time to bang my head agaist the wall simply because this would have failed to build in the first place long ago. That just makes me sad. After wading through this, I really ask the 0-day people to push hard on any sparse fallout which involves __percpu. The resulting failures can be truly subtle and not necessarily fatal right away. The series is based on Linus tree and also available from git: git://git.kernel.org/pub/scm/linux/kernel/git/tglx/devel.git x86/core Thanks, tglx --- arch/alpha/kernel/smp.c | 5 ----- arch/arc/kernel/smp.c | 5 ----- arch/csky/kernel/smp.c | 4 ---- arch/hexagon/kernel/smp.c | 4 ---- arch/openrisc/kernel/smp.c | 4 ---- arch/riscv/kernel/smpboot.c | 4 ---- arch/sparc/kernel/smp_64.c | 4 ---- arch/x86/events/amd/uncore.c | 2 +- arch/x86/events/intel/core.c | 1 + arch/x86/events/intel/ds.c | 1 + arch/x86/include/asm/debugreg.h | 24 ++++++++++++++++++++++++ arch/x86/include/asm/fsgsbase.h | 2 +- arch/x86/include/asm/msr.h | 26 ++++++++++++++------------ arch/x86/include/asm/processor.h | 28 ---------------------------- arch/x86/include/asm/smp.h | 5 ----- arch/x86/include/asm/spec-ctrl.h | 2 ++ arch/x86/include/asm/special_insns.h | 4 ++-- arch/x86/include/asm/tsc.h | 3 ++- arch/x86/include/asm/uaccess_64.h | 7 ++++--- arch/x86/kernel/callthunks.c | 4 ++-- arch/x86/kernel/cpu/bugs.c | 2 +- arch/x86/kernel/cpu/common.c | 3 +++ arch/x86/kernel/cpu/intel_pconfig.c | 2 ++ arch/x86/kernel/cpu/rdrand.c | 1 + arch/x86/kernel/fpu/bugs.c | 2 ++ arch/x86/kernel/setup.c | 10 ++++++++++ arch/x86/kernel/smpboot.c | 9 +++++---- arch/x86/kernel/step.c | 2 ++ arch/x86/kvm/mmu/mmu.c | 3 +-- arch/x86/lib/msr-smp.c | 12 +++++------- arch/x86/lib/msr.c | 6 +++--- include/linux/smp.h | 13 ++++++------- init/main.c | 4 ++++ 33 files changed, 99 insertions(+), 109 deletions(-)