Re: [libvirt] [RFC] Support for CPUID masking

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

 



Dor Laor wrote:
> What about another approach for the cpuid issue:
> I think that dealing with specific flags is pretty error prone on all
> levels - virt-mgr, libvirt, qemu, migration, and even the guest.

..and performance verification, QA, and the average end user.
Unless we reduce all possible combinations of knob settings
into a few well thought out lumped models the complexity can
be overwhelming.  It is probably a reasonable compromise to
initially support the most obvious use cases with more
fringe models added on an as-needed, as-justified basis.
  
> We can't just 'invent' new cpu modules that will be a combination of
> flags we have on the host. It might work for some kernels/apps but it
> might break others. In addition to cpuid we have the stepping and more
> MSRs that needed to be hidden/exposed.

In whatever abstraction, exposing all of that low-level detail
as the sole configuration means will needlessly exaggerate the
complexity as above.

> The offer:
> Libvirt, virt-mgr, qemu will not deal with lowlevel bits of the cpuid.
> We'll use predefined cpu modules to be emulated.
> These predefined modules will represent a real module that was once
> shipped by Intel/AMD.
> 
> We'll write an additional tool, not under libvirt, that will be able to
> calculate all the virtual cpus that can run over the physical cpu. This
> tool will be the one messing with /proc/cpuinfo, etc.
> 
> Example (theoretical): Physical cpu is "Intel(R) Core(TM)2 Duo CPU
> T9600  @ 2.80GHz" the output of the tool will be:
> shell>computeVirtCpuCapabilities
> core2duo
> core solo
> 486
> pentium3
> ..
> 
> Libvirt will only expose the real physical cpu and all of the outputs
> above. Higher level mgmt will compute the best -cpu to pick for the VM,
> and it will take account the user needs for performance or for migration
> flexibility.
> 
> 
> The cons:
>  - Simple for all levels
>  - Fast implementation
>  - Accurate representative of real cpus
> 
> The pros:
>  - none - we should write the tool anyway
>  - Maybe we hide some of the possibilities, but as said above, it is
>    safer and friendlier.

I think paving over the complexity to export the most common
use cases is a reasonable approach.  We can allow some sort
of fingers-in-the-gears mode for experimentation and tuning
as needed.  But supporting features such as safe migration
could be a non-goal in these scenarios.

-john


