hardirq.h

来自「this SRC packet is the headfiles that MI」· C头文件 代码 · 共 105 行

H
105
字号
#ifndef _ASM_IA64_HARDIRQ_H#define _ASM_IA64_HARDIRQ_H/* * Copyright (C) 1998-2001 Hewlett-Packard Co * Copyright (C) 1998-2001 David Mosberger-Tang <davidm@hpl.hp.com> */#include <linux/config.h>#include <linux/threads.h>#include <linux/irq.h>#include <asm/processor.h>/* * No irq_cpustat_t for IA-64.  The data is held in the per-CPU data structure. */#define softirq_pending(cpu)		(cpu_data(cpu)->softirq_pending)#define ksoftirqd_task(cpu)		(cpu_data(cpu)->ksoftirqd)#define irq_count(cpu)			(cpu_data(cpu)->irq_stat.f.irq_count)#define bh_count(cpu)			(cpu_data(cpu)->irq_stat.f.bh_count)#define syscall_count(cpu)		/* unused on IA-64 */#define nmi_count(cpu)			0#define local_softirq_pending()		(local_cpu_data->softirq_pending)#define local_ksoftirqd_task()		(local_cpu_data->ksoftirqd)#define local_irq_count()		(local_cpu_data->irq_stat.f.irq_count)#define local_bh_count()		(local_cpu_data->irq_stat.f.bh_count)#define local_syscall_count()		/* unused on IA-64 */#define local_nmi_count()		0/* * Are we in an interrupt context? Either doing bottom half or hardware interrupt * processing? */#define in_interrupt()			(local_cpu_data->irq_stat.irq_and_bh_counts != 0)#define in_irq()			(local_cpu_data->irq_stat.f.irq_count != 0)#ifndef CONFIG_SMP# define local_hardirq_trylock()	(local_irq_count() == 0)# define local_hardirq_endlock()	do { } while (0)# define local_irq_enter(irq)		(local_irq_count()++)# define local_irq_exit(irq)		(local_irq_count()--)# define synchronize_irq()		barrier()#else#include <asm/atomic.h>#include <asm/smp.h>extern unsigned int global_irq_holder;extern volatile unsigned long global_irq_lock;static inline intirqs_running (void){	int i;	for (i = 0; i < smp_num_cpus; i++)		if (irq_count(i))			return 1;	return 0;}static inline voidrelease_irqlock (int cpu){	/* if we didn't own the irq lock, just ignore.. */	if (global_irq_holder == cpu) {		global_irq_holder = NO_PROC_ID;		clear_bit(0,&global_irq_lock);        }}static inline voidlocal_irq_enter (int irq){	local_irq_count()++;	while (test_bit(0,&global_irq_lock)) {		/* nothing */;	}}static inline voidlocal_irq_exit (int irq){	local_irq_count()--;}static inline intlocal_hardirq_trylock (void){	return !local_irq_count() && !test_bit(0,&global_irq_lock);}#define local_hardirq_endlock()		do { } while (0)extern void synchronize_irq (void);#endif /* CONFIG_SMP */#endif /* _ASM_IA64_HARDIRQ_H */

⌨️ 快捷键说明

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