Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit df9ee292 authored by David Howells's avatar David Howells
Browse files

Fix IRQ flag handling naming



Fix the IRQ flag handling naming.  In linux/irqflags.h under one configuration,
it maps:

	local_irq_enable() -> raw_local_irq_enable()
	local_irq_disable() -> raw_local_irq_disable()
	local_irq_save() -> raw_local_irq_save()
	...

and under the other configuration, it maps:

	raw_local_irq_enable() -> local_irq_enable()
	raw_local_irq_disable() -> local_irq_disable()
	raw_local_irq_save() -> local_irq_save()
	...

This is quite confusing.  There should be one set of names expected of the
arch, and this should be wrapped to give another set of names that are expected
by users of this facility.

Change this to have the arch provide:

	flags = arch_local_save_flags()
	flags = arch_local_irq_save()
	arch_local_irq_restore(flags)
	arch_local_irq_disable()
	arch_local_irq_enable()
	arch_irqs_disabled_flags(flags)
	arch_irqs_disabled()
	arch_safe_halt()

Then linux/irqflags.h wraps these to provide:

	raw_local_save_flags(flags)
	raw_local_irq_save(flags)
	raw_local_irq_restore(flags)
	raw_local_irq_disable()
	raw_local_irq_enable()
	raw_irqs_disabled_flags(flags)
	raw_irqs_disabled()
	raw_safe_halt()

with type checking on the flags 'arguments', and then wraps those to provide:

	local_save_flags(flags)
	local_irq_save(flags)
	local_irq_restore(flags)
	local_irq_disable()
	local_irq_enable()
	irqs_disabled_flags(flags)
	irqs_disabled()
	safe_halt()

with tracing included if enabled.

The arch functions can now all be inline functions rather than some of them
having to be macros.

Signed-off-by: David Howells <dhowells@redhat.com> [X86, FRV, MN10300]
Signed-off-by: Chris Metcalf <cmetcalf@tilera.com> [Tile]
Signed-off-by: Michal Simek <monstr@monstr.eu> [Microblaze]
Tested-by: Catalin Marinas <catalin.marinas@arm.com> [ARM]
Acked-by: default avatarThomas Gleixner <tglx@linutronix.de>
Acked-by: Haavard Skinnemoen <haavard.skinnemoen@atmel.com> [AVR]
Acked-by: Tony Luck <tony.luck@intel.com> [IA-64]
Acked-by: Hirokazu Takata <takata@linux-m32r.org> [M32R]
Acked-by: Greg Ungerer <gerg@uclinux.org> [M68K/M68KNOMMU]
Acked-by: Ralf Baechle <ralf@linux-mips.org> [MIPS]
Acked-by: Kyle McMartin <kyle@mcmartin.ca> [PA-RISC]
Acked-by: Paul Mackerras <paulus@samba.org> [PowerPC]
Acked-by: Martin Schwidefsky <schwidefsky@de.ibm.com> [S390]
Acked-by: Chen Liqin <liqin.chen@sunplusct.com> [Score]
Acked-by: Matt Fleming <matt@console-pimps.org> [SH]
Acked-by: David S. Miller <davem@davemloft.net> [Sparc]
Acked-by: Chris Zankel <chris@zankel.net> [Xtensa]
Reviewed-by: Richard Henderson <rth@twiddle.net> [Alpha]
Reviewed-by: Yoshinori Sato <ysato@users.sourceforge.jp> [H8300]
Cc: starvik@axis.com [CRIS]
Cc: jesper.nilsson@axis.com [CRIS]
Cc: linux-cris-kernel@axis.com
parent ca4d3e67
Loading
Loading
Loading
Loading
+67 −0
Original line number Original line Diff line number Diff line
#ifndef __ALPHA_IRQFLAGS_H
#define __ALPHA_IRQFLAGS_H

#include <asm/system.h>

#define IPL_MIN		0
#define IPL_SW0		1
#define IPL_SW1		2
#define IPL_DEV0	3
#define IPL_DEV1	4
#define IPL_TIMER	5
#define IPL_PERF	6
#define IPL_POWERFAIL	6
#define IPL_MCHECK	7
#define IPL_MAX		7

