+ x86-expand-proc-interrupts-to-include-missing-vectors.patch added to -mm tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The patch titled
     x86: expand /proc/interrupts to include missing vectors: v4
has been added to the -mm tree.  Its filename is
     x86-expand-proc-interrupts-to-include-missing-vectors.patch

*** Remember to use Documentation/SubmitChecklist when testing your code ***

See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find
out what to do about this

------------------------------------------------------
Subject: x86: expand /proc/interrupts to include missing vectors: v4
From: Joe Korty <joe.korty@xxxxxxxx>

    s/irq_spur_counts/irq_spurious_counts/g (Andrew Morton)
    tweaked documentation (Andi Kleen)
    moved increments before irq_exit as appropriate (Andi Kleen)
    whitespace cleanup (Andi Kleen)

Signed-off-by: Joe Korty <joe.korty@xxxxxxxx>
Cc: Andi Kleen <ak@xxxxxxx>
Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx>
---

 Documentation/filesystems/proc.txt   |   13 ++++++++-----
 arch/i386/kernel/apic.c              |    2 +-
 arch/i386/kernel/cpu/mcheck/p4.c     |    2 +-
 arch/i386/kernel/irq.c               |    2 +-
 arch/i386/kernel/smp.c               |    2 +-
 arch/i386/mach-voyager/voyager_smp.c |    2 +-
 arch/i386/xen/smp.c                  |    2 +-
 arch/x86_64/kernel/apic.c            |    3 +--
 arch/x86_64/kernel/irq.c             |    2 +-
 arch/x86_64/kernel/mce_amd.c         |    2 +-
 arch/x86_64/kernel/mce_intel.c       |    2 +-
 arch/x86_64/kernel/smp.c             |    2 +-
 include/asm-i386/hardirq.h           |    2 +-
 include/asm-x86_64/pda.h             |    2 +-
 14 files changed, 21 insertions(+), 19 deletions(-)

diff -puN Documentation/filesystems/proc.txt~x86-expand-proc-interrupts-to-include-missing-vectors Documentation/filesystems/proc.txt
--- a/Documentation/filesystems/proc.txt~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/Documentation/filesystems/proc.txt
@@ -351,11 +351,14 @@ In 2.6.2* /proc/interrupts was expanded 
 /proc/interrupts to display every IRQ vector in use by the system, not
 just those considered 'most important'.  The new vectors are:
 
-  THR -- a threshold interrupt occurs when ECC memory correction is
-  occuring at too high a frequency.  Threshold interrupt machinery is
-  often put into the ECC logic, as occasional ECC memory failures are
-  part of normal memory operation, but sequences of ECC failures over
-  some short interval usually indicate a memory chip that is about to fail.
+  THR -- a threshold interrupt occurs when ECC memory correction is occuring
+  at too high a frequency.  Threshold interrupt machinery is often put
+  into the ECC logic, as occasional ECC memory corrections are part of
+  normal operation (due to random alpha particles), but sequences of
+  ECC corrections or outright failures over some short interval usually
+  indicate a memory chip that is about to fail.  Note that not every
+  platform has ECC threshold logic, and those that do generally require
+  it to be explicitly turned on.
 
   TRM -- a thermal event interrupt occurs when a temperature threshold
   has been exceeded for some CPU chip.  This interrupt may also be generated
diff -puN arch/i386/kernel/apic.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/i386/kernel/apic.c
--- a/arch/i386/kernel/apic.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/i386/kernel/apic.c
@@ -1279,8 +1279,8 @@ void smp_spurious_interrupt(struct pt_re
 	/* see sw-dev-man vol 3, chapter 7.4.13.5 */
 	printk(KERN_INFO "spurious APIC interrupt on CPU#%d, "
 	       "should never happen.\n", smp_processor_id());
+	__get_cpu_var(irq_stat).irq_spurious_counts++;
 	irq_exit();
-	__get_cpu_var(irq_stat).irq_spur_counts++;
 }
 
 /*
diff -puN arch/i386/kernel/cpu/mcheck/p4.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/i386/kernel/cpu/mcheck/p4.c
--- a/arch/i386/kernel/cpu/mcheck/p4.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/i386/kernel/cpu/mcheck/p4.c
@@ -61,8 +61,8 @@ fastcall void smp_thermal_interrupt(stru
 {
 	irq_enter();
 	vendor_thermal_interrupt(regs);
-	irq_exit();
 	__get_cpu_var(irq_stat).irq_thermal_counts++;
+	irq_exit();
 }
 
 /* P4/Xeon Thermal regulation detect and init */
