hw_irq.h

来自「linux 内核源代码」· C头文件 代码 · 共 125 行

H
125
字号
/* * Copyright (C) 1999 Cort Dougan <cort@cs.nmt.edu> */#ifndef _ASM_POWERPC_HW_IRQ_H#define _ASM_POWERPC_HW_IRQ_H#ifdef __KERNEL__#include <linux/errno.h>#include <linux/compiler.h>#include <asm/ptrace.h>#include <asm/processor.h>extern void timer_interrupt(struct pt_regs *);#ifdef CONFIG_PPC64#include <asm/paca.h>static inline unsigned long local_get_flags(void){	unsigned long flags;	__asm__ __volatile__("lbz %0,%1(13)"	: "=r" (flags)	: "i" (offsetof(struct paca_struct, soft_enabled)));	return flags;}static inline unsigned long local_irq_disable(void){	unsigned long flags, zero;	__asm__ __volatile__("li %1,0; lbz %0,%2(13); stb %1,%2(13)"	: "=r" (flags), "=&r" (zero)	: "i" (offsetof(struct paca_struct, soft_enabled))	: "memory");	return flags;}extern void local_irq_restore(unsigned long);extern void iseries_handle_interrupts(void);#define local_irq_enable()	local_irq_restore(1)#define local_save_flags(flags)	((flags) = local_get_flags())#define local_irq_save(flags)	((flags) = local_irq_disable())#define irqs_disabled()		(local_get_flags() == 0)#define __hard_irq_enable()	__mtmsrd(mfmsr() | MSR_EE, 1)#define __hard_irq_disable()	__mtmsrd(mfmsr() & ~MSR_EE, 1)#define  hard_irq_disable()			\	do {					\		__hard_irq_disable();		\		get_paca()->soft_enabled = 0;	\		get_paca()->hard_enabled = 0;	\	} while(0)#else#if defined(CONFIG_BOOKE)#define SET_MSR_EE(x)	mtmsr(x)#define local_irq_restore(flags)	__asm__ __volatile__("wrtee %0" : : "r" (flags) : "memory")#else#define SET_MSR_EE(x)	mtmsr(x)#define local_irq_restore(flags)	mtmsr(flags)#endifstatic inline void local_irq_disable(void){#ifdef CONFIG_BOOKE	__asm__ __volatile__("wrteei 0": : :"memory");#else	unsigned long msr;	__asm__ __volatile__("": : :"memory");	msr = mfmsr();	SET_MSR_EE(msr & ~MSR_EE);#endif}static inline void local_irq_enable(void){#ifdef CONFIG_BOOKE	__asm__ __volatile__("wrteei 1": : :"memory");#else	unsigned long msr;	__asm__ __volatile__("": : :"memory");	msr = mfmsr();	SET_MSR_EE(msr | MSR_EE);#endif}static inline void local_irq_save_ptr(unsigned long *flags){	unsigned long msr;	msr = mfmsr();	*flags = msr;#ifdef CONFIG_BOOKE	__asm__ __volatile__("wrteei 0": : :"memory");#else	SET_MSR_EE(msr & ~MSR_EE);#endif	__asm__ __volatile__("": : :"memory");}#define local_save_flags(flags)	((flags) = mfmsr())#define local_irq_save(flags)	local_irq_save_ptr(&flags)#define irqs_disabled()		((mfmsr() & MSR_EE) == 0)#define hard_irq_enable()	local_irq_enable()#define hard_irq_disable()	local_irq_disable()#endif /* CONFIG_PPC64 *//* * interrupt-retrigger: should we handle this via lost interrupts and IPIs * or should we not care like we do now ? --BenH. */struct hw_interrupt_type;#endif	/* __KERNEL__ */#endif	/* _ASM_POWERPC_HW_IRQ_H */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?