#ifdef CONFIG_ALPHA_BROKEN_IRQ_MASK
#undef IPL_MIN
#define IPL_MIN		__min_ipl
extern int __min_ipl;
#endif

#define getipl()		(rdps() & 7)
#define setipl(ipl)		((void) swpipl(ipl))

static inline unsigned long arch_local_save_flags(void)
{
	return rdps();
}

static inline void arch_local_irq_disable(void)
{
	setipl(IPL_MAX);
	barrier();
}

static inline unsigned long arch_local_irq_save(void)
{
	unsigned long flags = swpipl(IPL_MAX);
	barrier();
	return flags;
}

static inline void arch_local_irq_enable(void)
{
	barrier();
	setipl(IPL_MIN);
}

static inline void arch_local_irq_restore(unsigned long flags)
{
	barrier();
	setipl(flags);
	barrier();
}

static inline bool arch_irqs_disabled_flags(unsigned long flags)
{
	return flags == IPL_MAX;
}

static inline bool arch_irqs_disabled(void)
{
	return arch_irqs_disabled_flags(getipl());
}

#endif /* __ALPHA_IRQFLAGS_H */
+0 −28
Original line number Original line Diff line number Diff line
@@ -259,34 +259,6 @@ __CALL_PAL_RW2(wrperfmon, unsigned long, unsigned long, unsigned long);
__CALL_PAL_W1(wrusp, unsigned long);
__CALL_PAL_W1(wrusp, unsigned long);
__CALL_PAL_W1(wrvptptr, unsigned long);
__CALL_PAL_W1(wrvptptr, unsigned long);


#define IPL_MIN		0
#define IPL_SW0		1
#define IPL_SW1		2
#define IPL_DEV0	3
#define IPL_DEV1	4
#define IPL_TIMER	5
#define IPL_PERF	6
#define IPL_POWERFAIL	6
#define IPL_MCHECK	7
#define IPL_MAX		7

#ifdef CONFIG_ALPHA_BROKEN_IRQ_MASK
#undef IPL_MIN
#define IPL_MIN		__min_ipl
extern int __min_ipl;
#endif

#define getipl()		(rdps() & 7)
#define setipl(ipl)		((void) swpipl(ipl))

#define local_irq_disable()			do { setipl(IPL_MAX); barrier(); } while(0)
#define local_irq_enable()			do { barrier(); setipl(IPL_MIN); } while(0)
#define local_save_flags(flags)	((flags) = rdps())
#define local_irq_save(flags)	do { (flags) = swpipl(IPL_MAX); barrier(); } while(0)
#define local_irq_restore(flags)	do { barrier(); setipl(flags); barrier(); } while(0)

#define irqs_disabled()	(getipl() == IPL_MAX)

/*
/*
 * TB routines..
 * TB routines..
 */
 */
+84 −61
Original line number Original line Diff line number Diff line
@@ -10,66 +10,85 @@
 */
 */
#if __LINUX_ARM_ARCH__ >= 6
#if __LINUX_ARM_ARCH__ >= 6


#define raw_local_irq_save(x)					\
static inline unsigned long arch_local_irq_save(void)
	({							\
{
	__asm__ __volatile__(					\
	unsigned long flags;
	"mrs	%0, cpsr		@ local_irq_save\n"	\

	"cpsid	i"						\
	asm volatile(
	: "=r" (x) : : "memory", "cc");				\
		"	mrs	%0, cpsr	@ arch_local_irq_save\n"
	})
		"	cpsid	i"
		: "=r" (flags) : : "memory", "cc");
	return flags;
}

static inline void arch_local_irq_enable(void)
{
	asm volatile(
		"	cpsie i			@ arch_local_irq_enable"
		:
		:
		: "memory", "cc");
}

static inline void arch_local_irq_disable(void)
{
	asm volatile(
		"	cpsid i			@ arch_local_irq_disable"
		:
		:
		: "memory", "cc");
}


#define raw_local_irq_enable()  __asm__("cpsie i	@ __sti" : : : "memory", "cc")
#define raw_local_irq_disable() __asm__("cpsid i	@ __cli" : : : "memory", "cc")
#define local_fiq_enable()  __asm__("cpsie f	@ __stf" : : : "memory", "cc")
#define local_fiq_enable()  __asm__("cpsie f	@ __stf" : : : "memory", "cc")
#define local_fiq_disable() __asm__("cpsid f	@ __clf" : : : "memory", "cc")
#define local_fiq_disable() __asm__("cpsid f	@ __clf" : : : "memory", "cc")

