- Upstream or pending upstream patches from Jan 25587-fix-off-by-one-parsing-error.patch 25616-x86-MCi_CTL-default.patch 25617-vtd-qinval-addr.patch 25688-x86-nr_irqs_gsi.patch - bnc#773393 - VUL-0: CVE-2012-3433: xen: HVM guest destroy p2m teardown host DoS vulnerability CVE-2012-3433-xsa11.patch - bnc#773401 - VUL-1: CVE-2012-3432: xen: HVM guest user mode MMIO emulation DoS 25682-x86-inconsistent-io-state.patch - bnc#762484 - VUL-1: CVE-2012-2625: xen: pv bootloader doesn't check the size of the bzip2 or lzma compressed kernel, leading to denial of service 25589-pygrub-size-limits.patch - Make it build with latest TeXLive 2012 with new package layout OBS-URL: https://build.opensuse.org/package/show/Virtualization/xen?expand=0&rev=196
110 lines
3.6 KiB
Diff
110 lines
3.6 KiB
Diff
# HG changeset patch
|
|
# User Kevin Tian <kevin.tian@intel.com>
|
|
# Date 1314800303 -3600
|
|
# Node ID 42d76c68b2bfbedee3e5f79d32344e14bce48b0f
|
|
# Parent 51983821efa4db4040ae1c5063a4404791597699
|
|
x86: add irq count for IPIs
|
|
|
|
such count is useful to assist decision make in cpuidle governor,
|
|
while w/o this patch only device interrupts through do_IRQ is
|
|
currently counted.
|
|
|
|
Signed-off-by: Kevin Tian <kevin.tian@intel.com>
|
|
|
|
Index: xen-4.1.3-testing/xen/arch/x86/apic.c
|
|
===================================================================
|
|
--- xen-4.1.3-testing.orig/xen/arch/x86/apic.c
|
|
+++ xen-4.1.3-testing/xen/arch/x86/apic.c
|
|
@@ -1378,6 +1378,7 @@ fastcall void smp_apic_timer_interrupt(s
|
|
struct cpu_user_regs *old_regs = set_irq_regs(regs);
|
|
ack_APIC_irq();
|
|
perfc_incr(apic_timer);
|
|
+ this_cpu(irq_count)++;
|
|
raise_softirq(TIMER_SOFTIRQ);
|
|
set_irq_regs(old_regs);
|
|
}
|
|
@@ -1399,6 +1400,7 @@ fastcall void smp_spurious_interrupt(str
|
|
unsigned long v;
|
|
struct cpu_user_regs *old_regs = set_irq_regs(regs);
|
|
|
|
+ this_cpu(irq_count)++;
|
|
irq_enter();
|
|
|
|
/*
|
|
@@ -1434,6 +1436,7 @@ fastcall void smp_error_interrupt(struct
|
|
unsigned long v, v1;
|
|
struct cpu_user_regs *old_regs = set_irq_regs(regs);
|
|
|
|
+ this_cpu(irq_count)++;
|
|
irq_enter();
|
|
/* First tickle the hardware, only then report what went on. -- REW */
|
|
v = apic_read(APIC_ESR);
|
|
@@ -1465,6 +1468,7 @@ fastcall void smp_pmu_apic_interrupt(str
|
|
{
|
|
struct cpu_user_regs *old_regs = set_irq_regs(regs);
|
|
ack_APIC_irq();
|
|
+ this_cpu(irq_count)++;
|
|
hvm_do_pmu_interrupt(regs);
|
|
set_irq_regs(old_regs);
|
|
}
|
|
Index: xen-4.1.3-testing/xen/arch/x86/cpu/mcheck/mce_intel.c
|
|
===================================================================
|
|
--- xen-4.1.3-testing.orig/xen/arch/x86/cpu/mcheck/mce_intel.c
|
|
+++ xen-4.1.3-testing/xen/arch/x86/cpu/mcheck/mce_intel.c
|
|
@@ -66,6 +66,7 @@ static void (*vendor_thermal_interrupt)(
|
|
fastcall void smp_thermal_interrupt(struct cpu_user_regs *regs)
|
|
{
|
|
struct cpu_user_regs *old_regs = set_irq_regs(regs);
|
|
+ this_cpu(irq_count)++;
|
|
irq_enter();
|
|
vendor_thermal_interrupt(regs);
|
|
irq_exit();
|
|
@@ -1094,6 +1095,7 @@ fastcall void smp_cmci_interrupt(struct
|
|
struct cpu_user_regs *old_regs = set_irq_regs(regs);
|
|
|
|
ack_APIC_irq();
|
|
+ this_cpu(irq_count)++;
|
|
irq_enter();
|
|
|
|
mctc = mcheck_mca_logout(
|
|
Index: xen-4.1.3-testing/xen/arch/x86/io_apic.c
|
|
===================================================================
|
|
--- xen-4.1.3-testing.orig/xen/arch/x86/io_apic.c
|
|
+++ xen-4.1.3-testing/xen/arch/x86/io_apic.c
|
|
@@ -516,6 +516,7 @@ fastcall void smp_irq_move_cleanup_inter
|
|
struct cpu_user_regs *old_regs = set_irq_regs(regs);
|
|
|
|
ack_APIC_irq();
|
|
+ this_cpu(irq_count)++;
|
|
irq_enter();
|
|
|
|
me = smp_processor_id();
|
|
Index: xen-4.1.3-testing/xen/arch/x86/smp.c
|
|
===================================================================
|
|
--- xen-4.1.3-testing.orig/xen/arch/x86/smp.c
|
|
+++ xen-4.1.3-testing/xen/arch/x86/smp.c
|
|
@@ -222,6 +222,7 @@ fastcall void smp_invalidate_interrupt(v
|
|
{
|
|
ack_APIC_irq();
|
|
perfc_incr(ipis);
|
|
+ this_cpu(irq_count)++;
|
|
irq_enter();
|
|
if ( !__sync_local_execstate() ||
|
|
(flush_flags & (FLUSH_TLB_GLOBAL | FLUSH_CACHE)) )
|
|
@@ -387,6 +388,7 @@ fastcall void smp_event_check_interrupt(
|
|
struct cpu_user_regs *old_regs = set_irq_regs(regs);
|
|
ack_APIC_irq();
|
|
perfc_incr(ipis);
|
|
+ this_cpu(irq_count)++;
|
|
set_irq_regs(old_regs);
|
|
}
|
|
|
|
@@ -423,6 +425,7 @@ fastcall void smp_call_function_interrup
|
|
|
|
ack_APIC_irq();
|
|
perfc_incr(ipis);
|
|
+ this_cpu(irq_count)++;
|
|
__smp_call_function_interrupt();
|
|
set_irq_regs(old_regs);
|
|
}
|