From: "Andreas Färber" <afaerber@suse.de>
To: Igor Mammedov <imammedo@redhat.com>
Cc: aliguori@us.ibm.com, ehabkost@redhat.com, mst@redhat.com,
jan.kiszka@siemens.com, claudio.fontana@huawei.com,
qemu-devel@nongnu.org, aderumier@odiso.com,
lcapitulino@redhat.com, jfrei@linux.vnet.ibm.com,
yang.z.zhang@intel.com, pbonzini@redhat.com,
lig.fnst@cn.fujitsu.com, rth@twiddle.net
Subject: Re: [Qemu-devel] [PATCH 10/16] target-i386: introduce apic-id property
Date: Fri, 26 Apr 2013 18:35:42 +0200 [thread overview]
Message-ID: <517AACDE.5080200@suse.de> (raw)
In-Reply-To: <20130422183059.0ec7e482@nial.usersys.redhat.com>
Am 22.04.2013 18:30, schrieb Igor Mammedov:
> On Mon, 22 Apr 2013 16:05:34 +0200
> Andreas Färber <afaerber@suse.de> wrote:
>
>> Am 16.04.2013 00:12, schrieb Igor Mammedov:
>>> ... and use it from board level to set APIC ID for CPUs
>>> it creates.
>>>
>>> Signed-off-by: Igor Mammedov <imammedo@redhat.com>
>>> Reviewed-by: Paolo Bonzini <pbonzini@redhat.com>
>>> ---
>>> Note:
>>> * pc_new_cpu() function will be reused later in CPU hot-plug hook.
>>
>> Suggest as main commit message to avoid the "...":
>>
>> The property is used from board level to set APIC ID for CPUs it
>> creates. Do so in a new pc_new_cpu() helper, to be reused for hot-plug.
> I'll do on next respin.
>
>>>
>>> v3:
>>> * user error_propagate() in property setter
>>> v2:
>>> * use generic cpu_exists() instead of custom one
>>> * make apic-id dynamic property, so it won't be possible to use it
>>> as global property, since it's instance specific
>>> ---
>>> hw/i386/pc.c | 25 ++++++++++++++++++++++++-
>>> target-i386/cpu.c | 42 ++++++++++++++++++++++++++++++++++++++++++
>>> 2 files changed, 66 insertions(+), 1 deletion(-)
>>>
>>> diff --git a/hw/i386/pc.c b/hw/i386/pc.c
>>> index dc1a78b..cb57878 100644
>>> --- a/hw/i386/pc.c
>>> +++ b/hw/i386/pc.c
>>> @@ -889,9 +889,29 @@ void pc_acpi_smi_interrupt(void *opaque, int irq,
>>> int level) }
>>> }
>>>
>>> +static void pc_new_cpu(const char *cpu_model, int64_t apic_id, Error
>>> **errp) +{
>>> + X86CPU *cpu;
>>> +
>>> + cpu = cpu_x86_create(cpu_model, errp);
>>> + if (!cpu) {
>>> + return;
>>> + }
>>> +
>>> + object_property_set_int(OBJECT(cpu), apic_id, "apic-id", errp);
>>> + object_property_set_bool(OBJECT(cpu), true, "realized", errp);
>>> +
>>> + if (error_is_set(errp)) {
>>
>> Please use a local Error* variable with error_propagate, otherwise this
>> is fragile.
> done
>
>>
>>> + if (cpu != NULL) {
>>> + object_unref(OBJECT(cpu));
>>> + }
>>> + }
>>> +}
>>> +
>>> void pc_cpus_init(const char *cpu_model)
>>> {
>>> int i;
>>> + Error *error = NULL;
>>>
>>> /* init CPUs */
>>> if (cpu_model == NULL) {
>>> @@ -903,7 +923,10 @@ void pc_cpus_init(const char *cpu_model)
>>> }
>>>
>>> for (i = 0; i < smp_cpus; i++) {
>>> - if (!cpu_x86_init(cpu_model)) {
>>> + pc_new_cpu(cpu_model, x86_cpu_apic_id_from_index(i), &error);
>>> + if (error) {
>>> + fprintf(stderr, "%s\n", error_get_pretty(error));
>>> + error_free(error);
>>> exit(1);
>>> }
>>> }
>>> diff --git a/target-i386/cpu.c b/target-i386/cpu.c
>>> index a415fa3..6d6c527 100644
>>> --- a/target-i386/cpu.c
>>> +++ b/target-i386/cpu.c
>>> @@ -1271,6 +1271,45 @@ static void x86_cpuid_set_tsc_freq(Object *obj,
>>> Visitor *v, void *opaque, cpu->env.tsc_khz = value / 1000;
>>> }
>>>
>>> +static void x86_cpuid_get_apic_id(Object *obj, Visitor *v, void *opaque,
>>> + const char *name, Error **errp)
>>> +{
>>> + X86CPU *cpu = X86_CPU(obj);
>>> + int64_t value = cpu->env.cpuid_apic_id;
>>> +
>>> + visit_type_int(v, &value, name, errp);
>>> +}
>>> +
>>> +static void x86_cpuid_set_apic_id(Object *obj, Visitor *v, void *opaque,
>>> + const char *name, Error **errp)
>>> +{
>>> + X86CPU *cpu = X86_CPU(obj);
>>> + const int64_t min = 0;
>>> + const int64_t max = UINT32_MAX;
>>> + Error *error = NULL;
>>> + int64_t value;
>>> +
>>> + visit_type_int(v, &value, name, &error);
>>> + if (error) {
>>> + error_propagate(errp, error);
>>> + return;
>>> + }
>>
>>> + if (value < min || value > max) {
>>> + error_setg(&error, "Property %s.%s doesn't take value %" PRId64
>>> + " (minimum: %" PRId64 ", maximum: %" PRId64 ")" ,
>>> + object_get_typename(obj), name, value, min, max);
>>> + error_propagate(errp, error);
>>> + return;
>>> + }
>>> +
>>> + if (cpu_exists(value)) {
>>> + error_setg(&error, "CPU with APIC ID %" PRIi64 " exists", value);
>>> + error_propagate(errp, error);
>>
>> You could do both error_setg()s directly on errp.
> it was so before, but I was requested to use local error here:
> http://lists.gnu.org/archive/html/qemu-devel/2013-04/msg01606.html
The only thing Paolo requested there (and which I +1) is not to do
error_is_set(errp). That is independent of error_setg() though, which is
followed by a return, so has no functional difference.
Andreas
>
>>
>>> + return;
>>> + }
>>> + cpu->env.cpuid_apic_id = value;
>>> +}
>>> +
>>> static int cpu_x86_find_by_name(x86_def_t *x86_cpu_def, const char *name)
>>> {
>>> x86_def_t *def;
>>> @@ -2259,6 +2298,9 @@ static void x86_cpu_initfn(Object *obj)
>>> object_property_add(obj, "tsc-frequency", "int",
>>> x86_cpuid_get_tsc_freq,
>>> x86_cpuid_set_tsc_freq, NULL, NULL, NULL);
>>> + object_property_add(obj, "apic-id", "int",
>>> + x86_cpuid_get_apic_id,
>>> + x86_cpuid_set_apic_id, NULL, NULL, NULL);
>>>
>>> env->cpuid_apic_id = x86_cpu_apic_id_from_index(cs->cpu_index);
>>>
>>
>> Otherwise I like this x86-specific version now!
>>
>> Andreas
>>
>
>
--
SUSE LINUX Products GmbH, Maxfeldstr. 5, 90409 Nürnberg, Germany
GF: Jeff Hawn, Jennifer Guild, Felix Imendörffer; HRB 16746 AG Nürnberg
next prev parent reply other threads:[~2013-04-26 16:35 UTC|newest]
Thread overview: 73+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-04-15 22:12 [Qemu-devel] [PATCH 00/16 v4] target-i386: CPU hot-add with cpu-add QMP command Igor Mammedov
2013-04-15 22:12 ` [Qemu-devel] [PATCH 01/16] cpu: make kvm-stub.o a part of CPU library Igor Mammedov
[not found] ` <20130417185844.GA11821@otherpad.lan.raisama.net>
2013-04-17 22:26 ` Paolo Bonzini
2013-04-18 4:23 ` [Qemu-devel] [PATCH 01/16 v2] " Igor Mammedov
2013-04-18 14:24 ` Eduardo Habkost
2013-04-22 13:45 ` Andreas Färber
2013-04-22 14:35 ` Paolo Bonzini
2013-04-22 16:29 ` Gleb Natapov
2013-04-15 22:12 ` [Qemu-devel] [PATCH 02/16] cpu: call cpu_synchronize_post_init() from CPUClass.realize() if hotplugged Igor Mammedov
2013-04-18 17:03 ` Eduardo Habkost
2013-04-22 13:46 ` Andreas Färber
2013-04-22 16:30 ` Gleb Natapov
2013-04-15 22:12 ` [Qemu-devel] [PATCH 03/16] introduce resume_vcpu(), for single CPU Igor Mammedov
2013-04-18 17:04 ` Eduardo Habkost
2013-04-22 10:40 ` Gleb Natapov
2013-04-22 10:54 ` Igor Mammedov
2013-04-22 10:59 ` Gleb Natapov
2013-04-22 11:45 ` Igor Mammedov
2013-04-22 12:34 ` Gleb Natapov
2013-04-22 13:42 ` Andreas Färber
2013-04-22 14:50 ` Igor Mammedov
2013-04-22 14:59 ` Andreas Färber
2013-04-15 22:12 ` [Qemu-devel] [PATCH 04/16] cpu: resume CPU from CPUClass.cpu_common_realizefn() when it is hot-plugged Igor Mammedov
2013-04-18 17:04 ` Eduardo Habkost
2013-04-15 22:12 ` [Qemu-devel] [PATCH 05/16] introduce CPU hot-plug notifier Igor Mammedov
2013-04-22 11:00 ` Gleb Natapov
2013-04-22 11:09 ` Igor Mammedov
2013-04-22 11:24 ` Gleb Natapov
2013-04-22 20:01 ` Igor Mammedov
2013-04-15 22:12 ` [Qemu-devel] [PATCH 06/16] target-i386: pc: update rtc_cmos on CPU hot-plug Igor Mammedov
2013-04-18 17:09 ` Eduardo Habkost
2013-04-22 14:56 ` Andreas Färber
2013-04-22 15:18 ` Igor Mammedov
2013-04-15 22:12 ` [Qemu-devel] [PATCH 07/16] cpu: introduce get_arch_id() method and override it for target-i386 Igor Mammedov
2013-04-18 17:10 ` Eduardo Habkost
2013-04-19 0:05 ` li guang
2013-04-22 9:42 ` Michael S. Tsirkin
2013-04-22 16:33 ` Andreas Färber
2013-04-22 19:10 ` Igor Mammedov
2013-04-15 22:12 ` [Qemu-devel] [PATCH 08/16] cpu: add helper cpu_exists(), to check if CPU with specified id exists Igor Mammedov
2013-04-22 10:28 ` Michael S. Tsirkin
2013-04-22 10:45 ` Igor Mammedov
2013-04-22 11:15 ` Andreas Färber
2013-04-15 22:12 ` [Qemu-devel] [PATCH 09/16] acpi_piix4: add infrastructure to send CPU hot-plug GPE to guest Igor Mammedov
2013-04-22 9:55 ` Michael S. Tsirkin
2013-04-15 22:12 ` [Qemu-devel] [PATCH 10/16] target-i386: introduce apic-id property Igor Mammedov
2013-04-22 9:49 ` Michael S. Tsirkin
2013-04-22 14:05 ` Andreas Färber
2013-04-22 16:30 ` Igor Mammedov
2013-04-26 16:35 ` Andreas Färber [this message]
2013-04-15 22:12 ` [Qemu-devel] [PATCH 11/16] introduce ICC bus/device/bridge Igor Mammedov
2013-04-22 11:39 ` Peter Maydell
2013-04-22 12:27 ` Paolo Bonzini
2013-04-22 13:22 ` Andreas Färber
2013-04-22 15:08 ` Igor Mammedov
2013-04-15 22:12 ` [Qemu-devel] [PATCH 12/16] target-i386: cpu: attach ICC bus to CPU on its creation Igor Mammedov
2013-04-22 15:02 ` Andreas Färber
2013-04-22 15:20 ` Igor Mammedov
2013-04-22 15:27 ` Andreas Färber
2013-04-22 19:14 ` Igor Mammedov
2013-04-15 22:12 ` [Qemu-devel] [PATCH 13/16] target-i386: replace MSI_SPACE_SIZE with APIC_SPACE_SIZE Igor Mammedov
2013-04-22 15:03 ` Andreas Färber
2013-04-15 22:12 ` [Qemu-devel] [PATCH 14/16] target-i386: move APIC to ICC bus Igor Mammedov
2013-04-22 15:18 ` Andreas Färber
2013-04-22 15:59 ` Igor Mammedov
2013-04-15 22:12 ` [Qemu-devel] [PATCH 15/16] target-i386: move IOAPIC " Igor Mammedov
2013-04-15 22:12 ` [Qemu-devel] [PATCH 16/16] add cpu-add qmp command and implement CPU hot-add for target-i386 Igor Mammedov
2013-04-15 22:20 ` Eric Blake
2013-04-16 20:04 ` Igor Mammedov
2013-04-23 16:17 ` Eric Blake
2013-04-16 8:30 ` [Qemu-devel] [PATCH 00/16 v4] target-i386: CPU hot-add with cpu-add QMP command Jan Kiszka
2013-04-16 9:43 ` Igor Mammedov
2013-04-16 13:49 ` Eduardo Habkost
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=517AACDE.5080200@suse.de \
--to=afaerber@suse.de \
--cc=aderumier@odiso.com \
--cc=aliguori@us.ibm.com \
--cc=claudio.fontana@huawei.com \
--cc=ehabkost@redhat.com \
--cc=imammedo@redhat.com \
--cc=jan.kiszka@siemens.com \
--cc=jfrei@linux.vnet.ibm.com \
--cc=lcapitulino@redhat.com \
--cc=lig.fnst@cn.fujitsu.com \
--cc=mst@redhat.com \
--cc=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=rth@twiddle.net \
--cc=yang.z.zhang@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.