#else
#else


/*
/*
 * Save the current interrupt enable state & disable IRQs
 * Save the current interrupt enable state & disable IRQs
 */
 */
#define raw_local_irq_save(x)					\
static inline unsigned long arch_local_irq_save(void)
	({							\
{
		unsigned long temp;				\
	unsigned long flags, temp;
		(void) (&temp == &x);				\

	__asm__ __volatile__(					\
	asm volatile(
	"mrs	%0, cpsr		@ local_irq_save\n"	\
		"	mrs	%0, cpsr	@ arch_local_irq_save\n"
"	orr	%1, %0, #128\n"					\
		"	orr	%1, %0, #128\n"
"	msr	cpsr_c, %1"					\
		"	msr	cpsr_c, %1"
	: "=r" (x), "=r" (temp)					\
		: "=r" (flags), "=r" (temp)
	:							\
		:
	: "memory", "cc");					\
		: "memory", "cc");
	})
	return flags;
}


/*
/*
 * Enable IRQs
 * Enable IRQs
 */
 */
#define raw_local_irq_enable()					\
static inline void arch_local_irq_enable(void)
	({							\
{
		unsigned long temp;				\
	unsigned long temp;
	__asm__ __volatile__(					\
	asm volatile(
	"mrs	%0, cpsr		@ local_irq_enable\n"	\
		"	mrs	%0, cpsr	@ arch_local_irq_enable\n"
"	bic	%0, %0, #128\n"					\
		"	bic	%0, %0, #128\n"
"	msr	cpsr_c, %0"					\
		"	msr	cpsr_c, %0"
	: "=r" (temp)						\
		: "=r" (temp)
	:							\
		:
	: "memory", "cc");					\
		: "memory", "cc");
	})
}


/*
/*
 * Disable IRQs
 * Disable IRQs
 */
 */
#define raw_local_irq_disable()					\
static inline void arch_local_irq_disable(void)
	({							\
{
		unsigned long temp;				\
	unsigned long temp;
	__asm__ __volatile__(					\
	asm volatile(
	"mrs	%0, cpsr		@ local_irq_disable\n"	\
		"	mrs	%0, cpsr	@ arch_local_irq_disable\n"
"	orr	%0, %0, #128\n"					\
		"	orr	%0, %0, #128\n"
"	msr	cpsr_c, %0"					\
		"	msr	cpsr_c, %0"
	: "=r" (temp)						\
		: "=r" (temp)
	:							\
		:
	: "memory", "cc");					\
		: "memory", "cc");
	})
}


/*
/*
 * Enable FIQs
 * Enable FIQs
@@ -106,27 +125,31 @@
/*
/*
 * Save the current interrupt enable state.
 * Save the current interrupt enable state.
 */
 */
#define raw_local_save_flags(x)					\
static inline unsigned long arch_local_save_flags(void)
	({							\
{
	__asm__ __volatile__(					\
	unsigned long flags;
	"mrs	%0, cpsr		@ local_save_flags"	\
	asm volatile(
	: "=r" (x) : : "memory", "cc");				\
		"	mrs	%0, cpsr	@ local_save_flags"
	})
		: "=r" (flags) : : "memory", "cc");
	return flags;
}


/*
/*
 * restore saved IRQ & FIQ state
 * restore saved IRQ & FIQ state
 */
 */
#define raw_local_irq_restore(x)				\
static inline void arch_local_irq_restore(unsigned long flags)
	__asm__ __volatile__(					\
{
	"msr	cpsr_c, %0		@ local_irq_restore\n"	\
	asm volatile(
	:							\
		"	msr	cpsr_c, %0	@ local_irq_restore"
	: "r" (x)						\
		:
	: "memory", "cc")
		: "r" (flags)

		: "memory", "cc");
#define raw_irqs_disabled_flags(flags)	\
}
({					\

	(int)((flags) & PSR_I_BIT);	\
static inline int arch_irqs_disabled_flags(unsigned long flags)
})
{
	return flags & PSR_I_BIT;
}


