Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
/*
|
|
|
|
* cpu.c: internal functions for CPU manipulation
|
|
|
|
*
|
2013-09-23 11:45:59 +02:00
|
|
|
* Copyright (C) 2009-2013 Red Hat, Inc.
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2012-09-20 16:30:55 -06:00
|
|
|
* License along with this library. If not, see
|
2012-07-21 18:06:23 +08:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
2012-12-12 17:59:27 +00:00
|
|
|
#include "virlog.h"
|
2012-12-12 18:06:53 +00:00
|
|
|
#include "viralloc.h"
|
2012-12-13 18:13:21 +00:00
|
|
|
#include "virxml.h"
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
#include "cpu.h"
|
2013-09-23 11:45:59 +02:00
|
|
|
#include "cpu_map.h"
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
#include "cpu_x86.h"
|
2015-07-20 14:17:52 +02:00
|
|
|
#include "cpu_ppc64.h"
|
2012-06-22 13:50:11 +02:00
|
|
|
#include "cpu_s390.h"
|
2012-07-12 10:28:17 -05:00
|
|
|
#include "cpu_arm.h"
|
2017-03-07 10:40:15 +01:00
|
|
|
#include "capabilities.h"
|
2017-03-11 17:09:48 +01:00
|
|
|
#include "virstring.h"
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
|
|
|
|
|
|
|
|
#define VIR_FROM_THIS VIR_FROM_CPU
|
|
|
|
|
2014-02-28 12:16:17 +00:00
|
|
|
VIR_LOG_INIT("cpu.cpu");
|
|
|
|
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
static struct cpuArchDriver *drivers[] = {
|
|
|
|
&cpuDriverX86,
|
2015-07-20 14:35:22 +02:00
|
|
|
&cpuDriverPPC64,
|
2012-06-22 13:50:11 +02:00
|
|
|
&cpuDriverS390,
|
2012-07-12 10:28:17 -05:00
|
|
|
&cpuDriverArm,
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static struct cpuArchDriver *
|
2012-12-11 12:58:54 +00:00
|
|
|
cpuGetSubDriver(virArch arch)
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
{
|
Convert 'int i' to 'size_t i' in src/cpu/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
size_t i;
|
|
|
|
size_t j;
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
|
2012-12-11 12:58:54 +00:00
|
|
|
if (arch == VIR_ARCH_NONE) {
|
2012-07-18 13:16:38 +01:00
|
|
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
|
|
"%s", _("undefined hardware architecture"));
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2019-10-15 13:55:26 +02:00
|
|
|
for (i = 0; i < G_N_ELEMENTS(drivers); i++) {
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
for (j = 0; j < drivers[i]->narch; j++) {
|
2012-12-11 12:58:54 +00:00
|
|
|
if (arch == drivers[i]->arch[j])
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
return drivers[i];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-24 18:42:31 +02:00
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
|
|
|
_("'%s' architecture is not supported by CPU driver"),
|
|
|
|
virArchToString(arch));
|
|
|
|
return NULL;
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-06-29 11:08:30 +02:00
|
|
|
static struct cpuArchDriver *
|
|
|
|
cpuGetSubDriverByName(const char *name)
|
|
|
|
{
|
|
|
|
size_t i;
|
|
|
|
|
2019-10-15 13:55:26 +02:00
|
|
|
for (i = 0; i < G_N_ELEMENTS(drivers); i++) {
|
2015-06-29 11:08:30 +02:00
|
|
|
if (STREQ_NULLABLE(name, drivers[i]->name))
|
|
|
|
return drivers[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
|
|
_("CPU driver '%s' does not exist"),
|
|
|
|
name);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
/**
|
2016-08-09 13:26:53 +02:00
|
|
|
* virCPUCompareXML:
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
2016-08-09 13:26:53 +02:00
|
|
|
* @arch: CPU architecture
|
2014-03-26 15:45:50 +01:00
|
|
|
* @host: host CPU definition
|
|
|
|
* @xml: XML description of either guest or host CPU to be compared with @host
|
2016-09-16 11:45:54 +02:00
|
|
|
* @failIncompatible: return an error instead of VIR_CPU_COMPARE_INCOMPATIBLE
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
|
|
|
* Compares the CPU described by @xml with @host CPU.
|
|
|
|
*
|
|
|
|
* Returns VIR_CPU_COMPARE_ERROR on error, VIR_CPU_COMPARE_INCOMPATIBLE when
|
|
|
|
* the two CPUs are incompatible, VIR_CPU_COMPARE_IDENTICAL when the two CPUs
|
|
|
|
* are identical, VIR_CPU_COMPARE_SUPERSET when the @xml CPU is a superset of
|
2016-09-16 11:45:54 +02:00
|
|
|
* the @host CPU. If @failIncompatible is true, the function will return
|
|
|
|
* VIR_CPU_COMPARE_ERROR (and set VIR_ERR_CPU_INCOMPATIBLE error) when the
|
|
|
|
* two CPUs are incompatible.
|
2014-03-26 15:45:50 +01:00
|
|
|
*/
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
virCPUCompareResult
|
2016-08-09 13:26:53 +02:00
|
|
|
virCPUCompareXML(virArch arch,
|
|
|
|
virCPUDefPtr host,
|
|
|
|
const char *xml,
|
2020-10-07 10:54:55 +02:00
|
|
|
bool failIncompatible,
|
|
|
|
bool validateXML)
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
{
|
2020-09-07 16:58:55 +02:00
|
|
|
g_autoptr(virCPUDef) cpu = NULL;
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
|
2016-08-09 13:26:53 +02:00
|
|
|
VIR_DEBUG("arch=%s, host=%p, xml=%s",
|
|
|
|
virArchToString(arch), host, NULLSTR(xml));
|
|
|
|
|
2020-10-07 10:54:55 +02:00
|
|
|
if (virCPUDefParseXMLString(xml, VIR_CPU_TYPE_AUTO, &cpu, validateXML) < 0)
|
2020-09-07 16:58:55 +02:00
|
|
|
return VIR_CPU_COMPARE_ERROR;
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
|
2020-09-07 16:58:55 +02:00
|
|
|
return virCPUCompare(arch, host, cpu, failIncompatible);
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
/**
|
2016-08-09 13:26:53 +02:00
|
|
|
* virCPUCompare:
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
2016-08-09 13:26:53 +02:00
|
|
|
* @arch: CPU architecture
|
2014-03-26 15:45:50 +01:00
|
|
|
* @host: host CPU definition
|
|
|
|
* @cpu: either guest or host CPU to be compared with @host
|
2016-09-16 11:45:54 +02:00
|
|
|
* @failIncompatible: return an error instead of VIR_CPU_COMPARE_INCOMPATIBLE
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
|
|
|
* Compares the CPU described by @cpu with @host CPU.
|
|
|
|
*
|
|
|
|
* Returns VIR_CPU_COMPARE_ERROR on error, VIR_CPU_COMPARE_INCOMPATIBLE when
|
|
|
|
* the two CPUs are incompatible, VIR_CPU_COMPARE_IDENTICAL when the two CPUs
|
|
|
|
* are identical, VIR_CPU_COMPARE_SUPERSET when the @cpu CPU is a superset of
|
2016-09-16 11:45:54 +02:00
|
|
|
* the @host CPU. If @failIncompatible is true, the function will return
|
|
|
|
* VIR_CPU_COMPARE_ERROR (and set VIR_ERR_CPU_INCOMPATIBLE error) when the
|
|
|
|
* two CPUs are incompatible.
|
2014-03-26 15:45:50 +01:00
|
|
|
*/
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
virCPUCompareResult
|
2016-08-09 13:26:53 +02:00
|
|
|
virCPUCompare(virArch arch,
|
|
|
|
virCPUDefPtr host,
|
|
|
|
virCPUDefPtr cpu,
|
|
|
|
bool failIncompatible)
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
2016-08-09 13:26:53 +02:00
|
|
|
VIR_DEBUG("arch=%s, host=%p, cpu=%p",
|
|
|
|
virArchToString(arch), host, cpu);
|
2010-03-23 10:53:28 +01:00
|
|
|
|
2016-08-09 13:26:53 +02:00
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
return VIR_CPU_COMPARE_ERROR;
|
|
|
|
|
2016-08-09 13:26:53 +02:00
|
|
|
if (!driver->compare) {
|
2012-07-18 13:16:38 +01:00
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
|
|
|
_("cannot compare CPUs of %s architecture"),
|
2016-08-09 13:26:53 +02:00
|
|
|
virArchToString(arch));
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
return VIR_CPU_COMPARE_ERROR;
|
|
|
|
}
|
|
|
|
|
2014-05-28 15:11:57 +02:00
|
|
|
return driver->compare(host, cpu, failIncompatible);
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
/**
|
|
|
|
* cpuDecode:
|
|
|
|
*
|
|
|
|
* @cpu: CPU definition stub to be filled in
|
|
|
|
* @data: internal CPU data to be decoded into @cpu definition
|
|
|
|
* @models: list of CPU models that can be considered when decoding @data
|
|
|
|
*
|
|
|
|
* Decodes internal CPU data into a CPU definition consisting of a CPU model
|
|
|
|
* and a list of CPU features. The @cpu model stub is supposed to have arch,
|
|
|
|
* type, match and fallback members set, this function will add the rest. If
|
|
|
|
* @models list is NULL, all models supported by libvirt will be considered
|
|
|
|
* when decoding the data. In general, this function will select the model
|
2017-09-26 10:24:05 +02:00
|
|
|
* closest to the CPU specified by @data.
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
|
|
|
* For VIR_ARCH_I686 and VIR_ARCH_X86_64 architectures this means the computed
|
|
|
|
* CPU definition will have the shortest possible list of additional features.
|
|
|
|
*
|
|
|
|
* Returns 0 on success, -1 on error.
|
|
|
|
*/
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
int
|
2010-02-10 12:22:36 +00:00
|
|
|
cpuDecode(virCPUDefPtr cpu,
|
maint: avoid 'const fooPtr' in cpu files
'const fooPtr' is the same as 'foo * const' (the pointer won't
change, but it's contents can). But in general, if an interface
is trying to be const-correct, it should be using 'const foo *'
(the pointer is to data that can't be changed).
Fix up offenders in src/cpu.
* src/cpu/cpu.h (cpuArchDecode, cpuArchEncode, cpuArchUpdate)
(cpuArchHasFeature, cpuDecode, cpuEncode, cpuUpdate)
(cpuHasFeature): Use intended type.
* src/conf/cpu_conf.h (virCPUDefCopyModel, virCPUDefCopy):
Likewise.
(virCPUDefParseXML): Drop const.
* src/cpu/cpu.c (cpuDecode, cpuEncode, cpuUpdate, cpuHasFeature):
Fix fallout.
* src/cpu/cpu_x86.c (x86ModelFromCPU, x86ModelSubtractCPU)
(x86DecodeCPUData, x86EncodePolicy, x86Encode, x86UpdateCustom)
(x86UpdateHostModel, x86Update, x86HasFeature): Likewise.
* src/cpu/cpu_s390.c (s390Decode): Likewise.
* src/cpu/cpu_arm.c (ArmDecode): Likewise.
* src/cpu/cpu_powerpc.c (ppcModelFromCPU, ppcCompute, ppcDecode)
(ppcUpdate): Likewise.
* src/conf/cpu_conf.c (virCPUDefCopyModel, virCPUDefCopy)
(virCPUDefParseXML): Likewise.
Signed-off-by: Eric Blake <eblake@redhat.com>
2013-10-05 14:01:02 -06:00
|
|
|
const virCPUData *data,
|
2017-09-26 10:24:05 +02:00
|
|
|
virDomainCapsCPUModelsPtr models)
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
2017-09-26 10:24:05 +02:00
|
|
|
VIR_DEBUG("cpu=%p, data=%p, models=%p", cpu, data, models);
|
2010-03-23 10:53:28 +01:00
|
|
|
if (models) {
|
Convert 'int i' to 'size_t i' in src/cpu/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
size_t i;
|
2017-09-22 15:51:33 +02:00
|
|
|
for (i = 0; i < models->nmodels; i++)
|
|
|
|
VIR_DEBUG("models[%zu]=%s", i, models->models[i].name);
|
2010-02-01 12:42:27 +01:00
|
|
|
}
|
|
|
|
|
2014-03-26 15:59:26 +01:00
|
|
|
if (cpu->type > VIR_CPU_TYPE_GUEST ||
|
|
|
|
cpu->mode != VIR_CPU_MODE_CUSTOM) {
|
|
|
|
virReportError(VIR_ERR_INVALID_ARG, "%s",
|
|
|
|
_("invalid CPU definition stub"));
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2017-02-02 22:04:25 +01:00
|
|
|
if ((driver = cpuGetSubDriver(data->arch)) == NULL)
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (driver->decode == NULL) {
|
2012-07-18 13:16:38 +01:00
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
|
|
|
_("cannot decode CPU data for %s architecture"),
|
2012-12-11 12:58:54 +00:00
|
|
|
virArchToString(cpu->arch));
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2017-09-26 10:24:05 +02:00
|
|
|
return driver->decode(cpu, data, models);
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
/**
|
|
|
|
* cpuEncode:
|
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
|
|
|
* @cpu: CPU definition to be encoded into internal CPU driver representation
|
|
|
|
* @forced: where to store CPU data corresponding to forced features
|
|
|
|
* @required: where to store CPU data corresponding to required features
|
|
|
|
* @optional: where to store CPU data corresponding to optional features
|
|
|
|
* @disabled: where to store CPU data corresponding to disabled features
|
|
|
|
* @forbidden: where to store CPU data corresponding to forbidden features
|
|
|
|
* @vendor: where to store CPU data corresponding to CPU vendor
|
|
|
|
*
|
|
|
|
* Encode CPU definition from @cpu into internal CPU driver representation.
|
|
|
|
* Any of @forced, @required, @optional, @disabled, @forbidden and @vendor
|
|
|
|
* arguments can be NULL in case the caller is not interested in the
|
|
|
|
* corresponding data.
|
|
|
|
*
|
|
|
|
* Returns 0 on success, -1 on error.
|
|
|
|
*/
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
int
|
2012-12-11 12:58:54 +00:00
|
|
|
cpuEncode(virArch arch,
|
maint: avoid 'const fooPtr' in cpu files
'const fooPtr' is the same as 'foo * const' (the pointer won't
change, but it's contents can). But in general, if an interface
is trying to be const-correct, it should be using 'const foo *'
(the pointer is to data that can't be changed).
Fix up offenders in src/cpu.
* src/cpu/cpu.h (cpuArchDecode, cpuArchEncode, cpuArchUpdate)
(cpuArchHasFeature, cpuDecode, cpuEncode, cpuUpdate)
(cpuHasFeature): Use intended type.
* src/conf/cpu_conf.h (virCPUDefCopyModel, virCPUDefCopy):
Likewise.
(virCPUDefParseXML): Drop const.
* src/cpu/cpu.c (cpuDecode, cpuEncode, cpuUpdate, cpuHasFeature):
Fix fallout.
* src/cpu/cpu_x86.c (x86ModelFromCPU, x86ModelSubtractCPU)
(x86DecodeCPUData, x86EncodePolicy, x86Encode, x86UpdateCustom)
(x86UpdateHostModel, x86Update, x86HasFeature): Likewise.
* src/cpu/cpu_s390.c (s390Decode): Likewise.
* src/cpu/cpu_arm.c (ArmDecode): Likewise.
* src/cpu/cpu_powerpc.c (ppcModelFromCPU, ppcCompute, ppcDecode)
(ppcUpdate): Likewise.
* src/conf/cpu_conf.c (virCPUDefCopyModel, virCPUDefCopy)
(virCPUDefParseXML): Likewise.
Signed-off-by: Eric Blake <eblake@redhat.com>
2013-10-05 14:01:02 -06:00
|
|
|
const virCPUDef *cpu,
|
2012-12-18 19:44:23 +01:00
|
|
|
virCPUDataPtr *forced,
|
|
|
|
virCPUDataPtr *required,
|
|
|
|
virCPUDataPtr *optional,
|
|
|
|
virCPUDataPtr *disabled,
|
|
|
|
virCPUDataPtr *forbidden,
|
|
|
|
virCPUDataPtr *vendor)
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
2010-03-23 10:53:28 +01:00
|
|
|
VIR_DEBUG("arch=%s, cpu=%p, forced=%p, required=%p, "
|
2010-07-02 17:51:59 +02:00
|
|
|
"optional=%p, disabled=%p, forbidden=%p, vendor=%p",
|
2012-12-11 12:58:54 +00:00
|
|
|
virArchToString(arch), cpu, forced, required,
|
2010-07-02 17:51:59 +02:00
|
|
|
optional, disabled, forbidden, vendor);
|
2010-03-23 10:53:28 +01:00
|
|
|
|
2014-03-26 15:59:26 +01:00
|
|
|
if (!cpu->model) {
|
|
|
|
virReportError(VIR_ERR_INVALID_ARG, "%s",
|
|
|
|
_("no guest CPU model specified"));
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2010-02-10 12:22:36 +00:00
|
|
|
if ((driver = cpuGetSubDriver(arch)) == NULL)
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (driver->encode == NULL) {
|
2012-07-18 13:16:38 +01:00
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
|
|
|
_("cannot encode CPU data for %s architecture"),
|
2012-12-11 12:58:54 +00:00
|
|
|
virArchToString(arch));
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2013-07-16 14:39:40 +02:00
|
|
|
return driver->encode(arch, cpu, forced, required,
|
2010-07-02 17:51:59 +02:00
|
|
|
optional, disabled, forbidden, vendor);
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-02-02 12:09:52 +01:00
|
|
|
/**
|
|
|
|
* virCPUDataNew:
|
|
|
|
*
|
|
|
|
* Returns an allocated memory for virCPUData or NULL on error.
|
|
|
|
*/
|
|
|
|
virCPUDataPtr
|
|
|
|
virCPUDataNew(virArch arch)
|
|
|
|
{
|
|
|
|
virCPUDataPtr data;
|
|
|
|
|
2020-09-11 15:22:47 +02:00
|
|
|
data = g_new0(virCPUData, 1);
|
2017-02-02 12:09:52 +01:00
|
|
|
data->arch = arch;
|
|
|
|
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
/**
|
2017-02-02 15:37:40 +01:00
|
|
|
* virCPUDataFree:
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
|
|
|
* @data: CPU data structure to be freed
|
|
|
|
*
|
|
|
|
* Free internal CPU data.
|
|
|
|
*
|
|
|
|
* Returns nothing.
|
|
|
|
*/
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
void
|
2017-02-02 15:37:40 +01:00
|
|
|
virCPUDataFree(virCPUDataPtr data)
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
2013-07-16 14:39:40 +02:00
|
|
|
VIR_DEBUG("data=%p", data);
|
2010-03-23 10:53:28 +01:00
|
|
|
|
2017-02-02 15:37:40 +01:00
|
|
|
if (!data)
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
return;
|
|
|
|
|
2017-02-02 15:37:40 +01:00
|
|
|
if ((driver = cpuGetSubDriver(data->arch)) && driver->dataFree)
|
|
|
|
driver->dataFree(data);
|
|
|
|
else
|
2020-09-11 15:22:49 +02:00
|
|
|
g_free(data);
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-04-11 20:45:07 +02:00
|
|
|
/**
|
|
|
|
* virCPUGetHostIsSupported:
|
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
|
|
|
*
|
|
|
|
* Check whether virCPUGetHost is supported for @arch.
|
|
|
|
*
|
|
|
|
* Returns true if virCPUGetHost is supported, false otherwise.
|
|
|
|
*/
|
|
|
|
bool
|
|
|
|
virCPUGetHostIsSupported(virArch arch)
|
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
|
|
|
VIR_DEBUG("arch=%s", virArchToString(arch));
|
|
|
|
|
|
|
|
return (driver = cpuGetSubDriver(arch)) && driver->getHost;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
/**
|
2017-03-06 21:35:49 +01:00
|
|
|
* virCPUGetHost:
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
2017-03-07 11:38:38 +01:00
|
|
|
* @type: requested type of the CPU
|
2017-03-06 21:35:49 +01:00
|
|
|
* @nodeInfo: simplified CPU topology (optional)
|
2017-03-07 12:20:01 +01:00
|
|
|
* @models: list of CPU models that can be considered for host CPU
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
2017-03-07 11:38:38 +01:00
|
|
|
* Create CPU definition describing the host's CPU.
|
|
|
|
*
|
|
|
|
* The @type (either VIR_CPU_TYPE_HOST or VIR_CPU_TYPE_GUEST) specifies what
|
|
|
|
* type of CPU definition should be created. Specifically, VIR_CPU_TYPE_HOST
|
|
|
|
* CPUs may contain only features without any policy attribute. Requesting
|
|
|
|
* VIR_CPU_TYPE_GUEST provides better results because the CPU is allowed to
|
|
|
|
* contain disabled features.
|
|
|
|
*
|
|
|
|
* If @nodeInfo is not NULL (which is only allowed for VIR_CPU_TYPE_HOST CPUs),
|
2017-03-06 21:35:49 +01:00
|
|
|
* the CPU definition will have topology (sockets, cores, threads) filled in
|
|
|
|
* according to the content of @nodeInfo. The function fails only if @nodeInfo
|
|
|
|
* was not passed in and the assigned CPU driver was not able to detect the
|
|
|
|
* host CPU model. In other words, a CPU definition containing just the
|
|
|
|
* topology is a successful result even if detecting the host CPU model fails.
|
|
|
|
*
|
2017-03-07 12:20:01 +01:00
|
|
|
* It possible to limit the CPU model which may appear in the created CPU
|
|
|
|
* definition by passing non-NULL @models list. This is useful when requesting
|
|
|
|
* a CPU model usable on a specific hypervisor. If @models is NULL, any CPU
|
|
|
|
* model known to libvirt may appear in the result.
|
|
|
|
*
|
2017-03-06 21:35:49 +01:00
|
|
|
* Returns host CPU definition or NULL on error.
|
2014-03-26 15:45:50 +01:00
|
|
|
*/
|
2017-03-06 21:35:49 +01:00
|
|
|
virCPUDefPtr
|
|
|
|
virCPUGetHost(virArch arch,
|
2017-03-07 11:38:38 +01:00
|
|
|
virCPUType type,
|
2017-03-07 12:20:01 +01:00
|
|
|
virNodeInfoPtr nodeInfo,
|
2017-09-22 15:51:33 +02:00
|
|
|
virDomainCapsCPUModelsPtr models)
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
2020-09-07 16:58:56 +02:00
|
|
|
g_autoptr(virCPUDef) cpu = NULL;
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
|
2017-09-22 15:51:33 +02:00
|
|
|
VIR_DEBUG("arch=%s, type=%s, nodeInfo=%p, models=%p",
|
2017-03-07 12:20:01 +01:00
|
|
|
virArchToString(arch), virCPUTypeToString(type), nodeInfo,
|
2017-09-22 15:51:33 +02:00
|
|
|
models);
|
2010-03-23 10:53:28 +01:00
|
|
|
|
2017-03-06 21:35:49 +01:00
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
|
|
|
return NULL;
|
|
|
|
|
2019-11-29 11:00:26 +00:00
|
|
|
cpu = virCPUDefNew();
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
|
2017-03-07 11:38:38 +01:00
|
|
|
switch (type) {
|
|
|
|
case VIR_CPU_TYPE_HOST:
|
|
|
|
cpu->arch = arch;
|
|
|
|
cpu->type = type;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case VIR_CPU_TYPE_GUEST:
|
|
|
|
if (nodeInfo) {
|
|
|
|
virReportError(VIR_ERR_INVALID_ARG,
|
|
|
|
_("cannot set topology for CPU type '%s'"),
|
|
|
|
virCPUTypeToString(type));
|
2020-09-07 16:58:56 +02:00
|
|
|
return NULL;
|
2017-03-07 11:38:38 +01:00
|
|
|
}
|
|
|
|
cpu->type = type;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case VIR_CPU_TYPE_AUTO:
|
|
|
|
case VIR_CPU_TYPE_LAST:
|
|
|
|
virReportError(VIR_ERR_INVALID_ARG,
|
|
|
|
_("unsupported CPU type: %s"),
|
|
|
|
virCPUTypeToString(type));
|
2020-09-07 16:58:56 +02:00
|
|
|
return NULL;
|
2017-03-07 11:38:38 +01:00
|
|
|
}
|
2017-03-06 21:35:49 +01:00
|
|
|
|
|
|
|
if (nodeInfo) {
|
|
|
|
cpu->sockets = nodeInfo->sockets;
|
2019-12-16 11:16:51 +00:00
|
|
|
cpu->dies = 1;
|
2017-03-06 21:35:49 +01:00
|
|
|
cpu->cores = nodeInfo->cores;
|
|
|
|
cpu->threads = nodeInfo->threads;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Try to get the host CPU model, but don't really fail if nodeInfo is
|
|
|
|
* filled in.
|
|
|
|
*/
|
|
|
|
if (driver->getHost) {
|
2020-09-07 16:58:56 +02:00
|
|
|
if (driver->getHost(cpu, models) < 0 && !nodeInfo)
|
|
|
|
return NULL;
|
2017-03-06 21:35:49 +01:00
|
|
|
} else if (nodeInfo) {
|
|
|
|
VIR_DEBUG("cannot detect host CPU model for %s architecture",
|
|
|
|
virArchToString(arch));
|
|
|
|
} else {
|
2012-07-18 13:16:38 +01:00
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
2017-03-06 21:35:49 +01:00
|
|
|
_("cannot detect host CPU model for %s architecture"),
|
2012-12-11 12:58:54 +00:00
|
|
|
virArchToString(arch));
|
2020-09-07 16:58:56 +02:00
|
|
|
return NULL;
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
}
|
|
|
|
|
2020-09-07 16:58:56 +02:00
|
|
|
return g_steal_pointer(&cpu);
|
Adds CPU selection infrastructure
Each driver supporting CPU selection must fill in host CPU capabilities.
When filling them, drivers for hypervisors running on the same node as
libvirtd can use cpuNodeData() to obtain raw CPU data. Other drivers,
such as VMware, need to implement their own way of getting such data.
Raw data can be decoded into virCPUDefPtr using cpuDecode() function.
When implementing virConnectCompareCPU(), a hypervisor driver can just
call cpuCompareXML() function with host CPU capabilities.
For each guest for which a driver supports selecting CPU models, it must
set the appropriate feature in guest's capabilities:
virCapabilitiesAddGuestFeature(guest, "cpuselection", 1, 0)
Actions needed when a domain is being created depend on whether the
hypervisor understands raw CPU data (currently CPUID for i686, x86_64
architectures) or symbolic names has to be used.
Typical use by hypervisors which prefer CPUID (such as VMware and Xen):
- convert guest CPU configuration from domain's XML into a set of raw
data structures each representing one of the feature policies:
cpuEncode(conn, architecture, guest_cpu_config,
&forced_data, &required_data, &optional_data,
&disabled_data, &forbidden_data)
- create a mask or whatever the hypervisor expects to see and pass it
to the hypervisor
Typical use by hypervisors with symbolic model names (such as QEMU):
- get raw CPU data for a computed guest CPU:
cpuGuestData(conn, host_cpu, guest_cpu_config, &data)
- decode raw data into virCPUDefPtr with a possible restriction on
allowed model names:
cpuDecode(conn, guest, data, n_allowed_models, allowed_models)
- pass guest->model and guest->features to the hypervisor
* src/cpu/cpu.c src/cpu/cpu.h src/cpu/cpu_generic.c
src/cpu/cpu_generic.h src/cpu/cpu_map.c src/cpu/cpu_map.h
src/cpu/cpu_x86.c src/cpu/cpu_x86.h src/cpu/cpu_x86_data.h
* configure.in: check for CPUID instruction
* src/Makefile.am: glue the new files in
* src/libvirt_private.syms: add new private symbols
* po/POTFILES.in: add new cpu files containing translatable strings
2009-12-18 16:02:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-03-15 09:07:38 +01:00
|
|
|
virCPUDefPtr
|
|
|
|
virCPUProbeHost(virArch arch)
|
|
|
|
{
|
|
|
|
virNodeInfo nodeinfo;
|
|
|
|
|
2020-01-24 10:22:13 +01:00
|
|
|
if (virCapabilitiesGetNodeInfo(&nodeinfo) < 0)
|
2017-03-15 09:07:38 +01:00
|
|
|
return NULL;
|
|
|
|
|
2017-09-22 15:51:33 +02:00
|
|
|
return virCPUGetHost(arch, VIR_CPU_TYPE_HOST, &nodeinfo, NULL);
|
2017-03-15 09:07:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
/**
|
2018-05-15 10:50:32 +02:00
|
|
|
* virCPUBaseline:
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
2018-05-15 10:59:50 +02:00
|
|
|
* @arch: CPU architecture, use VIR_ARCH_NONE to autodetect from @cpus
|
2014-03-26 15:45:50 +01:00
|
|
|
* @cpus: list of host CPU definitions
|
|
|
|
* @ncpus: number of CPUs in @cpus
|
|
|
|
* @models: list of CPU models that can be considered for the baseline CPU
|
2018-05-15 11:57:35 +02:00
|
|
|
* @features: optional NULL terminated list of allowed features
|
2017-03-17 15:58:07 +01:00
|
|
|
* @migratable: requests non-migratable features to be removed from the result
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
|
|
|
* Computes the most feature-rich CPU which is compatible with all given
|
2018-05-15 10:59:50 +02:00
|
|
|
* CPUs. If @models is NULL, all models supported by libvirt will
|
2014-03-26 15:45:50 +01:00
|
|
|
* be considered when computing the baseline CPU model, otherwise the baseline
|
|
|
|
* CPU model will be one of the provided CPU @models.
|
|
|
|
*
|
|
|
|
* Returns baseline CPU definition or NULL on error.
|
|
|
|
*/
|
2010-01-25 18:27:56 +01:00
|
|
|
virCPUDefPtr
|
2018-05-15 10:59:50 +02:00
|
|
|
virCPUBaseline(virArch arch,
|
|
|
|
virCPUDefPtr *cpus,
|
2018-05-15 10:50:32 +02:00
|
|
|
unsigned int ncpus,
|
|
|
|
virDomainCapsCPUModelsPtr models,
|
2018-05-15 11:57:35 +02:00
|
|
|
const char **features,
|
2018-05-15 10:50:32 +02:00
|
|
|
bool migratable)
|
2010-01-25 18:27:56 +01:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
Convert 'int i' to 'size_t i' in src/cpu/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
size_t i;
|
2010-03-23 10:53:28 +01:00
|
|
|
|
2018-05-15 11:57:35 +02:00
|
|
|
VIR_DEBUG("arch=%s, ncpus=%u, models=%p, features=%p, migratable=%d",
|
|
|
|
virArchToString(arch), ncpus, models, features, migratable);
|
2010-03-23 10:53:28 +01:00
|
|
|
if (cpus) {
|
|
|
|
for (i = 0; i < ncpus; i++)
|
Convert 'int i' to 'size_t i' in src/cpu/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
VIR_DEBUG("cpus[%zu]=%p", i, cpus[i]);
|
2010-03-23 10:53:28 +01:00
|
|
|
}
|
|
|
|
if (models) {
|
2017-09-22 15:51:33 +02:00
|
|
|
for (i = 0; i < models->nmodels; i++)
|
|
|
|
VIR_DEBUG("models[%zu]=%s", i, models->models[i].name);
|
2010-03-23 10:53:28 +01:00
|
|
|
}
|
2010-01-25 18:27:56 +01:00
|
|
|
|
2018-05-15 11:04:10 +02:00
|
|
|
if (!cpus && ncpus != 0) {
|
2012-07-18 13:16:38 +01:00
|
|
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
|
|
"%s", _("nonzero ncpus doesn't match with NULL cpus"));
|
2010-01-25 18:27:56 +01:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (ncpus < 1) {
|
2018-05-15 11:04:10 +02:00
|
|
|
virReportError(VIR_ERR_INVALID_ARG, "%s", _("no CPUs given"));
|
2010-01-25 18:27:56 +01:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2014-03-26 15:59:26 +01:00
|
|
|
for (i = 0; i < ncpus; i++) {
|
|
|
|
if (!cpus[i]) {
|
|
|
|
virReportError(VIR_ERR_INVALID_ARG,
|
|
|
|
_("invalid CPU definition at index %zu"), i);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!cpus[i]->model) {
|
|
|
|
virReportError(VIR_ERR_INVALID_ARG,
|
|
|
|
_("no CPU model specified at index %zu"), i);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-15 10:59:50 +02:00
|
|
|
if (arch == VIR_ARCH_NONE)
|
|
|
|
arch = cpus[0]->arch;
|
|
|
|
|
2018-05-15 11:04:10 +02:00
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
2010-01-25 18:27:56 +01:00
|
|
|
return NULL;
|
|
|
|
|
2018-05-15 11:04:10 +02:00
|
|
|
if (!driver->baseline) {
|
2012-07-18 13:16:38 +01:00
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
|
|
|
_("cannot compute baseline CPU of %s architecture"),
|
2018-05-15 10:59:50 +02:00
|
|
|
virArchToString(arch));
|
2010-01-25 18:27:56 +01:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2018-05-15 11:57:35 +02:00
|
|
|
return driver->baseline(cpus, ncpus, models, features, migratable);
|
2010-01-25 18:27:56 +01:00
|
|
|
}
|
2010-03-23 09:32:50 +01:00
|
|
|
|
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
/**
|
2016-06-23 15:27:07 +02:00
|
|
|
* virCPUUpdate:
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
2016-06-23 15:27:07 +02:00
|
|
|
* @arch: CPU architecture
|
|
|
|
* @guest: guest CPU definition to be updated
|
2014-03-26 15:45:50 +01:00
|
|
|
* @host: host CPU definition
|
|
|
|
*
|
2020-11-19 21:35:41 +01:00
|
|
|
* Updates @guest CPU definition possibly taking @host CPU into account. This
|
|
|
|
* is required for maintaining compatibility with older libvirt releases or to
|
|
|
|
* support guest CPU definitions specified relatively to host CPU, such as CPUs
|
|
|
|
* with VIR_CPU_MODE_CUSTOM and optional features or VIR_CPU_MATCH_MINIMUM, or
|
|
|
|
* CPUs with VIR_CPU_MODE_HOST_MODEL.
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
|
|
|
* Returns 0 on success, -1 on error.
|
|
|
|
*/
|
2010-03-23 09:32:50 +01:00
|
|
|
int
|
2016-06-23 15:27:07 +02:00
|
|
|
virCPUUpdate(virArch arch,
|
|
|
|
virCPUDefPtr guest,
|
|
|
|
const virCPUDef *host)
|
2010-03-23 09:32:50 +01:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
2020-11-19 21:35:41 +01:00
|
|
|
bool relative;
|
2010-03-23 09:32:50 +01:00
|
|
|
|
2016-06-23 15:27:07 +02:00
|
|
|
VIR_DEBUG("arch=%s, guest=%p mode=%s model=%s, host=%p model=%s",
|
|
|
|
virArchToString(arch), guest, virCPUModeTypeToString(guest->mode),
|
|
|
|
NULLSTR(guest->model), host, NULLSTR(host ? host->model : NULL));
|
2010-03-23 09:32:50 +01:00
|
|
|
|
2016-06-23 15:27:07 +02:00
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
2010-03-23 09:32:50 +01:00
|
|
|
return -1;
|
|
|
|
|
2020-11-19 21:35:41 +01:00
|
|
|
switch ((virCPUMode) guest->mode) {
|
|
|
|
case VIR_CPU_MODE_HOST_PASSTHROUGH:
|
2016-06-23 15:27:07 +02:00
|
|
|
return 0;
|
|
|
|
|
2020-11-19 21:35:41 +01:00
|
|
|
case VIR_CPU_MODE_HOST_MODEL:
|
|
|
|
relative = true;
|
|
|
|
break;
|
2016-06-23 15:27:07 +02:00
|
|
|
|
2020-11-19 21:35:41 +01:00
|
|
|
case VIR_CPU_MODE_CUSTOM:
|
|
|
|
if (guest->match == VIR_CPU_MATCH_MINIMUM) {
|
|
|
|
relative = true;
|
|
|
|
} else {
|
|
|
|
size_t i;
|
|
|
|
|
|
|
|
relative = false;
|
|
|
|
for (i = 0; i < guest->nfeatures; i++) {
|
|
|
|
if (guest->features[i].policy == VIR_CPU_FEATURE_OPTIONAL) {
|
|
|
|
relative = true;
|
|
|
|
break;
|
|
|
|
}
|
2016-06-23 15:27:07 +02:00
|
|
|
}
|
|
|
|
}
|
2020-11-19 21:35:41 +01:00
|
|
|
break;
|
2016-06-23 15:27:07 +02:00
|
|
|
|
2020-11-19 21:35:41 +01:00
|
|
|
case VIR_CPU_MODE_LAST:
|
|
|
|
default:
|
|
|
|
virReportEnumRangeError(virCPUMode, guest->mode);
|
|
|
|
return -1;
|
2016-06-23 15:27:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!driver->update) {
|
2012-07-18 13:16:38 +01:00
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
2016-06-23 15:27:07 +02:00
|
|
|
_("cannot update guest CPU for %s architecture"),
|
|
|
|
virArchToString(arch));
|
2010-03-23 09:32:50 +01:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2020-11-19 21:35:41 +01:00
|
|
|
if (driver->update(guest, host, relative) < 0)
|
2016-06-23 15:27:07 +02:00
|
|
|
return -1;
|
|
|
|
|
|
|
|
VIR_DEBUG("model=%s", NULLSTR(guest->model));
|
|
|
|
return 0;
|
2010-03-23 09:32:50 +01:00
|
|
|
}
|
2010-09-22 12:47:09 +01:00
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
|
2017-03-13 12:32:02 +01:00
|
|
|
/**
|
|
|
|
* virCPUUpdateLive:
|
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
|
|
|
* @cpu: guest CPU definition to be updated
|
|
|
|
* @dataEnabled: CPU data of the virtual CPU
|
|
|
|
* @dataDisabled: CPU data with features requested by @cpu but disabled by the
|
|
|
|
* hypervisor
|
|
|
|
*
|
|
|
|
* Update custom mode CPU according to the virtual CPU created by the
|
2017-03-14 15:05:02 +01:00
|
|
|
* hypervisor. The function refuses to update the CPU in case cpu->check is set
|
|
|
|
* to VIR_CPU_CHECK_FULL.
|
2017-03-13 12:32:02 +01:00
|
|
|
*
|
|
|
|
* Returns -1 on error,
|
|
|
|
* 0 when the CPU was successfully updated,
|
|
|
|
* 1 when the operation does not make sense on the CPU or it is not
|
|
|
|
* supported for the given architecture.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
virCPUUpdateLive(virArch arch,
|
|
|
|
virCPUDefPtr cpu,
|
|
|
|
virCPUDataPtr dataEnabled,
|
|
|
|
virCPUDataPtr dataDisabled)
|
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
|
|
|
VIR_DEBUG("arch=%s, cpu=%p, dataEnabled=%p, dataDisabled=%p",
|
|
|
|
virArchToString(arch), cpu, dataEnabled, dataDisabled);
|
|
|
|
|
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (!driver->updateLive)
|
|
|
|
return 1;
|
|
|
|
|
2020-03-09 14:14:04 +01:00
|
|
|
if (cpu->mode == VIR_CPU_MODE_CUSTOM ||
|
|
|
|
cpu->check == VIR_CPU_CHECK_FULL) {
|
2020-03-09 10:30:39 +01:00
|
|
|
if (driver->updateLive(cpu, dataEnabled, dataDisabled) < 0)
|
|
|
|
return -1;
|
2017-03-13 12:32:02 +01:00
|
|
|
|
2020-03-09 10:30:39 +01:00
|
|
|
return 0;
|
|
|
|
}
|
2017-03-13 12:32:02 +01:00
|
|
|
|
2020-03-09 10:30:39 +01:00
|
|
|
return 1;
|
2017-03-13 12:32:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-09-16 14:13:09 +02:00
|
|
|
/**
|
|
|
|
* virCPUCheckFeature:
|
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
|
|
|
* @cpu: CPU definition
|
|
|
|
* @feature: feature to be checked for
|
|
|
|
*
|
|
|
|
* Checks whether @feature is supported by the CPU described by @cpu.
|
|
|
|
*
|
|
|
|
* Returns 1 if the feature is supported, 0 if it's not supported, or
|
|
|
|
* -1 on error.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
virCPUCheckFeature(virArch arch,
|
|
|
|
const virCPUDef *cpu,
|
|
|
|
const char *feature)
|
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
|
|
|
VIR_DEBUG("arch=%s, cpu=%p, feature=%s",
|
|
|
|
virArchToString(arch), cpu, feature);
|
|
|
|
|
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (!driver->checkFeature) {
|
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
|
|
|
_("cannot check guest CPU feature for %s architecture"),
|
|
|
|
virArchToString(arch));
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return driver->checkFeature(cpu, feature);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
/**
|
2016-08-08 15:48:15 +02:00
|
|
|
* virCPUDataCheckFeature:
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
2016-09-16 14:12:15 +02:00
|
|
|
* @data: CPU data
|
2014-03-26 15:45:50 +01:00
|
|
|
* @feature: feature to be checked for
|
|
|
|
*
|
|
|
|
* Checks whether @feature is supported by the CPU described by @data.
|
|
|
|
*
|
|
|
|
* Returns 1 if the feature is supported, 0 if it's not supported, or
|
|
|
|
* -1 on error.
|
|
|
|
*/
|
2010-09-22 12:47:09 +01:00
|
|
|
int
|
2016-08-08 15:48:15 +02:00
|
|
|
virCPUDataCheckFeature(const virCPUData *data,
|
|
|
|
const char *feature)
|
2010-09-22 12:47:09 +01:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
2016-09-16 14:12:15 +02:00
|
|
|
VIR_DEBUG("arch=%s, data=%p, feature=%s",
|
|
|
|
virArchToString(data->arch), data, feature);
|
2010-09-22 12:47:09 +01:00
|
|
|
|
2016-09-16 14:12:15 +02:00
|
|
|
if (!(driver = cpuGetSubDriver(data->arch)))
|
2010-09-22 12:47:09 +01:00
|
|
|
return -1;
|
|
|
|
|
2016-08-08 15:48:15 +02:00
|
|
|
if (!driver->dataCheckFeature) {
|
2012-07-18 13:16:38 +01:00
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
2016-09-16 14:12:15 +02:00
|
|
|
_("cannot check guest CPU feature for %s architecture"),
|
2013-07-16 14:39:40 +02:00
|
|
|
virArchToString(data->arch));
|
2010-09-22 12:47:09 +01:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2016-08-08 15:48:15 +02:00
|
|
|
return driver->dataCheckFeature(data, feature);
|
2010-09-22 12:47:09 +01:00
|
|
|
}
|
2012-12-19 12:08:32 +01:00
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
|
|
|
|
/**
|
2016-11-04 15:09:20 +01:00
|
|
|
* virCPUDataFormat:
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
|
|
|
* @data: internal CPU representation
|
|
|
|
*
|
|
|
|
* Formats @data into XML for test purposes.
|
|
|
|
*
|
|
|
|
* Returns string representation of the XML describing @data or NULL on error.
|
|
|
|
*/
|
2013-07-22 00:18:50 +02:00
|
|
|
char *
|
2016-11-04 15:09:20 +01:00
|
|
|
virCPUDataFormat(const virCPUData *data)
|
2013-07-22 00:18:50 +02:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
|
|
|
VIR_DEBUG("data=%p", data);
|
|
|
|
|
|
|
|
if (!(driver = cpuGetSubDriver(data->arch)))
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
if (!driver->dataFormat) {
|
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
|
|
|
_("cannot format %s CPU data"),
|
|
|
|
virArchToString(data->arch));
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return driver->dataFormat(data);
|
|
|
|
}
|
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
|
|
|
|
/**
|
2016-11-04 15:02:26 +01:00
|
|
|
* virCPUDataParse:
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
2016-11-04 15:09:20 +01:00
|
|
|
* @xmlStr: XML string produced by virCPUDataFormat
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
|
|
|
* Parses XML representation of virCPUData structure for test purposes.
|
|
|
|
*
|
|
|
|
* Returns internal CPU data structure parsed from the XML or NULL on error.
|
|
|
|
*/
|
2013-07-22 00:18:50 +02:00
|
|
|
virCPUDataPtr
|
2016-11-04 15:02:26 +01:00
|
|
|
virCPUDataParse(const char *xmlStr)
|
2013-07-22 00:18:50 +02:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
2020-04-06 18:54:06 +05:30
|
|
|
g_autoptr(xmlDoc) xml = NULL;
|
|
|
|
g_autoptr(xmlXPathContext) ctxt = NULL;
|
2015-06-29 11:08:30 +02:00
|
|
|
virCPUDataPtr data = NULL;
|
2020-04-06 18:54:06 +05:30
|
|
|
g_autofree char *arch = NULL;
|
2013-07-22 00:18:50 +02:00
|
|
|
|
2015-06-29 11:08:30 +02:00
|
|
|
VIR_DEBUG("xmlStr=%s", xmlStr);
|
2013-07-22 00:18:50 +02:00
|
|
|
|
2015-06-29 11:08:30 +02:00
|
|
|
if (!(xml = virXMLParseStringCtxt(xmlStr, _("CPU data"), &ctxt))) {
|
|
|
|
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
|
|
|
_("cannot parse CPU data"));
|
2020-04-06 18:54:06 +05:30
|
|
|
return NULL;
|
2015-06-29 11:08:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!(arch = virXPathString("string(/cpudata/@arch)", ctxt))) {
|
|
|
|
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
|
|
|
_("missing CPU data architecture"));
|
2020-04-06 18:54:06 +05:30
|
|
|
return NULL;
|
2015-06-29 11:08:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!(driver = cpuGetSubDriverByName(arch)))
|
2020-04-06 18:54:06 +05:30
|
|
|
return NULL;
|
2013-07-22 00:18:50 +02:00
|
|
|
|
|
|
|
if (!driver->dataParse) {
|
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
2015-06-29 11:08:30 +02:00
|
|
|
_("cannot parse %s CPU data"), arch);
|
2020-04-06 18:54:06 +05:30
|
|
|
return NULL;
|
2013-07-22 00:18:50 +02:00
|
|
|
}
|
|
|
|
|
2015-06-29 11:08:30 +02:00
|
|
|
data = driver->dataParse(ctxt);
|
|
|
|
return data;
|
2013-07-22 00:18:50 +02:00
|
|
|
}
|
|
|
|
|
2016-11-04 14:57:53 +01:00
|
|
|
|
|
|
|
/** virCPUModelIsAllowed:
|
|
|
|
*
|
|
|
|
* @model: CPU model to be checked
|
|
|
|
* @models: list of supported CPU models
|
|
|
|
*
|
|
|
|
* Checks whether @model can be found in the list of supported @models.
|
2017-09-22 15:51:33 +02:00
|
|
|
* If @models is NULL, all models are supported.
|
2016-11-04 14:57:53 +01:00
|
|
|
*
|
|
|
|
* Returns true if @model is supported, false otherwise.
|
|
|
|
*/
|
2012-12-19 12:08:32 +01:00
|
|
|
bool
|
2016-11-04 14:57:53 +01:00
|
|
|
virCPUModelIsAllowed(const char *model,
|
2017-09-22 15:51:33 +02:00
|
|
|
virDomainCapsCPUModelsPtr models)
|
2012-12-19 12:08:32 +01:00
|
|
|
{
|
2017-09-22 15:51:33 +02:00
|
|
|
if (!models)
|
2012-12-19 12:08:32 +01:00
|
|
|
return true;
|
|
|
|
|
2017-10-13 17:37:34 +02:00
|
|
|
return !!virDomainCapsCPUModelsGet(models, model);
|
2012-12-19 12:08:32 +01:00
|
|
|
}
|
2013-09-23 11:45:59 +02:00
|
|
|
|
2016-11-04 14:57:53 +01:00
|
|
|
|
2014-03-26 15:45:50 +01:00
|
|
|
/**
|
2016-11-04 14:20:39 +01:00
|
|
|
* virCPUGetModels:
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
2016-04-29 10:38:03 +02:00
|
|
|
* @arch: CPU architecture
|
2016-04-29 10:41:35 +02:00
|
|
|
* @models: where to store the NULL-terminated list of supported models
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
2016-06-14 11:12:49 +02:00
|
|
|
* Fetches all CPU models supported by libvirt on @archName. If there are
|
|
|
|
* no restrictions on CPU models on @archName (i.e., the CPU model is just
|
|
|
|
* passed directly to a hypervisor), this function returns 0 and sets
|
|
|
|
* @models to NULL.
|
2014-03-26 15:45:50 +01:00
|
|
|
*
|
2016-06-14 11:12:49 +02:00
|
|
|
* Returns number of supported CPU models, 0 if any CPU model is supported,
|
|
|
|
* or -1 on error.
|
2014-03-26 15:45:50 +01:00
|
|
|
*/
|
2013-09-23 11:45:59 +02:00
|
|
|
int
|
2016-11-04 14:20:39 +01:00
|
|
|
virCPUGetModels(virArch arch, char ***models)
|
2013-09-23 11:45:59 +02:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
2016-04-29 10:38:03 +02:00
|
|
|
VIR_DEBUG("arch=%s", virArchToString(arch));
|
2013-09-23 11:45:59 +02:00
|
|
|
|
2016-06-16 16:08:30 +02:00
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
2014-11-20 11:08:21 +01:00
|
|
|
return -1;
|
2013-09-23 11:45:59 +02:00
|
|
|
|
2014-11-20 11:08:21 +01:00
|
|
|
if (!driver->getModels) {
|
2016-06-14 11:12:49 +02:00
|
|
|
if (models)
|
|
|
|
*models = NULL;
|
|
|
|
return 0;
|
2014-11-20 11:08:21 +01:00
|
|
|
}
|
2013-09-23 11:45:59 +02:00
|
|
|
|
2014-11-20 11:08:21 +01:00
|
|
|
return driver->getModels(models);
|
2013-09-23 11:45:59 +02:00
|
|
|
}
|
2016-06-17 09:45:48 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virCPUTranslate:
|
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
|
|
|
* @cpu: CPU definition to be translated
|
2017-09-22 15:51:33 +02:00
|
|
|
* @models: list of allowed CPU models (NULL if all are allowed)
|
2016-06-17 09:45:48 +02:00
|
|
|
*
|
|
|
|
* Translates @cpu model (if allowed by @cpu->fallback) to a closest CPU model
|
|
|
|
* from @models list.
|
|
|
|
*
|
|
|
|
* The function does nothing (and returns 0) if @cpu does not have to be
|
|
|
|
* translated.
|
|
|
|
*
|
|
|
|
* Returns -1 on error, 0 on success.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
virCPUTranslate(virArch arch,
|
|
|
|
virCPUDefPtr cpu,
|
2017-09-22 15:51:33 +02:00
|
|
|
virDomainCapsCPUModelsPtr models)
|
2016-06-17 09:45:48 +02:00
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
2017-09-22 15:51:33 +02:00
|
|
|
VIR_DEBUG("arch=%s, cpu=%p, model=%s, models=%p",
|
|
|
|
virArchToString(arch), cpu, NULLSTR(cpu->model), models);
|
2016-06-17 09:45:48 +02:00
|
|
|
|
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (cpu->mode == VIR_CPU_MODE_HOST_MODEL ||
|
|
|
|
cpu->mode == VIR_CPU_MODE_HOST_PASSTHROUGH)
|
|
|
|
return 0;
|
|
|
|
|
2017-09-22 15:51:33 +02:00
|
|
|
if (virCPUModelIsAllowed(cpu->model, models))
|
2016-06-17 09:45:48 +02:00
|
|
|
return 0;
|
|
|
|
|
|
|
|
if (cpu->fallback != VIR_CPU_FALLBACK_ALLOW) {
|
|
|
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
|
|
|
_("CPU model %s is not supported by hypervisor"),
|
|
|
|
cpu->model);
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!driver->translate) {
|
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
|
|
|
_("cannot translate CPU model %s to a supported model"),
|
|
|
|
cpu->model);
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2017-09-22 15:51:33 +02:00
|
|
|
if (driver->translate(cpu, models) < 0)
|
2016-06-17 09:45:48 +02:00
|
|
|
return -1;
|
|
|
|
|
|
|
|
VIR_DEBUG("model=%s", NULLSTR(cpu->model));
|
|
|
|
return 0;
|
|
|
|
}
|
2016-11-09 17:09:48 +01:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virCPUConvertLegacy:
|
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
|
|
|
* @cpu: CPU definition to be converted
|
|
|
|
*
|
|
|
|
* Convert legacy CPU definition into one that the corresponding cpu driver
|
|
|
|
* will be able to work with. Currently this is only implemented by the PPC
|
|
|
|
* driver, which needs to convert legacy POWERx_v* names into POWERx.
|
|
|
|
*
|
|
|
|
* Returns -1 on error, 0 on success.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
virCPUConvertLegacy(virArch arch,
|
|
|
|
virCPUDefPtr cpu)
|
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
|
|
|
VIR_DEBUG("arch=%s, cpu=%p, model=%s",
|
|
|
|
virArchToString(arch), cpu, NULLSTR(cpu->model));
|
|
|
|
|
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (!driver->convertLegacy)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
if (driver->convertLegacy(cpu) < 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
VIR_DEBUG("model=%s", NULLSTR(cpu->model));
|
|
|
|
return 0;
|
|
|
|
}
|
2017-03-16 12:23:50 +01:00
|
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
virCPUFeatureCompare(const void *p1,
|
|
|
|
const void *p2)
|
|
|
|
{
|
|
|
|
const virCPUFeatureDef *f1 = p1;
|
|
|
|
const virCPUFeatureDef *f2 = p2;
|
|
|
|
|
|
|
|
return strcmp(f1->name, f2->name);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virCPUExpandFeatures:
|
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
|
|
|
* @cpu: CPU definition to be expanded
|
|
|
|
*
|
|
|
|
* Add all features implicitly enabled by the CPU model to the list of
|
|
|
|
* features. The @cpu is expected to be either a host or a guest representation
|
|
|
|
* of a host CPU, i.e., only VIR_CPU_FEATURE_REQUIRE and
|
|
|
|
* VIR_CPU_FEATURE_DISABLE policies are supported.
|
|
|
|
*
|
|
|
|
* The updated list of features in the CPU definition is sorted.
|
|
|
|
*
|
|
|
|
* Return -1 on error, 0 on success.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
virCPUExpandFeatures(virArch arch,
|
|
|
|
virCPUDefPtr cpu)
|
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
|
|
|
VIR_DEBUG("arch=%s, cpu=%p, model=%s, nfeatures=%zu",
|
|
|
|
virArchToString(arch), cpu, NULLSTR(cpu->model), cpu->nfeatures);
|
|
|
|
|
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (driver->expandFeatures &&
|
|
|
|
driver->expandFeatures(cpu) < 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
qsort(cpu->features, cpu->nfeatures, sizeof(*cpu->features),
|
|
|
|
virCPUFeatureCompare);
|
|
|
|
|
|
|
|
VIR_DEBUG("nfeatures=%zu", cpu->nfeatures);
|
|
|
|
return 0;
|
|
|
|
}
|
2017-03-29 14:45:44 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virCPUCopyMigratable:
|
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
|
|
|
* @cpu: CPU definition to be copied
|
|
|
|
*
|
|
|
|
* Makes a copy of @cpu with all features which would block migration removed.
|
|
|
|
* If this doesn't make sense for a given architecture, the function returns a
|
|
|
|
* plain copy of @cpu (i.e., a copy with no features removed).
|
|
|
|
*
|
|
|
|
* Returns the copy of the CPU or NULL on error.
|
|
|
|
*/
|
|
|
|
virCPUDefPtr
|
|
|
|
virCPUCopyMigratable(virArch arch,
|
|
|
|
virCPUDefPtr cpu)
|
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
|
|
|
VIR_DEBUG("arch=%s, cpu=%p, model=%s",
|
|
|
|
virArchToString(arch), cpu, NULLSTR(cpu->model));
|
|
|
|
|
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
if (driver->copyMigratable)
|
|
|
|
return driver->copyMigratable(cpu);
|
|
|
|
else
|
|
|
|
return virCPUDefCopy(cpu);
|
|
|
|
}
|
2017-09-14 16:04:13 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virCPUValidateFeatures:
|
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
|
|
|
* @cpu: CPU definition to be checked
|
|
|
|
*
|
|
|
|
* Checks whether all CPU features specified in @cpu are valid.
|
|
|
|
*
|
|
|
|
* Returns 0 on success (all features are valid), -1 on error.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
virCPUValidateFeatures(virArch arch,
|
|
|
|
virCPUDefPtr cpu)
|
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
|
|
|
VIR_DEBUG("arch=%s, cpu=%p, nfeatures=%zu",
|
|
|
|
virArchToString(arch), cpu, cpu->nfeatures);
|
|
|
|
|
|
|
|
if (!(driver = cpuGetSubDriver(arch)))
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (driver->validateFeatures)
|
|
|
|
return driver->validateFeatures(cpu);
|
|
|
|
else
|
|
|
|
return 0;
|
|
|
|
}
|
2019-06-18 10:09:31 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virCPUDataAddFeature:
|
|
|
|
*
|
|
|
|
* @cpuData: CPU data
|
|
|
|
* @name: feature to be added to @cpuData
|
|
|
|
*
|
|
|
|
* Adds a feature called @name to @cpuData.
|
|
|
|
*
|
|
|
|
* Returns 0 on success, -1 on error.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
virCPUDataAddFeature(virCPUDataPtr cpuData,
|
|
|
|
const char *name)
|
|
|
|
{
|
|
|
|
struct cpuArchDriver *driver;
|
|
|
|
|
|
|
|
VIR_DEBUG("arch=%s, cpuData=%p, name=%s",
|
|
|
|
virArchToString(cpuData->arch), cpuData, name);
|
|
|
|
|
|
|
|
if (!(driver = cpuGetSubDriver(cpuData->arch)))
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (!driver->dataAddFeature) {
|
|
|
|
virReportError(VIR_ERR_NO_SUPPORT,
|
|
|
|
_("cannot add guest CPU feature for %s architecture"),
|
|
|
|
virArchToString(cpuData->arch));
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return driver->dataAddFeature(cpuData, name);
|
|
|
|
}
|
2020-02-25 16:05:06 +01:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virCPUArchIsSupported:
|
|
|
|
*
|
|
|
|
* @arch: CPU architecture
|
|
|
|
*
|
|
|
|
* Returns true if the architecture is supported by any CPU driver.
|
|
|
|
*/
|
|
|
|
bool
|
|
|
|
virCPUArchIsSupported(virArch arch)
|
|
|
|
{
|
|
|
|
size_t i;
|
|
|
|
size_t j;
|
|
|
|
|
|
|
|
for (i = 0; i < G_N_ELEMENTS(drivers); i++) {
|
|
|
|
for (j = 0; j < drivers[i]->narch; j++) {
|
|
|
|
if (arch == drivers[i]->arch[j])
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|