From: Marcel Apfelbaum <marcel.apfelbaum@gmail.com>
To: Eduardo Habkost <ehabkost@redhat.com>, marcel@redhat.com
Cc: Igor Mammedov <imammedo@redhat.com>,
Marcel Apfelbaum <marcel.a@redhat.com>,
qemu-devel@nongnu.org, "Michael S. Tsirkin" <mst@redhat.com>
Subject: Re: [Qemu-devel] [PATCH 06/16] acpi: Save PCMachineState on AcpiBuildState
Date: Tue, 8 Dec 2015 20:44:38 +0200 [thread overview]
Message-ID: <56672516.3020809@gmail.com> (raw)
In-Reply-To: <20151208175927.GN14490@thinpad.lan.raisama.net>
On 12/08/2015 07:59 PM, Eduardo Habkost wrote:
> On Mon, Dec 07, 2015 at 05:39:29PM +0200, Marcel Apfelbaum wrote:
>> On 12/02/2015 03:47 AM, Eduardo Habkost wrote:
>>> PCMachineState will be used in some of the steps of ACPI table
>>> building.
>>>
>>> Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
>>> ---
>>> hw/i386/acpi-build.c | 8 ++++----
>>> 1 file changed, 4 insertions(+), 4 deletions(-)
>>>
>>> diff --git a/hw/i386/acpi-build.c b/hw/i386/acpi-build.c
>>> index 85a5c53..ca11c88 100644
>>> --- a/hw/i386/acpi-build.c
>>> +++ b/hw/i386/acpi-build.c
>>> @@ -1644,7 +1644,7 @@ struct AcpiBuildState {
>>> MemoryRegion *table_mr;
>>> /* Is table patched? */
>>> uint8_t patched;
>>> - PcGuestInfo *guest_info;
>>> + PCMachineState *pcms;
>>> void *rsdp;
>>> MemoryRegion *rsdp_mr;
>>> MemoryRegion *linker_mr;
>>> @@ -1855,7 +1855,7 @@ static void acpi_build_update(void *build_opaque, uint32_t offset)
>>>
>>> acpi_build_tables_init(&tables);
>>>
>>> - acpi_build(build_state->guest_info, &tables);
>>> + acpi_build(&build_state->pcms->acpi_guest_info, &tables);
>>>
>>> acpi_ram_update(build_state->table_mr, tables.table_data);
>>>
>>> @@ -1916,12 +1916,12 @@ void acpi_setup(PCMachineState *pcms)
>>>
>>> build_state = g_malloc0(sizeof *build_state);
>>>
>>> - build_state->guest_info = guest_info;
>>> + build_state->pcms = pcms;
>>
>> I am not "sold" on keeping a reference to machine in the build_state.
>> We can always query current machine using qdev_machine() or something.
>>
>> Keeping the "guest info" made sense since is used especially for ACPI,
>> however the machine has a wider scope. (And not having to keep it
>> around is a very good thing!)
>
> I wouldn't mind using qdev_get_machine() if preferred by the
> maintainer of that code, but I like to avoid it when possible. To
> me, qdev_get_machine() is just a global variable disguised as a
> harder-to-understand API.
Really? Hmm, for me is looking like the other way around :)
I see it as "query the QOM tree", instead of "keep the reference around" everywhere.
But it may be just a personal preference.
Thanks,
Marcel
>
next prev parent reply other threads:[~2015-12-08 18:44 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-12-02 1:46 [Qemu-devel] [PATCH 00/16] pc: Eliminate struct PcGuestInfo Eduardo Habkost
2015-12-02 1:46 ` [Qemu-devel] [PATCH 01/16] pc: Move PcGuestInfo declaration to top of file Eduardo Habkost
2015-12-02 1:46 ` [Qemu-devel] [PATCH 02/16] pc: Eliminate struct PcGuestInfoState Eduardo Habkost
2015-12-07 15:19 ` Marcel Apfelbaum
2015-12-02 1:46 ` [Qemu-devel] [PATCH 03/16] pc: Remove guest_info parameter from pc_memory_init() Eduardo Habkost
2015-12-02 1:46 ` [Qemu-devel] [PATCH 04/16] acpi: Make acpi_setup() get PCMachineState as argument Eduardo Habkost
2015-12-07 15:24 ` Marcel Apfelbaum
2015-12-08 17:40 ` Eduardo Habkost
2015-12-02 1:47 ` [Qemu-devel] [PATCH 05/16] acpi: Remove unused build_facs() PcGuestInfo paramter Eduardo Habkost
2015-12-07 15:25 ` Marcel Apfelbaum
2015-12-02 1:47 ` [Qemu-devel] [PATCH 06/16] acpi: Save PCMachineState on AcpiBuildState Eduardo Habkost
2015-12-07 15:39 ` Marcel Apfelbaum
2015-12-08 17:59 ` Eduardo Habkost
2015-12-08 18:44 ` Marcel Apfelbaum [this message]
2015-12-09 19:37 ` Igor Mammedov
2015-12-11 14:12 ` Eduardo Habkost
2015-12-02 1:47 ` [Qemu-devel] [PATCH 07/16] acpi: Make acpi_build() get PCMachineState as argument Eduardo Habkost
2015-12-02 1:47 ` [Qemu-devel] [PATCH 08/16] acpi: Make build_srat() " Eduardo Habkost
2015-12-02 1:47 ` [Qemu-devel] [PATCH 09/16] acpi: Remove ram size fields fron PcGuestInfo Eduardo Habkost
2015-12-02 1:47 ` [Qemu-devel] [PATCH 10/16] pc: Move PcGuestInfo.fw_cfg field to PCMachineState Eduardo Habkost
2015-12-02 1:47 ` [Qemu-devel] [PATCH 11/16] pc: Simplify signature of xen_load_linux() Eduardo Habkost
2015-12-11 11:40 ` Stefano Stabellini
2015-12-02 1:47 ` [Qemu-devel] [PATCH 12/16] pc: Remove PcGuestInfo.isapc_ram_fw field Eduardo Habkost
2015-12-02 1:47 ` [Qemu-devel] [PATCH 13/16] q35: Remove MCHPCIState.guest_info field Eduardo Habkost
2015-12-02 1:47 ` [Qemu-devel] [PATCH 14/16] acpi: Use PCMachineClass fields directly Eduardo Habkost
2015-12-02 1:47 ` [Qemu-devel] [PATCH 15/16] pc: Move PcGuestInfo.apic_xrupt_override field to PCMachineState Eduardo Habkost
2015-12-02 1:47 ` [Qemu-devel] [PATCH 16/16] pc: Move APIC and NUMA data from PcGuestInfo " Eduardo Habkost
2015-12-07 18:57 ` [Qemu-devel] [PATCH 00/16] pc: Eliminate struct PcGuestInfo Marcel Apfelbaum
2015-12-08 17:53 ` Eduardo Habkost
2015-12-10 11:27 ` Marcel Apfelbaum
2015-12-10 17:45 ` 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=56672516.3020809@gmail.com \
--to=marcel.apfelbaum@gmail.com \
--cc=ehabkost@redhat.com \
--cc=imammedo@redhat.com \
--cc=marcel.a@redhat.com \
--cc=marcel@redhat.com \
--cc=mst@redhat.com \
--cc=qemu-devel@nongnu.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).