[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <4B1BE136.4090005@redhat.com>
Date: Sun, 06 Dec 2009 18:52:06 +0200
From: Avi Kivity <avi@...hat.com>
To: bifferos <bifferos@...oo.co.uk>
CC: linux-kernel@...r.kernel.org
Subject: Re: Kexec failure on RDC (and possibly other early x86) platforms
On 12/06/2009 01:33 PM, bifferos wrote:
> I've updated the patch to allow Kexec to work on RDC platforms
> here:
> http://bifferboard.svn.sourceforge.net/viewvc/bifferboard/slack/kernel/2.6.32/0003-kexec-fix.patch
>
> I'm curious as to how one can detect the presence of the CR4
> register in assembler, as I'm sure it's possible, but I've just
> #ifndefed out the offending instruction in this patch and it
> seems to work with this change.
>
One way is to execute the instruction and trap the #UD exception if it
is not supported. Not sure whether you have an IDT set up or whether
your cpu traps on mov cr4.
If your cpu supports cpuid you can test for features that indicate bits
in cr4 are available, for example VME, DE, PSE, PVI, and PAE. If none
are available you likely don't have cr4 (and even if you do, it's
pointless to reset it).
--
error compiling committee.c: too many arguments to function
--
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