diff -puN arch/i386/kernel/irq.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/i386/kernel/irq.c
--- a/arch/i386/kernel/irq.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/i386/kernel/irq.c
@@ -317,7 +317,7 @@ skip:
 		seq_printf(p, "SPU: ");
 		for_each_online_cpu(j)
 			seq_printf(p, "%10u ",
-				per_cpu(irq_stat,j).irq_spur_counts);
+				per_cpu(irq_stat,j).irq_spurious_counts);
 		seq_printf(p, "  Spurious interrupts\n");
 		seq_printf(p, "ERR: %10u\n", atomic_read(&irq_err_count));
 #if defined(CONFIG_X86_IO_APIC)
diff -puN arch/i386/kernel/smp.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/i386/kernel/smp.c
--- a/arch/i386/kernel/smp.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/i386/kernel/smp.c
@@ -662,13 +662,13 @@ fastcall void smp_call_function_interrup
 	 */
 	irq_enter();
 	(*func)(info);
+	__get_cpu_var(irq_stat).irq_call_counts++;
 	irq_exit();
 
 	if (wait) {
 		mb();
 		atomic_inc(&call_data->finished);
 	}
-	__get_cpu_var(irq_stat).irq_call_counts++;
 }
 
 static int convert_apicid_to_cpu(int apic_id)
diff -puN arch/i386/mach-voyager/voyager_smp.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/i386/mach-voyager/voyager_smp.c
--- a/arch/i386/mach-voyager/voyager_smp.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/i386/mach-voyager/voyager_smp.c
@@ -1037,12 +1037,12 @@ smp_call_function_interrupt(void)
 	 */
 	irq_enter();
 	(*func)(info);
+	__get_cpu_var(irq_stat).irq_call_counts++;
 	irq_exit();
 	if (wait) {
 		mb();
 		clear_bit(cpu, &call_data->finished);
 	}
-	__get_cpu_var(irq_stat).irq_call_counts++;
 }
 
 static int
diff -puN arch/i386/xen/smp.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/i386/xen/smp.c
--- a/arch/i386/xen/smp.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/i386/xen/smp.c
@@ -346,13 +346,13 @@ static irqreturn_t xen_call_function_int
 	 */
 	irq_enter();
 	(*func)(info);
+	__get_cpu_var(irq_stat).irq_call_counts++;
 	irq_exit();
 
 	if (wait) {
 		mb();		/* commit everything before setting finished */
 		atomic_inc(&call_data->finished);
 	}
-	__get_cpu_var(irq_stat).irq_call_counts++;
 
 	return IRQ_HANDLED;
 }
