lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Wed, 9 Apr 2008 19:27:08 -0700 From: Andrew Morton <akpm@...ux-foundation.org> To: Martin Schwidefsky <schwidefsky@...ibm.com>, Heiko Carstens <heiko.carstens@...ibm.com> Cc: Thomas Gleixner <tglx@...utronix.de>, Ingo Molnar <mingo@...e.hu>, linux-kernel@...r.kernel.org Subject: local_softirq_pending() kernel/time/tick-sched.c: In function 'tick_nohz_stop_sched_tick': kernel/time/tick-sched.c:229: warning: format '%02x' expects type 'unsigned int', but argument 2 has type '__u64' I don't think the architecture's local_softirq_pending() should return u64. This is the sort of thing which should be consistent across architectures. Problem is, we've made such a complete mess of everything that this is a bitch to fix. The obvious and moderately clean fix is: --- a/include/asm-s390/hardirq.h~a +++ a/include/asm-s390/hardirq.h @@ -25,10 +25,24 @@ typedef struct { unsigned int __softirq_pending; } irq_cpustat_t; -#define local_softirq_pending() (S390_lowcore.softirq_pending) +static inline unsigned int local_softirq_pending(void) +{ + return S390_lowcore.softirq_pending; +} + +static inline void set_softirq_pending(unsigned int val) +{ + S390_lowcore.softirq_pending = val; +} + +static inline void or_softirq_pending(unsigned int val) +{ + S390_lowcore.softirq_pending |= val; +} #define __ARCH_IRQ_STAT #define __ARCH_HAS_DO_SOFTIRQ +#define __ARCH_SET_SOFTIRQ_PENDING #define HARDIRQ_BITS 8 But that doesn't work because sometimes this 'orrible crap from linux/interrupt.h: #ifndef __ARCH_SET_SOFTIRQ_PENDING #define set_softirq_pending(x) (local_softirq_pending() = (x)) #define or_softirq_pending(x) (local_softirq_pending() |= (x)) #endif gets included first, which screws up include/asm-s390/hardirq.h. So I'll cheerfully drop it into someone else's lap. A sensible fix would be to remove that nonsense from linux/interrupt.h (which appears to have been added for x86) and give each architecture its own local_softirq_pending(), set_softirq_pending() and or_softirq_pending(). Very much preferably for avoiding any ^+#define... btw, there's a naming inconsistency here. Shouldn't they be local_softirq_pending set_local_softirq_pending or_local_softirq_pending ? btw2, why do we need a per-arch or_softirq_pending()? Can't that just be built from set_softirq_pending() and local_softirq_pending() in generic code? -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@...r.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists