[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH 12/16] target-i386: cpu: attach ICC bus to CPU o
From: |
Andreas Färber |
Subject: |
Re: [Qemu-devel] [PATCH 12/16] target-i386: cpu: attach ICC bus to CPU on its creation |
Date: |
Mon, 22 Apr 2013 17:27:29 +0200 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:17.0) Gecko/20130329 Thunderbird/17.0.5 |
Am 22.04.2013 17:20, schrieb Igor Mammedov:
> On Mon, 22 Apr 2013 17:02:33 +0200
> Andreas Färber <address@hidden> wrote:
>
>> Am 16.04.2013 00:12, schrieb Igor Mammedov:
>>> ... during startup, so it would be possible to unplug it later
>>> and set bus_type to TYPE_ICC_BUS for X86CPU type to make device_add
>>> attach hotplugged CPU to ICC bus.
>>>
>>> Signed-off-by: Igor Mammedov <address@hidden>
>>
>> Reviewed-by: Andreas Färber <address@hidden>
>>
>> But still one question...
>>
>>> ---
>>> target-i386/cpu.c | 7 +++++++
>>> 1 file changed, 7 insertions(+)
>>>
>>> diff --git a/target-i386/cpu.c b/target-i386/cpu.c
>>> index 6d6c527..3b5f90b 100644
>>> --- a/target-i386/cpu.c
>>> +++ b/target-i386/cpu.c
>>> @@ -41,6 +41,7 @@
>>> #endif
>>>
>>> #include "sysemu/sysemu.h"
>>> +#include "hw/i386/icc_bus.h"
>>> #ifndef CONFIG_USER_ONLY
>>> #include "hw/xen/xen.h"
>>> #include "hw/sysbus.h"
>>> @@ -1609,6 +1610,7 @@ X86CPU *cpu_x86_create(const char *cpu_model, Error
>>> **errp) gchar **model_pieces;
>>> char *name, *features;
>>> Error *error = NULL;
>>> + Object *icc_bus = object_resolve_path_type("icc-bus", TYPE_ICC_BUS,
>>> NULL);
>>> model_pieces = g_strsplit(cpu_model, ",", 2);
>>> if (!model_pieces[0]) {
>>> @@ -1619,6 +1621,10 @@ X86CPU *cpu_x86_create(const char *cpu_model,
>>> Error **errp) features = model_pieces[1];
>>>
>>> cpu = X86_CPU(object_new(TYPE_X86_CPU));
>>> + if (icc_bus) {
>>> + qdev_set_parent_bus(DEVICE(cpu), BUS(icc_bus));
>>> + object_unref(OBJECT(cpu));
>>> + }
>>> env = &cpu->env;
>>> env->cpu_model_str = cpu_model;
>>>
>>
>> You seem to be avoiding making lack of icc-bus an error although you add
>> it for both PC and q35 PC - which non-ICC use cases are you thinking of?
> *-user targets, CPU is bus-less there.
Would you be opposed to #ifdef'ing it then? In particular I am asking
because of the NULL error argument to the resolve function - for softmmu
I would prefer to make lack of icc-bus a fatal error.
Andreas
--
SUSE LINUX Products GmbH, Maxfeldstr. 5, 90409 Nürnberg, Germany
GF: Jeff Hawn, Jennifer Guild, Felix Imendörffer; HRB 16746 AG Nürnberg
- Re: [Qemu-devel] [PATCH 10/16] target-i386: introduce apic-id property, (continued)
[Qemu-devel] [PATCH 13/16] target-i386: replace MSI_SPACE_SIZE with APIC_SPACE_SIZE, Igor Mammedov, 2013/04/15
[Qemu-devel] [PATCH 14/16] target-i386: move APIC to ICC bus, Igor Mammedov, 2013/04/15
[Qemu-devel] [PATCH 15/16] target-i386: move IOAPIC to ICC bus, Igor Mammedov, 2013/04/15
[Qemu-devel] [PATCH 16/16] add cpu-add qmp command and implement CPU hot-add for target-i386, Igor Mammedov, 2013/04/15