target-ppc: Register all types for TARGET_PPCEMB

Don't attempt to suppress registration of CPU types, since the criteria
is actually a property of the class and should thus become a field.
Since we can't check a field set in a class_init function before
registering the type that leads to execution of that function, guard the
-cpu class lookup instead and suppress exposing these classes in -cpu ?
and in QMP.

In case someone tries to hot-add an incompatible CPU via device_add,
error out in realize.

Signed-off-by: Andreas Färber <afaerber@suse.de>
Signed-off-by: Alexander Graf <agraf@suse.de>
This commit is contained in:
Andreas Färber 2013-02-17 23:16:44 +00:00 committed by Alexander Graf
parent 53116ebfc9
commit 4d7fb187e0

View File

@ -7876,14 +7876,6 @@ enum {
/* PowerPC CPU definitions */ /* PowerPC CPU definitions */
#define POWERPC_DEF_PREFIX(pvr, svr, type) \ #define POWERPC_DEF_PREFIX(pvr, svr, type) \
glue(glue(glue(glue(pvr, _), svr), _), type) glue(glue(glue(glue(pvr, _), svr), _), type)
#if defined(TARGET_PPCEMB)
#define POWERPC_DEF_CONDITION(type) \
if (glue(POWERPC_MMU_, type) != POWERPC_MMU_BOOKE) { \
return; \
}
#else
#define POWERPC_DEF_CONDITION(type)
#endif
#define POWERPC_DEF_SVR(_name, _pvr, _svr, _type) \ #define POWERPC_DEF_SVR(_name, _pvr, _svr, _type) \
static void \ static void \
glue(POWERPC_DEF_PREFIX(_pvr, _svr, _type), _cpu_class_init) \ glue(POWERPC_DEF_PREFIX(_pvr, _svr, _type), _cpu_class_init) \
@ -7912,7 +7904,6 @@ enum {
static void \ static void \
glue(POWERPC_DEF_PREFIX(_pvr, _svr, _type), _cpu_register_types)(void) \ glue(POWERPC_DEF_PREFIX(_pvr, _svr, _type), _cpu_register_types)(void) \
{ \ { \
POWERPC_DEF_CONDITION(_type) \
type_register_static( \ type_register_static( \
&glue(POWERPC_DEF_PREFIX(_pvr, _svr, _type), _cpu_type_info)); \ &glue(POWERPC_DEF_PREFIX(_pvr, _svr, _type), _cpu_type_info)); \
} \ } \
@ -10040,6 +10031,15 @@ static void ppc_cpu_realizefn(DeviceState *dev, Error **errp)
} }
} }
#if defined(TARGET_PPCEMB)
if (pcc->mmu_model != POWERPC_MMU_BOOKE) {
error_setg(errp, "CPU does not possess a BookE MMU. "
"Please use qemu-system-ppc or qemu-system-ppc64 instead "
"or choose another CPU model.");
return;
}
#endif
create_ppc_opcodes(cpu, &local_err); create_ppc_opcodes(cpu, &local_err);
if (local_err != NULL) { if (local_err != NULL) {
error_propagate(errp, local_err); error_propagate(errp, local_err);
@ -10239,6 +10239,12 @@ static gint ppc_cpu_compare_class_pvr(gconstpointer a, gconstpointer b)
return -1; return -1;
} }
#if defined(TARGET_PPCEMB)
if (pcc->mmu_model != POWERPC_MMU_BOOKE) {
return -1;
}
#endif
return pcc->pvr == pvr ? 0 : -1; return pcc->pvr == pvr ? 0 : -1;
} }
@ -10261,8 +10267,14 @@ static gint ppc_cpu_compare_class_name(gconstpointer a, gconstpointer b)
{ {
ObjectClass *oc = (ObjectClass *)a; ObjectClass *oc = (ObjectClass *)a;
const char *name = b; const char *name = b;
#if defined(TARGET_PPCEMB)
PowerPCCPUClass *pcc = POWERPC_CPU_CLASS(oc);
#endif
if (strncasecmp(name, object_class_get_name(oc), strlen(name)) == 0 && if (strncasecmp(name, object_class_get_name(oc), strlen(name)) == 0 &&
#if defined(TARGET_PPCEMB)
pcc->mmu_model == POWERPC_MMU_BOOKE &&
#endif
strcmp(object_class_get_name(oc) + strlen(name), strcmp(object_class_get_name(oc) + strlen(name),
"-" TYPE_POWERPC_CPU) == 0) { "-" TYPE_POWERPC_CPU) == 0) {
return 0; return 0;
@ -10381,6 +10393,12 @@ static void ppc_cpu_list_entry(gpointer data, gpointer user_data)
const char *typename = object_class_get_name(oc); const char *typename = object_class_get_name(oc);
char *name; char *name;
#if defined(TARGET_PPCEMB)
if (pcc->mmu_model != POWERPC_MMU_BOOKE) {
return;
}
#endif
name = g_strndup(typename, name = g_strndup(typename,
strlen(typename) - strlen("-" TYPE_POWERPC_CPU)); strlen(typename) - strlen("-" TYPE_POWERPC_CPU));
(*s->cpu_fprintf)(s->file, "PowerPC %-16s PVR %08x\n", (*s->cpu_fprintf)(s->file, "PowerPC %-16s PVR %08x\n",
@ -10421,6 +10439,13 @@ static void ppc_cpu_defs_entry(gpointer data, gpointer user_data)
const char *typename; const char *typename;
CpuDefinitionInfoList *entry; CpuDefinitionInfoList *entry;
CpuDefinitionInfo *info; CpuDefinitionInfo *info;
#if defined(TARGET_PPCEMB)
PowerPCCPUClass *pcc = POWERPC_CPU_CLASS(oc);
if (pcc->mmu_model != POWERPC_MMU_BOOKE) {
return;
}
#endif
typename = object_class_get_name(oc); typename = object_class_get_name(oc);
info = g_malloc0(sizeof(*info)); info = g_malloc0(sizeof(*info));