提交 1c30044e 编写于 作者: M Marc-André Lureau

compat: replace PC_COMPAT_2_2 & HW_COMPAT_2_2 macros

Use static arrays instead.  I decided to rename the conflicting
pc_compat_2_2() function with pc_compat_2_2_fn().
Suggested-by: NEduardo Habkost <ehabkost@redhat.com>
Signed-off-by: NMarc-André Lureau <marcandre.lureau@redhat.com>
Reviewed-by: NIgor Mammedov <imammedo@redhat.com>
Reviewed-by: NCornelia Huck <cohuck@redhat.com>
Acked-by: NEduardo Habkost <ehabkost@redhat.com>
上级 8995dd90
...@@ -306,6 +306,9 @@ GlobalProperty hw_compat_2_3[] = { ...@@ -306,6 +306,9 @@ GlobalProperty hw_compat_2_3[] = {
}; };
const size_t hw_compat_2_3_len = G_N_ELEMENTS(hw_compat_2_3); const size_t hw_compat_2_3_len = G_N_ELEMENTS(hw_compat_2_3);
GlobalProperty hw_compat_2_2[] = {};
const size_t hw_compat_2_2_len = G_N_ELEMENTS(hw_compat_2_2);
static char *machine_get_accel(Object *obj, Error **errp) static char *machine_get_accel(Object *obj, Error **errp)
{ {
MachineState *ms = MACHINE(obj); MachineState *ms = MACHINE(obj);
......
...@@ -441,6 +441,101 @@ GlobalProperty pc_compat_2_3[] = { ...@@ -441,6 +441,101 @@ GlobalProperty pc_compat_2_3[] = {
}; };
const size_t pc_compat_2_3_len = G_N_ELEMENTS(pc_compat_2_3); const size_t pc_compat_2_3_len = G_N_ELEMENTS(pc_compat_2_3);
GlobalProperty pc_compat_2_2[] = {
PC_CPU_MODEL_IDS("2.2.0")
{
.driver = "kvm64" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "kvm32" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Conroe" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Penryn" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Nehalem" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Westmere" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "SandyBridge" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Haswell" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Broadwell" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Opteron_G1" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Opteron_G2" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Opteron_G3" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Opteron_G4" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Opteron_G5" "-" TYPE_X86_CPU,
.property = "vme",
.value = "off",
},
{
.driver = "Haswell" "-" TYPE_X86_CPU,
.property = "f16c",
.value = "off",
},
{
.driver = "Haswell" "-" TYPE_X86_CPU,
.property = "rdrand",
.value = "off",
},
{
.driver = "Broadwell" "-" TYPE_X86_CPU,
.property = "f16c",
.value = "off",
},
{
.driver = "Broadwell" "-" TYPE_X86_CPU,
.property = "rdrand",
.value = "off",
},
};
const size_t pc_compat_2_2_len = G_N_ELEMENTS(pc_compat_2_2);
void gsi_handler(void *opaque, int n, int level) void gsi_handler(void *opaque, int n, int level)
{ {
GSIState *s = opaque; GSIState *s = opaque;
......
...@@ -318,14 +318,14 @@ static void pc_compat_2_3_fn(MachineState *machine) ...@@ -318,14 +318,14 @@ static void pc_compat_2_3_fn(MachineState *machine)
} }
} }
static void pc_compat_2_2(MachineState *machine) static void pc_compat_2_2_fn(MachineState *machine)
{ {
pc_compat_2_3_fn(machine); pc_compat_2_3_fn(machine);
} }
static void pc_compat_2_1(MachineState *machine) static void pc_compat_2_1(MachineState *machine)
{ {
pc_compat_2_2(machine); pc_compat_2_2_fn(machine);
x86_cpu_change_kvm_default("svm", NULL); x86_cpu_change_kvm_default("svm", NULL);
} }
...@@ -578,18 +578,16 @@ DEFINE_I440FX_MACHINE(v2_3, "pc-i440fx-2.3", pc_compat_2_3_fn, ...@@ -578,18 +578,16 @@ DEFINE_I440FX_MACHINE(v2_3, "pc-i440fx-2.3", pc_compat_2_3_fn,
static void pc_i440fx_2_2_machine_options(MachineClass *m) static void pc_i440fx_2_2_machine_options(MachineClass *m)
{ {
PCMachineClass *pcmc = PC_MACHINE_CLASS(m); PCMachineClass *pcmc = PC_MACHINE_CLASS(m);
static GlobalProperty compat[] = {
PC_COMPAT_2_2
};
pc_i440fx_2_3_machine_options(m); pc_i440fx_2_3_machine_options(m);
m->hw_version = "2.2.0"; m->hw_version = "2.2.0";
m->default_machine_opts = "firmware=bios-256k.bin,suppress-vmdesc=on"; m->default_machine_opts = "firmware=bios-256k.bin,suppress-vmdesc=on";
compat_props_add(m->compat_props, compat, G_N_ELEMENTS(compat)); compat_props_add(m->compat_props, hw_compat_2_2, hw_compat_2_2_len);
compat_props_add(m->compat_props, pc_compat_2_2, pc_compat_2_2_len);
pcmc->rsdp_in_ram = false; pcmc->rsdp_in_ram = false;
} }
DEFINE_I440FX_MACHINE(v2_2, "pc-i440fx-2.2", pc_compat_2_2, DEFINE_I440FX_MACHINE(v2_2, "pc-i440fx-2.2", pc_compat_2_2_fn,
pc_i440fx_2_2_machine_options); pc_i440fx_2_2_machine_options);
static void pc_i440fx_2_1_machine_options(MachineClass *m) static void pc_i440fx_2_1_machine_options(MachineClass *m)
......
...@@ -4341,7 +4341,6 @@ DEFINE_SPAPR_MACHINE(2_3, "2.3", false); ...@@ -4341,7 +4341,6 @@ DEFINE_SPAPR_MACHINE(2_3, "2.3", false);
static void spapr_machine_2_2_class_options(MachineClass *mc) static void spapr_machine_2_2_class_options(MachineClass *mc)
{ {
static GlobalProperty compat[] = { static GlobalProperty compat[] = {
HW_COMPAT_2_2
{ {
.driver = TYPE_SPAPR_PCI_HOST_BRIDGE, .driver = TYPE_SPAPR_PCI_HOST_BRIDGE,
.property = "mem_win_size", .property = "mem_win_size",
...@@ -4350,6 +4349,7 @@ static void spapr_machine_2_2_class_options(MachineClass *mc) ...@@ -4350,6 +4349,7 @@ static void spapr_machine_2_2_class_options(MachineClass *mc)
}; };
spapr_machine_2_3_class_options(mc); spapr_machine_2_3_class_options(mc);
compat_props_add(mc->compat_props, hw_compat_2_2, hw_compat_2_2_len);
compat_props_add(mc->compat_props, compat, G_N_ELEMENTS(compat)); compat_props_add(mc->compat_props, compat, G_N_ELEMENTS(compat));
mc->default_machine_opts = "modern-hotplug-events=off,suppress-vmdesc=on"; mc->default_machine_opts = "modern-hotplug-events=off,suppress-vmdesc=on";
} }
......
...@@ -324,4 +324,7 @@ extern const size_t hw_compat_2_4_len; ...@@ -324,4 +324,7 @@ extern const size_t hw_compat_2_4_len;
extern GlobalProperty hw_compat_2_3[]; extern GlobalProperty hw_compat_2_3[];
extern const size_t hw_compat_2_3_len; extern const size_t hw_compat_2_3_len;
extern GlobalProperty hw_compat_2_2[];
extern const size_t hw_compat_2_2_len;
#endif #endif
#ifndef HW_COMPAT_H #ifndef HW_COMPAT_H
#define HW_COMPAT_H #define HW_COMPAT_H
#define HW_COMPAT_2_2 \
/* empty */
#define HW_COMPAT_2_1 \ #define HW_COMPAT_2_1 \
{\ {\
.driver = "intel-hda",\ .driver = "intel-hda",\
......
...@@ -330,6 +330,9 @@ extern const size_t pc_compat_2_4_len; ...@@ -330,6 +330,9 @@ extern const size_t pc_compat_2_4_len;
extern GlobalProperty pc_compat_2_3[]; extern GlobalProperty pc_compat_2_3[];
extern const size_t pc_compat_2_3_len; extern const size_t pc_compat_2_3_len;
extern GlobalProperty pc_compat_2_2[];
extern const size_t pc_compat_2_2_len;
/* Helper for setting model-id for CPU models that changed model-id /* Helper for setting model-id for CPU models that changed model-id
* depending on QEMU versions up to QEMU 2.4. * depending on QEMU versions up to QEMU 2.4.
*/ */
...@@ -350,100 +353,6 @@ extern const size_t pc_compat_2_3_len; ...@@ -350,100 +353,6 @@ extern const size_t pc_compat_2_3_len;
.value = "QEMU Virtual CPU version " v,\ .value = "QEMU Virtual CPU version " v,\
}, },
#define PC_COMPAT_2_2 \
HW_COMPAT_2_2 \
PC_CPU_MODEL_IDS("2.2.0") \
{\
.driver = "kvm64" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "kvm32" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Conroe" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Penryn" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Nehalem" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Westmere" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "SandyBridge" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Haswell" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Broadwell" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Opteron_G1" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Opteron_G2" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Opteron_G3" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Opteron_G4" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Opteron_G5" "-" TYPE_X86_CPU,\
.property = "vme",\
.value = "off",\
},\
{\
.driver = "Haswell" "-" TYPE_X86_CPU,\
.property = "f16c",\
.value = "off",\
},\
{\
.driver = "Haswell" "-" TYPE_X86_CPU,\
.property = "rdrand",\
.value = "off",\
},\
{\
.driver = "Broadwell" "-" TYPE_X86_CPU,\
.property = "f16c",\
.value = "off",\
},\
{\
.driver = "Broadwell" "-" TYPE_X86_CPU,\
.property = "rdrand",\
.value = "off",\
},
#define PC_COMPAT_2_1 \ #define PC_COMPAT_2_1 \
HW_COMPAT_2_1 \ HW_COMPAT_2_1 \
PC_CPU_MODEL_IDS("2.1.0") \ PC_CPU_MODEL_IDS("2.1.0") \
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册