From: Ingo Molnar Date: Fri, 23 Jan 2009 09:20:15 +0000 (+0100) Subject: Merge branch 'core/percpu' into perfcounters/core X-Git-Url: http://drtracing.org/?a=commitdiff_plain;h=bfe2a3c3b5bf479788d5d5c5561346be6b169043;p=deliverable%2Flinux.git Merge branch 'core/percpu' into perfcounters/core Conflicts: arch/x86/include/asm/hardirq_32.h arch/x86/include/asm/hardirq_64.h Semantic merge: arch/x86/include/asm/hardirq.h [ added apic_perf_irqs field. ] Signed-off-by: Ingo Molnar --- bfe2a3c3b5bf479788d5d5c5561346be6b169043 diff --cc arch/x86/include/asm/hardirq.h index 000787df66e6,176f058e7159..46ebed797e4f --- a/arch/x86/include/asm/hardirq.h +++ b/arch/x86/include/asm/hardirq.h @@@ -1,8 -1,47 +1,48 @@@ - #ifdef CONFIG_X86_32 - # include "hardirq_32.h" - #else - # include "hardirq_64.h" + #ifndef _ASM_X86_HARDIRQ_H + #define _ASM_X86_HARDIRQ_H + + #include + #include + + typedef struct { + unsigned int __softirq_pending; + unsigned int __nmi_count; /* arch dependent */ + unsigned int irq0_irqs; + #ifdef CONFIG_X86_LOCAL_APIC + unsigned int apic_timer_irqs; /* arch dependent */ + unsigned int irq_spurious_count; + #endif ++ unsigned int apic_perf_irqs; + #ifdef CONFIG_SMP + unsigned int irq_resched_count; + unsigned int irq_call_count; + unsigned int irq_tlb_count; + #endif + #ifdef CONFIG_X86_MCE + unsigned int irq_thermal_count; + # ifdef CONFIG_X86_64 + unsigned int irq_threshold_count; + # endif #endif + } ____cacheline_aligned irq_cpustat_t; + + DECLARE_PER_CPU(irq_cpustat_t, irq_stat); + + /* We can have at most NR_VECTORS irqs routed to a cpu at a time */ + #define MAX_HARDIRQS_PER_CPU NR_VECTORS + + #define __ARCH_IRQ_STAT + + #define inc_irq_stat(member) percpu_add(irq_stat.member, 1) + + #define local_softirq_pending() percpu_read(irq_stat.__softirq_pending) + + #define __ARCH_SET_SOFTIRQ_PENDING + + #define set_softirq_pending(x) percpu_write(irq_stat.__softirq_pending, (x)) + #define or_softirq_pending(x) percpu_or(irq_stat.__softirq_pending, (x)) + + extern void ack_bad_irq(unsigned int irq); extern u64 arch_irq_stat_cpu(unsigned int cpu); #define arch_irq_stat_cpu arch_irq_stat_cpu