diff -puN arch/x86_64/kernel/apic.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/x86_64/kernel/apic.c
--- a/arch/x86_64/kernel/apic.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/x86_64/kernel/apic.c
@@ -1141,7 +1141,6 @@ __cpuinit int apic_is_clustered_box(void
 asmlinkage void smp_spurious_interrupt(void)
 {
 	unsigned int v;
-
 	exit_idle();
 	irq_enter();
 	/*
@@ -1153,8 +1152,8 @@ asmlinkage void smp_spurious_interrupt(v
 	if (v & (1 << (SPURIOUS_APIC_VECTOR & 0x1f)))
 		ack_APIC_irq();
 
+	add_pda(irq_spurious_counts, 1);
 	irq_exit();
-	add_pda(irq_spur_counts, 1);
 }
 
 /*
diff -puN arch/x86_64/kernel/irq.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/x86_64/kernel/irq.c
--- a/arch/x86_64/kernel/irq.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/x86_64/kernel/irq.c
@@ -117,7 +117,7 @@ skip:
 		seq_printf(p, "  Threshold APIC interrupts\n");
 		seq_printf(p, "SPU: ");
 		for_each_online_cpu(j)
-			seq_printf(p, "%10u ", cpu_pda(j)->irq_spur_counts);
+			seq_printf(p, "%10u ", cpu_pda(j)->irq_spurious_counts);
 		seq_printf(p, "  Spurious interrupts\n");
 		seq_printf(p, "ERR: %10u\n", atomic_read(&irq_err_count));
 	}
diff -puN arch/x86_64/kernel/mce_amd.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/x86_64/kernel/mce_amd.c
--- a/arch/x86_64/kernel/mce_amd.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/x86_64/kernel/mce_amd.c
@@ -237,8 +237,8 @@ asmlinkage void mce_threshold_interrupt(
 		}
 	}
 out:
-	irq_exit();
 	add_pda(irq_threshold_counts, 1);
+	irq_exit();
 }
 
 /*
diff -puN arch/x86_64/kernel/mce_intel.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/x86_64/kernel/mce_intel.c
--- a/arch/x86_64/kernel/mce_intel.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/x86_64/kernel/mce_intel.c
@@ -26,8 +26,8 @@ asmlinkage void smp_thermal_interrupt(vo
 	if (therm_throt_process(msr_val & 1))
 		mce_log_therm_throt_event(smp_processor_id(), msr_val);
 
-	irq_exit();
 	add_pda(irq_thermal_counts, 1);
+	irq_exit();
 }
 
 static void __cpuinit intel_init_thermal(struct cpuinfo_x86 *c)
diff -puN arch/x86_64/kernel/smp.c~x86-expand-proc-interrupts-to-include-missing-vectors arch/x86_64/kernel/smp.c
--- a/arch/x86_64/kernel/smp.c~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/arch/x86_64/kernel/smp.c
@@ -516,11 +516,11 @@ asmlinkage void smp_call_function_interr
 	exit_idle();
 	irq_enter();
 	(*func)(info);
+	add_pda(irq_call_counts, 1);
 	irq_exit();
 	if (wait) {
 		mb();
 		atomic_inc(&call_data->finished);
 	}
-	add_pda(irq_call_counts, 1);
 }
 
diff -puN include/asm-i386/hardirq.h~x86-expand-proc-interrupts-to-include-missing-vectors include/asm-i386/hardirq.h
--- a/include/asm-i386/hardirq.h~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/include/asm-i386/hardirq.h
@@ -13,7 +13,7 @@ typedef struct {
 	unsigned int irq_call_counts;
 	unsigned int irq_tlb_counts;
 	unsigned int irq_thermal_counts;
-	unsigned int irq_spur_counts;
+	unsigned int irq_spurious_counts;
 } ____cacheline_aligned irq_cpustat_t;
 
 DECLARE_PER_CPU(irq_cpustat_t, irq_stat);
diff -puN include/asm-x86_64/pda.h~x86-expand-proc-interrupts-to-include-missing-vectors include/asm-x86_64/pda.h
--- a/include/asm-x86_64/pda.h~x86-expand-proc-interrupts-to-include-missing-vectors
+++ a/include/asm-x86_64/pda.h
@@ -34,7 +34,7 @@ struct x8664_pda {
 	unsigned irq_tlb_counts;
 	unsigned irq_thermal_counts;
 	unsigned irq_threshold_counts;
-	unsigned irq_spur_counts;
+	unsigned irq_spurious_counts;
 } ____cacheline_aligned_in_smp;
 
 extern struct x8664_pda *_cpu_pda[];
_

Patches currently in -mm which might be from joe.korty@xxxxxxxx are

x86-expand-proc-interrupts-to-include-missing-vectors-v2.patch
expand-proc-interrupts-to-include-missing-vectors-v3.patch
x86-expand-proc-interrupts-to-include-missing-vectors.patch
x86-expand-proc-interrupts-to-include-missing-vectors-v2-fix.patch

-
To unsubscribe from this list: send the line "unsubscribe mm-commits" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Kernel Newbies FAQ]     [Kernel Archive]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Photo]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]

  Powered by Linux