|   xen-devel
[Xen-devel] Re: [RFC] Hypercalls from HVM guests 
| 
On 8 Apr 2006, at 15:12, Andi Kleen wrote:
 
This sounds encouraging, but is CPUID always trapped by the HVM code?
 
It can be, and in practise yes it is so this could work.
 
CPUID doesn't have any advantage over MSRs for this purpose because
for custom CPUIDs like 0xb... you can't use the normal "max count" 
mechanism 
of determining if a CPUID is supported.  All that would work is to try
it and handle the GPF if it didn't work. That would give the same ugly
implementation as with MSRs.
 
CPUID never faults. Well, unless the processor doesn't support the 
instruction, but you find that out from EFLAGS. 
 Using the MSR would have the advantage of it being trappable in a para 
virtual
kernel too.
 
I would definitely prefer to use MSRs for gathering hypervisor 
signature and other information, but because of the possible hassle of 
catching faults I'd also support a signature return (and maybe 
identifying some hypervisor features) via a special CPUID index. The 
index could be greater than the normal "max count" and you'd determine 
if the index(es) were supported by checking for a well-known signature 
in EAX,EBX,ECX,EDX for the first of the hypervisor indexes. Running on 
native hardware would not fault and you'd expect it to be vastly 
unlikely that the final values of EAX thru EDX would  coincidentally 
match a 128-bit signature. 
(Cue attempts to think up a 16-character signature string. :-)
 -- Keir
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel
 | 
 |  |