From: Wei Huang <wei@redhat.com>
To: Shannon Zhao <zhaoshenglong@huawei.com>, qemu-devel@nongnu.org
Cc: peter.maydell@linaro.org, drjones@redhat.com,
ehabkost@redhat.com, ard.biesheuvel@linaro.org, somlo@cmu.edu,
mst@redhat.com, imammedo@redhat.com, pbonzini@redhat.com,
lersek@redhat.com, rth@twiddle.net
Subject: Re: [Qemu-devel] [ARM SMBIOS V1 PATCH 6/6] smbios: implement smbios support for mach-virt
Date: Fri, 31 Jul 2015 01:08:43 -0500 [thread overview]
Message-ID: <55BB10EB.7080404@redhat.com> (raw)
In-Reply-To: <55BAD96D.6070707@huawei.com>
On 07/30/2015 09:11 PM, Shannon Zhao wrote:
>
>
> On 2015/7/28 14:00, Wei Huang wrote:
>> This patch generates smbios tables for ARM mach-virt. Also add
>> CONFIG_SMBIOS=y for ARM default config.
>>
>> Signed-off-by: Wei Huang <wei@redhat.com>
>> ---
>> default-configs/arm-softmmu.mak | 1 +
>> hw/arm/virt.c | 24 ++++++++++++++++++++++++
>> include/hw/arm/virt-acpi-build.h | 1 +
>> 3 files changed, 26 insertions(+)
>>
>> diff --git a/default-configs/arm-softmmu.mak b/default-configs/arm-softmmu.mak
>> index 74f1db3..99b41e9 100644
>> --- a/default-configs/arm-softmmu.mak
>> +++ b/default-configs/arm-softmmu.mak
>> @@ -102,3 +102,4 @@ CONFIG_XIO3130=y
>> CONFIG_IOH3420=y
>> CONFIG_I82801B11=y
>> CONFIG_ACPI=y
>> +CONFIG_SMBIOS=y
>> diff --git a/hw/arm/virt.c b/hw/arm/virt.c
>> index 4846892..04e5da4 100644
>> --- a/hw/arm/virt.c
>> +++ b/hw/arm/virt.c
>> @@ -48,6 +48,7 @@
>> #include "hw/arm/sysbus-fdt.h"
>> #include "hw/platform-bus.h"
>> #include "hw/arm/fdt.h"
>> +#include "hw/smbios/smbios.h"
>>
>> /* Number of external interrupt lines to configure the GIC with */
>> #define NUM_IRQS 256
>> @@ -780,12 +781,34 @@ static void *machvirt_dtb(const struct arm_boot_info *binfo, int *fdt_size)
>> return board->fdt;
>> }
>>
>> +static void virt_build_smbios(VirtGuestInfo *guest_info)
>> +{
>> + FWCfgState *fw_cfg = guest_info->fw_cfg;
>
> Would be better to check whether guest_info->fw_cfg is NULL?
Good point. I will address it in next spin.
Thanks,
-Wei
>
>> + uint8_t *smbios_tables, *smbios_anchor;
>> + size_t smbios_tables_len, smbios_anchor_len;
>> +
>> + smbios_set_defaults("QEMU", "QEMU Virtual Machine",
>> + "1.0", false, false, SMBIOS_ENTRY_POINT_30);
>> +
>> + smbios_get_tables(NULL, 0, guest_info->ram_size,
>> + &smbios_tables, &smbios_tables_len,
>> + &smbios_anchor, &smbios_anchor_len);
>> +
>> + if (smbios_anchor) {
>> + fw_cfg_add_file(fw_cfg, "etc/smbios/smbios-tables",
>> + smbios_tables, smbios_tables_len);
>> + fw_cfg_add_file(fw_cfg, "etc/smbios/smbios-anchor",
>> + smbios_anchor, smbios_anchor_len);
>> + }
>> +}
>> +
>> static
>> void virt_guest_info_machine_done(Notifier *notifier, void *data)
>> {
>> VirtGuestInfoState *guest_info_state = container_of(notifier,
>> VirtGuestInfoState, machine_done);
>> virt_acpi_setup(&guest_info_state->info);
>> + virt_build_smbios(&guest_info_state->info);
>> }
>>
>> static void machvirt_init(MachineState *machine)
>> @@ -894,6 +917,7 @@ static void machvirt_init(MachineState *machine)
>>
>> guest_info->smp_cpus = smp_cpus;
>> guest_info->fw_cfg = fw_cfg_find();
>> + guest_info->ram_size = machine->ram_size;
>> guest_info->memmap = vbi->memmap;
>> guest_info->irqmap = vbi->irqmap;
>> guest_info_state->machine_done.notify = virt_guest_info_machine_done;
>> diff --git a/include/hw/arm/virt-acpi-build.h b/include/hw/arm/virt-acpi-build.h
>> index 04f174d..ef274c6 100644
>> --- a/include/hw/arm/virt-acpi-build.h
>> +++ b/include/hw/arm/virt-acpi-build.h
>> @@ -29,6 +29,7 @@
>> typedef struct VirtGuestInfo {
>> int smp_cpus;
>> FWCfgState *fw_cfg;
>> + ram_addr_t ram_size;
>> const MemMapEntry *memmap;
>> const int *irqmap;
>> } VirtGuestInfo;
>>
>
next prev parent reply other threads:[~2015-07-31 6:08 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-07-28 6:00 [Qemu-devel] [ARM SMBIOS V1 PATCH 0/6] SMBIOS Support for ARM Wei Huang
2015-07-28 6:00 ` [Qemu-devel] [ARM SMBIOS V1 PATCH 1/6] smbios: extract x86 smbios building code into a function Wei Huang
2015-07-28 6:00 ` [Qemu-devel] [ARM SMBIOS V1 PATCH 2/6] smbios: remove dependency on x86 e820 tables Wei Huang
2015-07-28 6:00 ` [Qemu-devel] [ARM SMBIOS V1 PATCH 3/6] smbios: pass ram size as a parameter to build smbios tables Wei Huang
2015-07-28 6:00 ` [Qemu-devel] [ARM SMBIOS V1 PATCH 4/6] smbios: move smbios code into a common folder Wei Huang
2015-07-28 6:00 ` [Qemu-devel] [ARM SMBIOS V1 PATCH 5/6] smbios: add smbios 3.0 support Wei Huang
2015-07-31 17:12 ` Laszlo Ersek
2015-07-28 6:00 ` [Qemu-devel] [ARM SMBIOS V1 PATCH 6/6] smbios: implement smbios support for mach-virt Wei Huang
2015-07-31 2:11 ` Shannon Zhao
2015-07-31 6:08 ` Wei Huang [this message]
2015-08-05 17:16 ` [Qemu-devel] [ARM SMBIOS V1 PATCH 0/6] SMBIOS Support for ARM Laszlo Ersek
2015-08-05 17:35 ` Peter Maydell
2015-08-05 18:35 ` Laszlo Ersek
2015-08-05 19:39 ` Ivan Khoronzhuk
2015-08-05 22:03 ` Jean Delvare
2015-08-06 8:07 ` Laszlo Ersek
2015-08-06 8:16 ` Ivan Khoronzhuk
2015-08-06 11:20 ` Jean Delvare
2015-08-10 7:43 ` [Qemu-devel] dmidecode repository (Was: [ARM SMBIOS V1 PATCH 0/6] SMBIOS Support for ARM) Jean Delvare
2015-08-10 11:58 ` Laszlo Ersek
2015-08-10 12:26 ` Jean Delvare
2015-08-10 15:08 ` Laszlo Ersek
2015-08-06 12:41 ` [Qemu-devel] [ARM SMBIOS V1 PATCH 0/6] SMBIOS Support for ARM Andrew Jones
2015-08-07 11:12 ` Ard Biesheuvel
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=55BB10EB.7080404@redhat.com \
--to=wei@redhat.com \
--cc=ard.biesheuvel@linaro.org \
--cc=drjones@redhat.com \
--cc=ehabkost@redhat.com \
--cc=imammedo@redhat.com \
--cc=lersek@redhat.com \
--cc=mst@redhat.com \
--cc=pbonzini@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=qemu-devel@nongnu.org \
--cc=rth@twiddle.net \
--cc=somlo@cmu.edu \
--cc=zhaoshenglong@huawei.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.