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 07/16] cpu: introduce get_arch_id() method and override it for target-i386
Date: Mon, 22 Apr 2013 18:33:48 +0200 [thread overview]
Message-ID: <5175666C.3080808@suse.de> (raw)
In-Reply-To: <1366063976-4909-8-git-send-email-imammedo@redhat.com>
Am 16.04.2013 00:12, schrieb Igor Mammedov:
> get_arch_id() adds possibility for generic code to get guest visible
> CPU ID without accessing CPUArchState. If target doesn't override it,
> it will return cpu_index.
>
> Override it on target-i386 to return APIC ID.
>
> Signed-off-by: Igor Mammedov <imammedo@redhat.com>
> ---
> * it will be used later by new cpu_exists() generic function and
> acpi_piix.
> * s/cpu_firmware_id/cpu_arch_id/
> ---
> include/qom/cpu.h | 2 ++
> qom/cpu.c | 6 ++++++
> target-i386/cpu.c | 10 ++++++++++
> 3 files changed, 18 insertions(+)
Eduardo and me had discussed on IRC that apparently the only reason we
need this generalized "arch_id" is that acpi_piix4 is shared between x86
and mips. Did you investigate whether we can just access the x86 apic-id
property instead for x86 and leave mips as-is without hotplug support?
Andreas
>
> diff --git a/include/qom/cpu.h b/include/qom/cpu.h
> index 6ce6f10..428aaf0 100644
> --- a/include/qom/cpu.h
> +++ b/include/qom/cpu.h
> @@ -45,6 +45,7 @@ typedef struct CPUState CPUState;
> * instantiatable CPU type.
> * @reset: Callback to reset the #CPUState to its initial state.
> * @do_interrupt: Callback for interrupt handling.
> + * @get_arch_id: Callback for getting architecture depended CPU ID
> * @vmsd: State description for migration.
> *
> * Represents a CPU family or model.
> @@ -58,6 +59,7 @@ typedef struct CPUClass {
>
> void (*reset)(CPUState *cpu);
> void (*do_interrupt)(CPUState *cpu);
> + int64_t (*get_arch_id)(CPUState *cpu);
>
> const struct VMStateDescription *vmsd;
> } CPUClass;
> diff --git a/qom/cpu.c b/qom/cpu.c
> index 819986e..a13ddda 100644
> --- a/qom/cpu.c
> +++ b/qom/cpu.c
> @@ -76,6 +76,11 @@ static void cpu_common_realizefn(DeviceState *dev, Error **errp)
> }
> }
>
> +static int64_t cpu_common_get_arch_id(CPUState *cpu)
> +{
> + return cpu->cpu_index;
> +}
> +
> static void cpu_class_init(ObjectClass *klass, void *data)
> {
> DeviceClass *dc = DEVICE_CLASS(klass);
> @@ -83,6 +88,7 @@ static void cpu_class_init(ObjectClass *klass, void *data)
>
> k->class_by_name = cpu_common_class_by_name;
> k->reset = cpu_common_reset;
> + k->get_arch_id = cpu_common_get_arch_id;
> dc->realize = cpu_common_realizefn;
> dc->no_user = 1;
> }
> diff --git a/target-i386/cpu.c b/target-i386/cpu.c
> index e2302d8..a415fa3 100644
> --- a/target-i386/cpu.c
> +++ b/target-i386/cpu.c
> @@ -2272,6 +2272,14 @@ static void x86_cpu_initfn(Object *obj)
> }
> }
>
> +static int64_t x86_cpu_get_arch_id(CPUState *cpu)
> +{
> + X86CPU *x86cpu = X86_CPU(cpu);
> + CPUX86State *env = &x86cpu->env;
> +
> + return env->cpuid_apic_id;
> +}
> +
> static void x86_cpu_common_class_init(ObjectClass *oc, void *data)
> {
> X86CPUClass *xcc = X86_CPU_CLASS(oc);
> @@ -2286,6 +2294,8 @@ static void x86_cpu_common_class_init(ObjectClass *oc, void *data)
>
> cc->do_interrupt = x86_cpu_do_interrupt;
> cpu_class_set_vmsd(cc, &vmstate_x86_cpu);
> +
> + cc->get_arch_id = x86_cpu_get_arch_id;
> }
>
> static const TypeInfo x86_cpu_type_info = {
>
--
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-22 16:33 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 [this message]
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
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=5175666C.3080808@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.