#endif
#endif
#endif
#endif
+11 −18
Original line number Original line Diff line number Diff line
@@ -8,16 +8,14 @@
#ifndef __ASM_AVR32_IRQFLAGS_H
#ifndef __ASM_AVR32_IRQFLAGS_H
#define __ASM_AVR32_IRQFLAGS_H
#define __ASM_AVR32_IRQFLAGS_H


#include <linux/types.h>
#include <asm/sysreg.h>
#include <asm/sysreg.h>


static inline unsigned long __raw_local_save_flags(void)
static inline unsigned long arch_local_save_flags(void)
{
{
	return sysreg_read(SR);
	return sysreg_read(SR);
}
}


#define raw_local_save_flags(x)					\
	do { (x) = __raw_local_save_flags(); } while (0)

/*
/*
 * This will restore ALL status register flags, not only the interrupt
 * This will restore ALL status register flags, not only the interrupt
 * mask flag.
 * mask flag.
@@ -25,44 +23,39 @@ static inline unsigned long __raw_local_save_flags(void)
 * The empty asm statement informs the compiler of this fact while
 * The empty asm statement informs the compiler of this fact while
 * also serving as a barrier.
 * also serving as a barrier.
 */
 */
static inline void raw_local_irq_restore(unsigned long flags)
static inline void arch_local_irq_restore(unsigned long flags)
{
{
	sysreg_write(SR, flags);
	sysreg_write(SR, flags);
	asm volatile("" : : : "memory", "cc");
	asm volatile("" : : : "memory", "cc");
}
}


static inline void raw_local_irq_disable(void)
static inline void arch_local_irq_disable(void)
{
{
	asm volatile("ssrf %0" : : "n"(SYSREG_GM_OFFSET) : "memory");
	asm volatile("ssrf %0" : : "n"(SYSREG_GM_OFFSET) : "memory");
}
}


static inline void raw_local_irq_enable(void)
static inline void arch_local_irq_enable(void)
{
{
	asm volatile("csrf %0" : : "n"(SYSREG_GM_OFFSET) : "memory");
	asm volatile("csrf %0" : : "n"(SYSREG_GM_OFFSET) : "memory");
}
}


static inline int raw_irqs_disabled_flags(unsigned long flags)
static inline bool arch_irqs_disabled_flags(unsigned long flags)
{
{
	return (flags & SYSREG_BIT(GM)) != 0;
	return (flags & SYSREG_BIT(GM)) != 0;
}
}


static inline int raw_irqs_disabled(void)
static inline bool arch_irqs_disabled(void)
{
{
	unsigned long flags = __raw_local_save_flags();
	return arch_irqs_disabled_flags(arch_local_save_flags());

	return raw_irqs_disabled_flags(flags);
}
}


static inline unsigned long __raw_local_irq_save(void)
static inline unsigned long arch_local_irq_save(void)
{
{
	unsigned long flags = __raw_local_save_flags();
	unsigned long flags = arch_local_save_flags();


	raw_local_irq_disable();
	arch_local_irq_disable();


	return flags;
	return flags;
}
}


#define raw_local_irq_save(flags)				\
	do { (flags) = __raw_local_irq_save(); } while (0)

#endif /* __ASM_AVR32_IRQFLAGS_H */
#endif /* __ASM_AVR32_IRQFLAGS_H */
+0 −12
Original line number Original line Diff line number Diff line
@@ -218,16 +218,4 @@ static inline void hard_local_irq_restore(unsigned long flags)




#endif /* !CONFIG_IPIPE */
#endif /* !CONFIG_IPIPE */

/*
 * Raw interface to linux/irqflags.h.
 */
#define raw_local_save_flags(flags)	do { (flags) = arch_local_save_flags(); } while (0)
#define raw_local_irq_save(flags)	do { (flags) = arch_local_irq_save(); } while (0)
#define raw_local_irq_restore(flags)	arch_local_irq_restore(flags)
#define raw_local_irq_enable()		arch_local_irq_enable()
#define raw_local_irq_disable()		arch_local_irq_disable()
#define raw_irqs_disabled_flags(flags)	arch_irqs_disabled_flags(flags)
#define raw_irqs_disabled()		arch_irqs_disabled()

#endif
#endif
Loading