2012-07-12 10:28:17 -05:00
|
|
|
/*
|
|
|
|
* cpu_arm.c: CPU driver for arm CPUs
|
|
|
|
*
|
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
|
|
|
* Copyright (C) 2013 Red Hat, Inc.
|
2012-07-12 10:28:17 -05:00
|
|
|
* Copyright (C) Canonical Ltd. 2012
|
|
|
|
*
|
|
|
|
* 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/>.
|
2012-07-12 10:28:17 -05:00
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Chuck Short <chuck.short@canonical.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
2012-12-12 18:06:53 +00:00
|
|
|
#include "viralloc.h"
|
2012-07-12 10:28:17 -05:00
|
|
|
#include "cpu.h"
|
2014-02-26 20:40:12 +04:00
|
|
|
#include "virstring.h"
|
2012-07-12 10:28:17 -05:00
|
|
|
|
|
|
|
#define VIR_FROM_THIS VIR_FROM_CPU
|
|
|
|
|
2014-06-17 15:27:17 +02:00
|
|
|
static const virArch archs[] = {VIR_ARCH_ARMV6L,
|
|
|
|
VIR_ARCH_ARMV7B,
|
|
|
|
VIR_ARCH_ARMV7L};
|
2012-07-12 10:28:17 -05:00
|
|
|
|
2012-12-18 19:44:23 +01:00
|
|
|
static virCPUDataPtr
|
Ensure 'arch' is always set in cpuArchNodeData
The s390, ppc and arm CPU drivers never set the 'arch' field
in their impl of cpuArchNodeData. This leads to error messages
being reported from cpuDataFree later, due to trying to use
VIR_ARCH_NONE.
#0 virRaiseErrorFull (filename=filename@entry=0x76f94434 "cpu/cpu.c", funcname=funcname@entry=0x76f942dc <__FUNCTION__.18096> "cpuGetSubDriver", linenr=linenr@entry=58,
domain=domain@entry=31, code=code@entry=1, level=level@entry=VIR_ERR_ERROR, str1=0x76f70e18 "internal error: %s",
str2=str2@entry=0x7155f2ec "undefined hardware architecture", str3=str3@entry=0x0, int1=int1@entry=-1, int2=int2@entry=-1, fmt=0x76f70e18 "internal error: %s")
at util/virerror.c:646
#1 0x76e682ea in virReportErrorHelper (domcode=domcode@entry=31, errorcode=errorcode@entry=1, filename=0x76f94434 "cpu/cpu.c",
funcname=0x76f942dc <__FUNCTION__.18096> "cpuGetSubDriver", linenr=linenr@entry=58, fmt=0x76f7e7e4 "%s") at util/virerror.c:1292
#2 0x76ed82d4 in cpuGetSubDriver (arch=<optimized out>) at cpu/cpu.c:57
#3 cpuGetSubDriver (arch=VIR_ARCH_NONE) at cpu/cpu.c:51
#4 0x76ed8818 in cpuDataFree (data=data@entry=0x70c22d78) at cpu/cpu.c:216
#5 0x716aaec0 in virQEMUCapsInitCPU (arch=VIR_ARCH_ARMV7L, caps=0x70c29a08) at qemu/qemu_capabilities.c:867
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-09-04 17:41:55 +01:00
|
|
|
ArmNodeData(virArch arch)
|
2012-07-12 10:28:17 -05:00
|
|
|
{
|
2012-12-18 19:44:23 +01:00
|
|
|
virCPUDataPtr data;
|
2012-07-12 10:28:17 -05:00
|
|
|
|
Ensure 'arch' is always set in cpuArchNodeData
The s390, ppc and arm CPU drivers never set the 'arch' field
in their impl of cpuArchNodeData. This leads to error messages
being reported from cpuDataFree later, due to trying to use
VIR_ARCH_NONE.
#0 virRaiseErrorFull (filename=filename@entry=0x76f94434 "cpu/cpu.c", funcname=funcname@entry=0x76f942dc <__FUNCTION__.18096> "cpuGetSubDriver", linenr=linenr@entry=58,
domain=domain@entry=31, code=code@entry=1, level=level@entry=VIR_ERR_ERROR, str1=0x76f70e18 "internal error: %s",
str2=str2@entry=0x7155f2ec "undefined hardware architecture", str3=str3@entry=0x0, int1=int1@entry=-1, int2=int2@entry=-1, fmt=0x76f70e18 "internal error: %s")
at util/virerror.c:646
#1 0x76e682ea in virReportErrorHelper (domcode=domcode@entry=31, errorcode=errorcode@entry=1, filename=0x76f94434 "cpu/cpu.c",
funcname=0x76f942dc <__FUNCTION__.18096> "cpuGetSubDriver", linenr=linenr@entry=58, fmt=0x76f7e7e4 "%s") at util/virerror.c:1292
#2 0x76ed82d4 in cpuGetSubDriver (arch=<optimized out>) at cpu/cpu.c:57
#3 cpuGetSubDriver (arch=VIR_ARCH_NONE) at cpu/cpu.c:51
#4 0x76ed8818 in cpuDataFree (data=data@entry=0x70c22d78) at cpu/cpu.c:216
#5 0x716aaec0 in virQEMUCapsInitCPU (arch=VIR_ARCH_ARMV7L, caps=0x70c29a08) at qemu/qemu_capabilities.c:867
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-09-04 17:41:55 +01:00
|
|
|
if (VIR_ALLOC(data) < 0)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
data->arch = arch;
|
|
|
|
|
2012-07-12 10:28:17 -05:00
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
2014-02-26 20:40:12 +04:00
|
|
|
ArmDecode(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 ATTRIBUTE_UNUSED,
|
2012-07-12 10:28:17 -05:00
|
|
|
const char **models ATTRIBUTE_UNUSED,
|
|
|
|
unsigned int nmodels ATTRIBUTE_UNUSED,
|
2013-08-02 13:08:19 -06:00
|
|
|
const char *preferred ATTRIBUTE_UNUSED,
|
|
|
|
unsigned int flags)
|
2012-07-12 10:28:17 -05:00
|
|
|
{
|
2013-08-02 13:08:19 -06:00
|
|
|
virCheckFlags(VIR_CONNECT_BASELINE_CPU_EXPAND_FEATURES, -1);
|
|
|
|
|
2014-02-26 20:40:12 +04:00
|
|
|
if (cpu->model == NULL &&
|
|
|
|
VIR_STRDUP(cpu->model, "host") < 0)
|
|
|
|
return -1;
|
|
|
|
|
2012-07-12 10:28:17 -05:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2012-12-18 19:44:23 +01:00
|
|
|
ArmDataFree(virCPUDataPtr data)
|
2012-07-12 10:28:17 -05:00
|
|
|
{
|
|
|
|
VIR_FREE(data);
|
|
|
|
}
|
|
|
|
|
2014-02-26 20:40:12 +04:00
|
|
|
static int
|
|
|
|
ArmUpdate(virCPUDefPtr guest,
|
|
|
|
const virCPUDef *host)
|
|
|
|
{
|
|
|
|
guest->match = VIR_CPU_MATCH_EXACT;
|
|
|
|
virCPUDefFreeModel(guest);
|
|
|
|
return virCPUDefCopyModel(guest, host, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
static virCPUCompareResult
|
|
|
|
ArmGuestData(virCPUDefPtr host ATTRIBUTE_UNUSED,
|
|
|
|
virCPUDefPtr guest ATTRIBUTE_UNUSED,
|
|
|
|
virCPUDataPtr *data ATTRIBUTE_UNUSED,
|
|
|
|
char **message ATTRIBUTE_UNUSED)
|
|
|
|
{
|
|
|
|
return VIR_CPU_COMPARE_IDENTICAL;
|
|
|
|
}
|
|
|
|
|
2014-03-03 17:41:03 +04:00
|
|
|
static virCPUDefPtr
|
|
|
|
ArmBaseline(virCPUDefPtr *cpus,
|
|
|
|
unsigned int ncpus ATTRIBUTE_UNUSED,
|
|
|
|
const char **models ATTRIBUTE_UNUSED,
|
|
|
|
unsigned int nmodels ATTRIBUTE_UNUSED,
|
|
|
|
unsigned int flags)
|
|
|
|
{
|
|
|
|
virCPUDefPtr cpu = NULL;
|
|
|
|
|
2015-02-05 15:29:52 +01:00
|
|
|
virCheckFlags(VIR_CONNECT_BASELINE_CPU_EXPAND_FEATURES |
|
|
|
|
VIR_CONNECT_BASELINE_CPU_MIGRATABLE, NULL);
|
2014-03-03 17:41:03 +04:00
|
|
|
|
|
|
|
if (VIR_ALLOC(cpu) < 0 ||
|
|
|
|
VIR_STRDUP(cpu->model, cpus[0]->model) < 0) {
|
|
|
|
virCPUDefFree(cpu);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
cpu->type = VIR_CPU_TYPE_GUEST;
|
|
|
|
cpu->match = VIR_CPU_MATCH_EXACT;
|
|
|
|
|
|
|
|
return cpu;
|
|
|
|
}
|
|
|
|
|
2014-05-07 20:38:10 +04:00
|
|
|
static virCPUCompareResult
|
|
|
|
ArmCompare(virCPUDefPtr host ATTRIBUTE_UNUSED,
|
2014-05-28 15:11:57 +02:00
|
|
|
virCPUDefPtr cpu ATTRIBUTE_UNUSED,
|
|
|
|
bool failMessages ATTRIBUTE_UNUSED)
|
2014-05-07 20:38:10 +04:00
|
|
|
{
|
|
|
|
return VIR_CPU_COMPARE_IDENTICAL;
|
|
|
|
}
|
|
|
|
|
2012-07-12 10:28:17 -05:00
|
|
|
struct cpuArchDriver cpuDriverArm = {
|
|
|
|
.name = "arm",
|
|
|
|
.arch = archs,
|
|
|
|
.narch = ARRAY_CARDINALITY(archs),
|
2014-05-07 20:38:10 +04:00
|
|
|
.compare = ArmCompare,
|
2012-07-12 10:28:17 -05:00
|
|
|
.decode = ArmDecode,
|
|
|
|
.encode = NULL,
|
|
|
|
.free = ArmDataFree,
|
|
|
|
.nodeData = ArmNodeData,
|
2014-02-26 20:40:12 +04:00
|
|
|
.guestData = ArmGuestData,
|
2014-03-03 17:41:03 +04:00
|
|
|
.baseline = ArmBaseline,
|
2014-02-26 20:40:12 +04:00
|
|
|
.update = ArmUpdate,
|
2012-07-12 10:28:17 -05:00
|
|
|
.hasFeature = NULL,
|
|
|
|
};
|