lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [day] [month] [year] [list]
Message-ID: <6d217be011dd04c86ba9c3e2178b5efb@eikelenboom.it>
Date:	Mon, 14 Dec 2015 22:07:30 +0100
From:	Sander Eikelenboom <linux@...elenboom.it>
To:	Eric Shelton <eshelton@...ox.com>
Cc:	David Vrabel <david.vrabel@...rix.com>,
	Boris Ostrovsky <boris.ostrovsky@...cle.com>,
	linux-kernel@...r.kernel.org, xen-devel@...ts.xen.org,
	knockknock@...il.com
Subject: Re: [Xen-devel] linux 4.4 Regression: 100% cpu usage on idle pv
 guest under Xen with single vcpu

On 2015-12-14 20:48, Eric Shelton wrote:
> Please note that the same issue appears to have been introduced in the
> recent 4.2.7 kernel.  It perhaps has to do
> with b4ff8389ed14b849354b59ce9b360bdefcdbf99c having a matching
> commit e8d097151d309eb71f750bbf34e6a7ef6256da7e in linux-stable.git.  
> The
> below patch to arch/x86/kernel/rtc.c was also effective for 4.2.7.
> 
> Eric

Hi Eric,

Yeah it's unfortunate the patch patching the other patches destined for 
stable didn't make it in time for stable :(.
Any how the chosen solution wasn't ideal so there now is a V2 patch by 
Boris. It hasn't been picked up yet,
but hopefully will be anytime soon (for the patch see 
http://lkml.iu.edu/hypermail/linux/kernel/1512.1/03504.html)

--
Sander

> On 2015-12-02 18:30, Sander Eikelenboom wrote:
>> On 2015-12-02 15:55, David Vrabel wrote:
>> > On 28/11/15 15:47, Sander Eikelenboom wrote:
>> >> genirq: Flags mismatch irq 8. 00000000 (hvc_console) vs. 00000000
>> >> (rtc0)
>> >
>> > We shouldn't register an rtc_cmos device because its legacy irq
>> > conflicts with the irq needed for hvc0.  For a multi VCPU guest irq 8
>> > is
>> > in use for the pv spinlocks and this gets requested first, preventing
>> > the rtc device from probing.
>> >
>> > Does this patch fix it for you?
>> >
>> > David
>> 
>> It does, thanks.
>> 
>> Reported-and-tested-by: Sander Eikelenboom <linux@...elenboom.it>
>> 
>> --
>> Sander
>> 
>> > 8<--------------------
>> > x86: rtc_cmos platform device requires legacy irqs
>> >
>> > Adding the rtc platform device when there are no legacy irqs (no
>> > legacy PIC) causes a conflict with other devices that end up using the
>> > same irq number.
>> >
>> > In a single VCPU PV guest we should have:
>> >
>> > /proc/interrupts:
>> >            CPU0
>> >   0:       4934  xen-percpu-virq      timer0
>> >   1:          0  xen-percpu-ipi       spinlock0
>> >   2:          0  xen-percpu-ipi       resched0
>> >   3:          0  xen-percpu-ipi       callfunc0
>> >   4:          0  xen-percpu-virq      debug0
>> >   5:          0  xen-percpu-ipi       callfuncsingle0
>> >   6:          0  xen-percpu-ipi       irqwork0
>> >   7:        321   xen-dyn-event     xenbus
>> >   8:         90   xen-dyn-event     hvc_console
>> >   ...
>> >
>> > But hvc_console cannot get its interrupt because it is already in use
>> > by rtc0 and the console does not work.
>> >
>> >   genirq: Flags mismatch irq 8. 00000000 (hvc_console) vs. 00000000
>> > (rtc0)
>> >
>> > The rtc_cmos device requires a particular legacy irq so don't add it
>> > if there are no legacy irqs.
>> >
>> > Signed-off-by: David Vrabel <david.vrabel@...rix.com>
>> > ---
>> >  arch/x86/kernel/rtc.c | 5 +++++
>> >  1 file changed, 5 insertions(+)
>> >
>> > diff --git a/arch/x86/kernel/rtc.c b/arch/x86/kernel/rtc.c
>> > index cd96852..07c70f1 100644
>> > --- a/arch/x86/kernel/rtc.c
>> > +++ b/arch/x86/kernel/rtc.c
>> > @@ -14,6 +14,7 @@
>> >  #include <asm/time.h>
>> >  #include <asm/intel-mid.h>
>> >  #include <asm/rtc.h>
>> > +#include <asm/i8259.h>
>> >
>> >  #ifdef CONFIG_X86_32
>> >  /*
>> > @@ -200,6 +201,10 @@ static __init int add_rtc_cmos(void)
>> >       }
>> >  #endif
>> >
>> > +     /* RTC uses legacy IRQs. */
>> > +     if (!nr_legacy_irqs())
>> > +             return -ENODEV;
>> > +
>> >       platform_device_register(&rtc_device);
>> >       dev_info(&rtc_device.dev,
>> >                "registered platform RTC device (no PNP device
> found)\n");
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