>    I also recommend of adding a field to be added next to the cpu for
>    flexibility and possible future changes + dealing with problematic
>    bios with NX bit disabled.
> 
> Regards,
> Dor
> 
>>
>> Thanks
>>
>> Mukesh
>>
>> On Thu, Sep 3, 2009 at 3:09 PM, Daniel P.
>> Berrange<berrange@xxxxxxxxxx>  wrote:
>>> On Thu, Sep 03, 2009 at 11:19:47AM +0300, Dor Laor wrote:
>>>> On 09/02/2009 07:09 PM, Daniel P. Berrange wrote:
>>>>> On Wed, Sep 02, 2009 at 11:59:39AM -0400, Jim Paris wrote:
>>>>>> Jiri Denemark wrote:
>>>>>>> Hi,
>>>>>>>
>>>>>>> We need to provide support for CPU ID masking. Xen and VMware ESX
>>>>>>> are
>>>>>>> examples
>>>>>>> of current hypervisors which support such masking.
>>>>>>>
>>>>>>> My proposal is to define new 'cpuid' feature advertised in guest
>>>>>>> capabilities:
>>>>>> ...
>>>>>>> <domain type='xen' id='42'>
>>>>>>>      ...
>>>>>>>      <features>
>>>>>>>          <pae/>
>>>>>>>          <acpi/>
>>>>>>>          <apic/>
>>>>>>>          <cpuid>
>>>>>>>              <mask level='1' register='ebx'>
>>>>>>>                  xxxx:xxxx:0000:1010:xxxx:xxxx:xxxx:xxxx
>>>>>>>              </mask>
>>>>>> ...
>>>>>>> What are your opinions about this?
>>>>>>
>>>>>> I think it's too low-level, and the structure is x86-specific.  QEMU
>>>>>> and KVM compute their CPUID response based on arguments to the -cpu
>>>>>> argument, e.g.:
>>>>>>
>>>>>>     -cpu core2duo,model=23,+ssse3,+lahf_lm
>>>>>>
>>>>>> I think a similar structure makes more sense for libvirt, where the
>>>>>> configuration generally avoids big blocks of binary data, and the
>>>>>> XML format should suit other architectures as well.
>>>>>
>>>>> I'm going back&    forth on this too. We essentially have 3 options
>>>>>
>>>>>   - Named CPU + flags/features
>>>>>   - CPUID masks
>>>>>   - Allow either
>>>>>
>>>>>
>>>>> If we do either of the first two, we have to translate between the
>>>>> two formats for one or more of the hypervisors. For the last one we
>>>>> are just punting the problem off to applications.
>>>>>
>>>>>
>>>>> If we choose CPUID, and made QEMU driver convert to named CPU + flags
>>>>> we'd be stuck for non-x86 as you say.
>>>>
>>>> Why is that? cpu model + flags may apply for other arch too.
>>>
>>> If we have CPUID in the XML, there is no meaningful CPUID register
>>> representation for sparc/ppc/arm/etc. It is an x86 concept, which
>>> is almost certainly why QEMU uses named CPU models + named flags
>>> instead of CPUID as is public facing config.
>>>
>>> Xen/VMWare of course don't have this limitation since they only
>>> really care about x86.
>>>
>>> So really QEMU's  CPU model + flags approach is more generic albeit
>>> being much more verbose to achieve the same level of expressivity.
>>>
>>>>> If we chose named CPU + flags,  and made VMWare/Xen convert to raw
>>>>> CPUID we'd potentially loose information if user had defined a config
>>>>> with a raw CPUID mask outside context of libvirt.
>>>>>
>>>>> The other thing to remember is that CPUID also encodes sockets/cores/
>>>>> threads  topology data, and it'd be very desirable to expose that in
>>>>> a sensible fashion (ie not a bitmask).
>>>>>
>>>>> On balance i'm currently leaning to named CPU + flags + expliciti
>>>>> topology data because although its harder to implement for Xen/VMWare
>>>>> I think its much nicer to applications&    users. We might loose a
>>>>> tiny
>>>>> bit of data in the CPU ->    named/flags conversion for Xen/VMWare but
>>>>> I reckon we can get it good enough that most people won't really care
>>>>> about that.
>>>>>
>>>>> Daniel
>>>>
>>>> There are 2 more issues to consider:
>>>> 1. The VMW approach with all the cpuid bits might be ok, the problem is
>>>>     to map it into qemu model, will libvirt to that?
>>>
>>> THe problem is that CPUID is not viable for non-x86 archs so can't
>>> really be used as our master representation
>>>
>>>> 2. If we use the qemu approach, the host information (cpuids) need to
>>>>     travel to higher mgmt level in order to allow computation of
>>>>     greatest common denominator.
>>>
>>> Yes, whatever we decide for exposing guest CPU model/flags/etc should
>>> be equally applied to the libvirt capabilities XML so that apps can
>>> query physical host data
>>>
>>> Regards,
>>> Daniel
>>> -- 
>>> |: Red Hat, Engineering, London   -o-  
>>> http://people.redhat.com/berrange/ :|
>>> |: http://libvirt.org  -o-  http://virt-manager.org  -o- 
>>> http://ovirt.org :|
>>> |: http://autobuild.org       -o-        
>>> http://search.cpan.org/~danberr/ :|
>>> |: GnuPG: 7D3B9505  -o-  F3C9 553F A1DA 4AC2 5648 23C1 B3DF F742 7D3B
>>> 9505 :|
>>>
>>> -- 
>>> Libvir-list mailing list
>>> Libvir-list@xxxxxxxxxx
>>> https://www.redhat.com/mailman/listinfo/libvir-list
>>>
> 


-- 
john.cooper@xxxxxxxxxx

--
Libvir-list mailing list
Libvir-list@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/libvir-list

[Index of Archives]     [Virt Tools]     [Libvirt Users]     [Lib OS Info]     [Fedora Users]     [Fedora Desktop]     [Fedora SELinux]     [Big List of Linux Books]     [Yosemite News]     [KDE Users]     [Fedora Tools]