* [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID @ 2014-09-17 11:39 Gal Hammer 2014-09-17 11:39 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer ` (4 more replies) 0 siblings, 5 replies; 20+ messages in thread From: Gal Hammer @ 2014-09-17 11:39 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, Paolo Bonzini, Igor Mammedov Hi, A two parts patch to add a QEmu support for Microsoft's Virtual Machine Generation ID device. The first one add a new ACPI directive which allow to use a 16-bytes buffer in an ACPI table. This buffer is for storing the VM's UUID. The second is the ACPI tables changes and the actual device. Your comment are welcomed. Thanks, Gal. V5: - include the pre-compiled ASL file - remove an empty line at end of files. V4: - Move device's description to SSDT table (dynamic build). V3: - Fix a typo in error message string. - Move device's description from DSDT back to SSDT table. V2: - Remove "-uuid" command line parameter. - Move device's description from SSDT to DSDT table. - Add new "vmgenid" sysbus device. Gal Hammer (2): i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. i386: Add a Virtual Machine Generation ID device. default-configs/i386-softmmu.mak | 1 + default-configs/x86_64-softmmu.mak | 1 + hw/i386/Makefile.objs | 2 +- hw/i386/acpi-build.c | 39 +++++++ hw/i386/ssdt-vmgenid.dsl | 63 ++++++++++++ hw/i386/ssdt-vmgenid.hex.generated | 206 +++++++++++++++++++++++++++++++++++++ hw/misc/Makefile.objs | 1 + hw/misc/vmgenid.c | 84 +++++++++++++++ include/hw/i386/pc.h | 3 + scripts/acpi_extract.py | 23 +++-- 10 files changed, 413 insertions(+), 10 deletions(-) create mode 100644 hw/i386/ssdt-vmgenid.dsl create mode 100644 hw/i386/ssdt-vmgenid.hex.generated create mode 100644 hw/misc/vmgenid.c -- 1.9.3 ^ permalink raw reply [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. 2014-09-17 11:39 [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID Gal Hammer @ 2014-09-17 11:39 ` Gal Hammer 2014-10-02 12:20 ` Michael S. Tsirkin 2014-09-17 11:39 ` [Qemu-devel] [PATCH 2/2] i386: Add a Virtual Machine Generation ID device Gal Hammer ` (3 subsequent siblings) 4 siblings, 1 reply; 20+ messages in thread From: Gal Hammer @ 2014-09-17 11:39 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, Paolo Bonzini, Igor Mammedov Add a 16-bytes buffer to allow storing a 128-bit UUID value in an ACPI table. Signed-off-by: Gal Hammer <ghammer@redhat.com> Reviewed-by: Paolo Bonzini <pbonzini@redhat.com> --- scripts/acpi_extract.py | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/scripts/acpi_extract.py b/scripts/acpi_extract.py index 22ea468..10c1ffb 100755 --- a/scripts/acpi_extract.py +++ b/scripts/acpi_extract.py @@ -139,13 +139,16 @@ def aml_name_string(offset): offset += 1 return offset; -# Given data offset, find 8 byte buffer offset -def aml_data_buffer8(offset): - #0x08 NameOp NameString DataRef - expect = [0x11, 0x0B, 0x0A, 0x08] +# Given data offset, find variable length byte buffer offset +def aml_data_buffer(offset, length): + #0x11 PkgLength BufferSize ByteList + if (length > 63): + die( "Name offset 0x%x: expected a one byte PkgLength (length<=63)" % + (offset)); + expect = [0x11, length+3, 0x0A, length] if (aml[offset:offset+4] != expect): die( "Name offset 0x%x: expected %s actual %s" % - (offset, aml[offset:offset+4], expect)) + (offset, expect, aml[offset:offset+4])) return offset + len(expect) # Given data offset, find dword const offset @@ -172,9 +175,9 @@ def aml_data_byte_const(offset): (offset, aml[offset])); return offset + 1; -# Find name'd buffer8 -def aml_name_buffer8(offset): - return aml_data_buffer8(aml_name_string(offset) + 4) +# Find name'd buffer +def aml_name_buffer(offset, length): + return aml_data_buffer(aml_name_string(offset) + 4, length) # Given name offset, find dword const offset def aml_name_dword_const(offset): @@ -308,7 +311,9 @@ for i in range(len(asl)): output[array] = aml continue if (directive == "ACPI_EXTRACT_NAME_BUFFER8"): - offset = aml_name_buffer8(offset) + offset = aml_name_buffer(offset, 8) + elif (directive == "ACPI_EXTRACT_NAME_BUFFER16"): + offset = aml_name_buffer(offset, 16) elif (directive == "ACPI_EXTRACT_NAME_DWORD_CONST"): offset = aml_name_dword_const(offset) elif (directive == "ACPI_EXTRACT_NAME_WORD_CONST"): -- 1.9.3 ^ permalink raw reply related [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. 2014-09-17 11:39 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer @ 2014-10-02 12:20 ` Michael S. Tsirkin 0 siblings, 0 replies; 20+ messages in thread From: Michael S. Tsirkin @ 2014-10-02 12:20 UTC (permalink / raw) To: Gal Hammer; +Cc: Paolo Bonzini, qemu-devel, Igor Mammedov On Wed, Sep 17, 2014 at 02:39:51PM +0300, Gal Hammer wrote: > Add a 16-bytes buffer to allow storing a 128-bit UUID value in an > ACPI table. > > Signed-off-by: Gal Hammer <ghammer@redhat.com> > Reviewed-by: Paolo Bonzini <pbonzini@redhat.com> This one looks good. Applied, thanks! > --- > scripts/acpi_extract.py | 23 ++++++++++++++--------- > 1 file changed, 14 insertions(+), 9 deletions(-) > > diff --git a/scripts/acpi_extract.py b/scripts/acpi_extract.py > index 22ea468..10c1ffb 100755 > --- a/scripts/acpi_extract.py > +++ b/scripts/acpi_extract.py > @@ -139,13 +139,16 @@ def aml_name_string(offset): > offset += 1 > return offset; > > -# Given data offset, find 8 byte buffer offset > -def aml_data_buffer8(offset): > - #0x08 NameOp NameString DataRef > - expect = [0x11, 0x0B, 0x0A, 0x08] > +# Given data offset, find variable length byte buffer offset > +def aml_data_buffer(offset, length): > + #0x11 PkgLength BufferSize ByteList > + if (length > 63): > + die( "Name offset 0x%x: expected a one byte PkgLength (length<=63)" % > + (offset)); > + expect = [0x11, length+3, 0x0A, length] > if (aml[offset:offset+4] != expect): > die( "Name offset 0x%x: expected %s actual %s" % > - (offset, aml[offset:offset+4], expect)) > + (offset, expect, aml[offset:offset+4])) > return offset + len(expect) > > # Given data offset, find dword const offset > @@ -172,9 +175,9 @@ def aml_data_byte_const(offset): > (offset, aml[offset])); > return offset + 1; > > -# Find name'd buffer8 > -def aml_name_buffer8(offset): > - return aml_data_buffer8(aml_name_string(offset) + 4) > +# Find name'd buffer > +def aml_name_buffer(offset, length): > + return aml_data_buffer(aml_name_string(offset) + 4, length) > > # Given name offset, find dword const offset > def aml_name_dword_const(offset): > @@ -308,7 +311,9 @@ for i in range(len(asl)): > output[array] = aml > continue > if (directive == "ACPI_EXTRACT_NAME_BUFFER8"): > - offset = aml_name_buffer8(offset) > + offset = aml_name_buffer(offset, 8) > + elif (directive == "ACPI_EXTRACT_NAME_BUFFER16"): > + offset = aml_name_buffer(offset, 16) > elif (directive == "ACPI_EXTRACT_NAME_DWORD_CONST"): > offset = aml_name_dword_const(offset) > elif (directive == "ACPI_EXTRACT_NAME_WORD_CONST"): > -- > 1.9.3 > ^ permalink raw reply [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 2/2] i386: Add a Virtual Machine Generation ID device. 2014-09-17 11:39 [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID Gal Hammer 2014-09-17 11:39 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer @ 2014-09-17 11:39 ` Gal Hammer 2014-10-02 12:49 ` Michael S. Tsirkin 2014-10-01 8:58 ` [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID Markus Armbruster ` (2 subsequent siblings) 4 siblings, 1 reply; 20+ messages in thread From: Gal Hammer @ 2014-09-17 11:39 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, Paolo Bonzini, Igor Mammedov Based on Microsoft's sepecifications (paper can be dowloaded from http://go.microsoft.com/fwlink/?LinkId=260709), add a device description to the SSDT ACPI table. The GUID is set using a new "vmgenid" device. Signed-off-by: Gal Hammer <ghammer@redhat.com> Reviewed-By: Igor Mammedov <imammedo@redhat.com> --- default-configs/i386-softmmu.mak | 1 + default-configs/x86_64-softmmu.mak | 1 + hw/i386/Makefile.objs | 2 +- hw/i386/acpi-build.c | 39 +++++++ hw/i386/ssdt-vmgenid.dsl | 63 ++++++++++++ hw/i386/ssdt-vmgenid.hex.generated | 206 +++++++++++++++++++++++++++++++++++++ hw/misc/Makefile.objs | 1 + hw/misc/vmgenid.c | 84 +++++++++++++++ include/hw/i386/pc.h | 3 + 9 files changed, 399 insertions(+), 1 deletion(-) create mode 100644 hw/i386/ssdt-vmgenid.dsl create mode 100644 hw/i386/ssdt-vmgenid.hex.generated create mode 100644 hw/misc/vmgenid.c diff --git a/default-configs/i386-softmmu.mak b/default-configs/i386-softmmu.mak index 8e08841..bd33c75 100644 --- a/default-configs/i386-softmmu.mak +++ b/default-configs/i386-softmmu.mak @@ -45,3 +45,4 @@ CONFIG_IOAPIC=y CONFIG_ICC_BUS=y CONFIG_PVPANIC=y CONFIG_MEM_HOTPLUG=y +CONFIG_VMGENID=y diff --git a/default-configs/x86_64-softmmu.mak b/default-configs/x86_64-softmmu.mak index 66557ac..006fc7c 100644 --- a/default-configs/x86_64-softmmu.mak +++ b/default-configs/x86_64-softmmu.mak @@ -45,3 +45,4 @@ CONFIG_IOAPIC=y CONFIG_ICC_BUS=y CONFIG_PVPANIC=y CONFIG_MEM_HOTPLUG=y +CONFIG_VMGENID=y diff --git a/hw/i386/Makefile.objs b/hw/i386/Makefile.objs index 9d419ad..cd1beb3 100644 --- a/hw/i386/Makefile.objs +++ b/hw/i386/Makefile.objs @@ -12,7 +12,7 @@ hw/i386/acpi-build.o: hw/i386/acpi-build.c hw/i386/acpi-dsdt.hex \ hw/i386/ssdt-proc.hex hw/i386/ssdt-pcihp.hex hw/i386/ssdt-misc.hex \ hw/i386/acpi-dsdt.hex hw/i386/q35-acpi-dsdt.hex \ hw/i386/q35-acpi-dsdt.hex hw/i386/ssdt-mem.hex \ - hw/i386/ssdt-tpm.hex + hw/i386/ssdt-tpm.hex hw/i386/ssdt-vmgenid.hex iasl-option=$(shell if test -z "`$(1) $(2) 2>&1 > /dev/null`" \ ; then echo "$(2)"; else echo "$(3)"; fi ;) diff --git a/hw/i386/acpi-build.c b/hw/i386/acpi-build.c index a313321..72d5a88 100644 --- a/hw/i386/acpi-build.c +++ b/hw/i386/acpi-build.c @@ -96,6 +96,8 @@ typedef struct AcpiMiscInfo { const unsigned char *dsdt_code; unsigned dsdt_size; uint16_t pvpanic_port; + bool vm_generation_id_set; + uint8_t vm_generation_id[16]; } AcpiMiscInfo; typedef struct AcpiBuildPciBusHotplugState { @@ -216,6 +218,7 @@ static void acpi_get_misc_info(AcpiMiscInfo *info) info->has_hpet = hpet_find(); info->has_tpm = tpm_find(); info->pvpanic_port = pvpanic_port(); + info->vm_generation_id_set = vm_generation_id(info->vm_generation_id); } static void acpi_get_pci_info(PcPciInfo *info) @@ -710,6 +713,7 @@ static inline char acpi_get_hex(uint32_t val) #include "hw/i386/ssdt-misc.hex" #include "hw/i386/ssdt-pcihp.hex" #include "hw/i386/ssdt-tpm.hex" +#include "hw/i386/ssdt-vmgenid.hex" static void build_append_notify_method(GArray *device, const char *name, @@ -1246,6 +1250,37 @@ build_tpm_ssdt(GArray *table_data, GArray *linker) memcpy(tpm_ptr, ssdt_tpm_aml, sizeof(ssdt_tpm_aml)); } +static void +build_vmgenid_ssdt(GArray *table_data, GArray *linker, AcpiMiscInfo *info) +{ + int vgid_start = table_data->len; + void *vgid_ptr; + uint8_t *vm_gid_ptr; + uint32_t vm_gid_physical_address; + + vgid_ptr = acpi_data_push(table_data, sizeof(ssdt_vmgenid_aml)); + memcpy(vgid_ptr, ssdt_vmgenid_aml, sizeof(ssdt_vmgenid_aml)); + + vm_gid_ptr = acpi_data_get_ptr(vgid_ptr, sizeof(ssdt_vmgenid_aml), + *ssdt_acpi_vm_gid, + sizeof(info->vm_generation_id)); + memcpy(vm_gid_ptr, info->vm_generation_id, + sizeof(info->vm_generation_id)); + + bios_linker_loader_add_pointer(linker, ACPI_BUILD_TABLE_FILE, + ACPI_BUILD_TABLE_FILE, + table_data, + vgid_ptr + *ssdt_acpi_vm_gid_addr, + sizeof(uint32_t)); + + vm_gid_physical_address = vgid_start + *ssdt_acpi_vm_gid; + ACPI_BUILD_SET_LE(vgid_ptr, sizeof(ssdt_vmgenid_aml), + *ssdt_acpi_vm_gid_addr, 32, vm_gid_physical_address); + + build_header(linker, table_data, vgid_ptr, "SSDT", + sizeof(ssdt_vmgenid_aml), 1); +} + typedef enum { MEM_AFFINITY_NOFLAGS = 0, MEM_AFFINITY_ENABLED = (1 << 0), @@ -1617,6 +1652,10 @@ void acpi_build(PcGuestInfo *guest_info, AcpiBuildTables *tables) acpi_add_table(table_offsets, tables->table_data); build_tpm_ssdt(tables->table_data, tables->linker); } + if (misc.vm_generation_id_set) { + acpi_add_table(table_offsets, tables->table_data); + build_vmgenid_ssdt(tables->table_data, tables->linker, &misc); + } if (guest_info->numa_nodes) { acpi_add_table(table_offsets, tables->table_data); build_srat(tables->table_data, tables->linker, &cpu, guest_info); diff --git a/hw/i386/ssdt-vmgenid.dsl b/hw/i386/ssdt-vmgenid.dsl new file mode 100644 index 0000000..fee376f --- /dev/null +++ b/hw/i386/ssdt-vmgenid.dsl @@ -0,0 +1,63 @@ +/* + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + + * You should have received a copy of the GNU General Public License along + * with this program; if not, see <http://www.gnu.org/licenses/>. + */ + +/**************************************************************** + * Virtual Machine Generation ID Device + ****************************************************************/ + +ACPI_EXTRACT_ALL_CODE ssdt_vmgenid_aml + +DefinitionBlock ( + "ssdt-vmgenid.aml", // Output Filename + "SSDT", // Signature + 0x01, // SSDT Compliance Revision + "BXPC", // OEMID + "BXSSDTSUSP", // TABLE ID + 0x1 // OEM Revision + ) +{ + Scope(\_SB) { + + Device(VMGI) { + Name(_HID, "QEMU0002") + Name(_CID, "VM_Gen_Counter") + Name(_DDN, "VM_Gen_Counter") + + ACPI_EXTRACT_NAME_DWORD_CONST ssdt_acpi_vm_gid_addr + Name(VGIA, 0x12345678) + + ACPI_EXTRACT_NAME_BUFFER16 ssdt_acpi_vm_gid + Name(VGID, Buffer(16) { + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) + + Method(_STA, 0, NotSerialized) { + Store(VGIA, Local0) + If (LEqual(Local0, Zero)) { + Return (0x00) + } Else { + Return (0x0F) + } + } + + Method(ADDR, 0, Serialized) { + Store(Package(2) { }, Local0) + Store(VGIA, Index(Local0, 0)) + Store(0x0000, Index(Local0, 1)) + return (Local0) + } + } + } +} diff --git a/hw/i386/ssdt-vmgenid.hex.generated b/hw/i386/ssdt-vmgenid.hex.generated new file mode 100644 index 0000000..e96cb36 --- /dev/null +++ b/hw/i386/ssdt-vmgenid.hex.generated @@ -0,0 +1,206 @@ +static unsigned char ssdt_vmgenid_aml[] = { +0x53, +0x53, +0x44, +0x54, +0xc6, +0x0, +0x0, +0x0, +0x1, +0xeb, +0x42, +0x58, +0x50, +0x43, +0x0, +0x0, +0x42, +0x58, +0x53, +0x53, +0x44, +0x54, +0x53, +0x55, +0x1, +0x0, +0x0, +0x0, +0x49, +0x4e, +0x54, +0x4c, +0x24, +0x4, +0x14, +0x20, +0x10, +0x41, +0xa, +0x5c, +0x5f, +0x53, +0x42, +0x5f, +0x5b, +0x82, +0x48, +0x9, +0x56, +0x4d, +0x47, +0x49, +0x8, +0x5f, +0x48, +0x49, +0x44, +0xd, +0x51, +0x45, +0x4d, +0x55, +0x30, +0x30, +0x30, +0x32, +0x0, +0x8, +0x5f, +0x43, +0x49, +0x44, +0xd, +0x56, +0x4d, +0x5f, +0x47, +0x65, +0x6e, +0x5f, +0x43, +0x6f, +0x75, +0x6e, +0x74, +0x65, +0x72, +0x0, +0x8, +0x5f, +0x44, +0x44, +0x4e, +0xd, +0x56, +0x4d, +0x5f, +0x47, +0x65, +0x6e, +0x5f, +0x43, +0x6f, +0x75, +0x6e, +0x74, +0x65, +0x72, +0x0, +0x8, +0x56, +0x47, +0x49, +0x41, +0xc, +0x78, +0x56, +0x34, +0x12, +0x8, +0x56, +0x47, +0x49, +0x44, +0x11, +0x13, +0xa, +0x10, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x0, +0x14, +0x18, +0x5f, +0x53, +0x54, +0x41, +0x0, +0x70, +0x56, +0x47, +0x49, +0x41, +0x60, +0xa0, +0x6, +0x93, +0x60, +0x0, +0xa4, +0x0, +0xa1, +0x4, +0xa4, +0xa, +0xf, +0x14, +0x1c, +0x41, +0x44, +0x44, +0x52, +0x8, +0x70, +0x12, +0x2, +0x2, +0x60, +0x70, +0x56, +0x47, +0x49, +0x41, +0x88, +0x60, +0x0, +0x0, +0x70, +0x0, +0x88, +0x60, +0x1, +0x0, +0xa4, +0x60 +}; +static unsigned char ssdt_acpi_vm_gid_addr[] = { +0x73 +}; +static unsigned char ssdt_acpi_vm_gid[] = { +0x80 +}; diff --git a/hw/misc/Makefile.objs b/hw/misc/Makefile.objs index 979e532..c18b800 100644 --- a/hw/misc/Makefile.objs +++ b/hw/misc/Makefile.objs @@ -41,3 +41,4 @@ obj-$(CONFIG_SLAVIO) += slavio_misc.o obj-$(CONFIG_ZYNQ) += zynq_slcr.o obj-$(CONFIG_PVPANIC) += pvpanic.o +obj-$(CONFIG_VMGENID) += vmgenid.o diff --git a/hw/misc/vmgenid.c b/hw/misc/vmgenid.c new file mode 100644 index 0000000..81cc49e --- /dev/null +++ b/hw/misc/vmgenid.c @@ -0,0 +1,84 @@ +/* + * Virtual Machine Generation ID Device + * + * Copyright (C) 2014 Red Hat Inc. + * + * Authors: Gal Hammer <ghammer@redhat.com> + * + * This work is licensed under the terms of the GNU GPL, version 2 or later. + * See the COPYING file in the top-level directory. + * + */ + +#include "hw/i386/pc.h" +#include "hw/sysbus.h" + +#define VMGENID_DEVICE "vmgenid" + +#define PROPERTY_UUID "uuid" + +#define VMGENID(obj) OBJECT_CHECK(VmGenIdState, (obj), VMGENID_DEVICE) + +typedef struct VmGenIdState { + SysBusDevice parent_obj; + char *guid_arg; +} VmGenIdState; + +bool vm_generation_id(uint8_t id[16]) +{ + Object *o = object_resolve_path_type("", VMGENID_DEVICE, NULL); + char *guid; + + if (!o) { + return false; + } + guid = object_property_get_str(o, PROPERTY_UUID, NULL); + /* actual uuid validation was checked during realize. */ + (void)qemu_uuid_parse(guid, id); + return true; +} + +static void vmgenid_realize(DeviceState *dev, Error **errp) +{ + VmGenIdState *s = VMGENID(dev); + uint8_t id[16]; + + if (!s->guid_arg) { + error_setg(errp, "missing uuid."); + return; + } + + if (qemu_uuid_parse(s->guid_arg, id) < 0) { + error_setg(errp, "Fail to parse UUID string."); + return; + } +} + +static Property vmgenid_device_properties[] = { + DEFINE_PROP_STRING(PROPERTY_UUID, VmGenIdState, guid_arg), + DEFINE_PROP_END_OF_LIST(), +}; + +static void vmgenid_class_init(ObjectClass *klass, void *data) +{ + DeviceClass *dc = DEVICE_CLASS(klass); + + dc->realize = vmgenid_realize; + dc->props = vmgenid_device_properties; + dc->cannot_instantiate_with_device_add_yet = false; + set_bit(DEVICE_CATEGORY_MISC, dc->categories); +} + +static const TypeInfo vmgenid_device_info = { + .name = VMGENID_DEVICE, + .parent = TYPE_SYS_BUS_DEVICE, + .instance_size = sizeof(VmGenIdState), + .class_init = vmgenid_class_init, +}; + +static void vmgenid_register_types(void) +{ + type_register_static(&vmgenid_device_info); +} + +type_init(vmgenid_register_types) diff --git a/include/hw/i386/pc.h b/include/hw/i386/pc.h index 77316d5..40ecccb 100644 --- a/include/hw/i386/pc.h +++ b/include/hw/i386/pc.h @@ -290,6 +290,9 @@ void pc_system_firmware_init(MemoryRegion *rom_memory, /* pvpanic.c */ uint16_t pvpanic_port(void); +/* vmgenid.c */ +bool vm_generation_id(uint8_t id[16]); + /* e820 types */ #define E820_RAM 1 #define E820_RESERVED 2 -- 1.9.3 ^ permalink raw reply related [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 2/2] i386: Add a Virtual Machine Generation ID device. 2014-09-17 11:39 ` [Qemu-devel] [PATCH 2/2] i386: Add a Virtual Machine Generation ID device Gal Hammer @ 2014-10-02 12:49 ` Michael S. Tsirkin 2014-10-02 13:14 ` Gal Hammer 0 siblings, 1 reply; 20+ messages in thread From: Michael S. Tsirkin @ 2014-10-02 12:49 UTC (permalink / raw) To: Gal Hammer; +Cc: Paolo Bonzini, qemu-devel, Igor Mammedov On Wed, Sep 17, 2014 at 02:39:52PM +0300, Gal Hammer wrote: > Based on Microsoft's sepecifications (paper can be dowloaded from > http://go.microsoft.com/fwlink/?LinkId=260709), add a device > description to the SSDT ACPI table. > > The GUID is set using a new "vmgenid" device. > > Signed-off-by: Gal Hammer <ghammer@redhat.com> > Reviewed-By: Igor Mammedov <imammedo@redhat.com> > --- > default-configs/i386-softmmu.mak | 1 + > default-configs/x86_64-softmmu.mak | 1 + > hw/i386/Makefile.objs | 2 +- > hw/i386/acpi-build.c | 39 +++++++ > hw/i386/ssdt-vmgenid.dsl | 63 ++++++++++++ > hw/i386/ssdt-vmgenid.hex.generated | 206 +++++++++++++++++++++++++++++++++++++ > hw/misc/Makefile.objs | 1 + > hw/misc/vmgenid.c | 84 +++++++++++++++ > include/hw/i386/pc.h | 3 + Patch scripts/update-acpi.sh as well please. > 9 files changed, 399 insertions(+), 1 deletion(-) > create mode 100644 hw/i386/ssdt-vmgenid.dsl > create mode 100644 hw/i386/ssdt-vmgenid.hex.generated > create mode 100644 hw/misc/vmgenid.c > > diff --git a/default-configs/i386-softmmu.mak b/default-configs/i386-softmmu.mak > index 8e08841..bd33c75 100644 > --- a/default-configs/i386-softmmu.mak > +++ b/default-configs/i386-softmmu.mak > @@ -45,3 +45,4 @@ CONFIG_IOAPIC=y > CONFIG_ICC_BUS=y > CONFIG_PVPANIC=y > CONFIG_MEM_HOTPLUG=y > +CONFIG_VMGENID=y > diff --git a/default-configs/x86_64-softmmu.mak b/default-configs/x86_64-softmmu.mak > index 66557ac..006fc7c 100644 > --- a/default-configs/x86_64-softmmu.mak > +++ b/default-configs/x86_64-softmmu.mak > @@ -45,3 +45,4 @@ CONFIG_IOAPIC=y > CONFIG_ICC_BUS=y > CONFIG_PVPANIC=y > CONFIG_MEM_HOTPLUG=y > +CONFIG_VMGENID=y > diff --git a/hw/i386/Makefile.objs b/hw/i386/Makefile.objs > index 9d419ad..cd1beb3 100644 > --- a/hw/i386/Makefile.objs > +++ b/hw/i386/Makefile.objs > @@ -12,7 +12,7 @@ hw/i386/acpi-build.o: hw/i386/acpi-build.c hw/i386/acpi-dsdt.hex \ > hw/i386/ssdt-proc.hex hw/i386/ssdt-pcihp.hex hw/i386/ssdt-misc.hex \ > hw/i386/acpi-dsdt.hex hw/i386/q35-acpi-dsdt.hex \ > hw/i386/q35-acpi-dsdt.hex hw/i386/ssdt-mem.hex \ > - hw/i386/ssdt-tpm.hex > + hw/i386/ssdt-tpm.hex hw/i386/ssdt-vmgenid.hex > > iasl-option=$(shell if test -z "`$(1) $(2) 2>&1 > /dev/null`" \ > ; then echo "$(2)"; else echo "$(3)"; fi ;) > diff --git a/hw/i386/acpi-build.c b/hw/i386/acpi-build.c > index a313321..72d5a88 100644 > --- a/hw/i386/acpi-build.c > +++ b/hw/i386/acpi-build.c > @@ -96,6 +96,8 @@ typedef struct AcpiMiscInfo { > const unsigned char *dsdt_code; > unsigned dsdt_size; > uint16_t pvpanic_port; > + bool vm_generation_id_set; > + uint8_t vm_generation_id[16]; > } AcpiMiscInfo; > > typedef struct AcpiBuildPciBusHotplugState { > @@ -216,6 +218,7 @@ static void acpi_get_misc_info(AcpiMiscInfo *info) > info->has_hpet = hpet_find(); > info->has_tpm = tpm_find(); > info->pvpanic_port = pvpanic_port(); > + info->vm_generation_id_set = vm_generation_id(info->vm_generation_id); > } > > static void acpi_get_pci_info(PcPciInfo *info) > @@ -710,6 +713,7 @@ static inline char acpi_get_hex(uint32_t val) > #include "hw/i386/ssdt-misc.hex" > #include "hw/i386/ssdt-pcihp.hex" > #include "hw/i386/ssdt-tpm.hex" > +#include "hw/i386/ssdt-vmgenid.hex" > > static void > build_append_notify_method(GArray *device, const char *name, > @@ -1246,6 +1250,37 @@ build_tpm_ssdt(GArray *table_data, GArray *linker) > memcpy(tpm_ptr, ssdt_tpm_aml, sizeof(ssdt_tpm_aml)); > } > > +static void > +build_vmgenid_ssdt(GArray *table_data, GArray *linker, AcpiMiscInfo *info) > +{ > + int vgid_start = table_data->len; > + void *vgid_ptr; > + uint8_t *vm_gid_ptr; > + uint32_t vm_gid_physical_address; > + > + vgid_ptr = acpi_data_push(table_data, sizeof(ssdt_vmgenid_aml)); > + memcpy(vgid_ptr, ssdt_vmgenid_aml, sizeof(ssdt_vmgenid_aml)); > + > + vm_gid_ptr = acpi_data_get_ptr(vgid_ptr, sizeof(ssdt_vmgenid_aml), > + *ssdt_acpi_vm_gid, > + sizeof(info->vm_generation_id)); > + memcpy(vm_gid_ptr, info->vm_generation_id, > + sizeof(info->vm_generation_id)); > + > + bios_linker_loader_add_pointer(linker, ACPI_BUILD_TABLE_FILE, > + ACPI_BUILD_TABLE_FILE, > + table_data, > + vgid_ptr + *ssdt_acpi_vm_gid_addr, > + sizeof(uint32_t)); > + > + vm_gid_physical_address = vgid_start + *ssdt_acpi_vm_gid; > + ACPI_BUILD_SET_LE(vgid_ptr, sizeof(ssdt_vmgenid_aml), > + *ssdt_acpi_vm_gid_addr, 32, vm_gid_physical_address); > + > + build_header(linker, table_data, vgid_ptr, "SSDT", > + sizeof(ssdt_vmgenid_aml), 1); > +} > + > typedef enum { > MEM_AFFINITY_NOFLAGS = 0, > MEM_AFFINITY_ENABLED = (1 << 0), > @@ -1617,6 +1652,10 @@ void acpi_build(PcGuestInfo *guest_info, AcpiBuildTables *tables) > acpi_add_table(table_offsets, tables->table_data); > build_tpm_ssdt(tables->table_data, tables->linker); > } > + if (misc.vm_generation_id_set) { > + acpi_add_table(table_offsets, tables->table_data); > + build_vmgenid_ssdt(tables->table_data, tables->linker, &misc); > + } > if (guest_info->numa_nodes) { > acpi_add_table(table_offsets, tables->table_data); > build_srat(tables->table_data, tables->linker, &cpu, guest_info); > diff --git a/hw/i386/ssdt-vmgenid.dsl b/hw/i386/ssdt-vmgenid.dsl > new file mode 100644 > index 0000000..fee376f > --- /dev/null > +++ b/hw/i386/ssdt-vmgenid.dsl > @@ -0,0 +1,63 @@ > +/* > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License as published by > + * the Free Software Foundation; either version 2 of the License, or > + * (at your option) any later version. > + > + * This program is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + > + * You should have received a copy of the GNU General Public License along > + * with this program; if not, see <http://www.gnu.org/licenses/>. > + */ > + > +/**************************************************************** > + * Virtual Machine Generation ID Device > + ****************************************************************/ > + > +ACPI_EXTRACT_ALL_CODE ssdt_vmgenid_aml > + > +DefinitionBlock ( > + "ssdt-vmgenid.aml", // Output Filename > + "SSDT", // Signature > + 0x01, // SSDT Compliance Revision > + "BXPC", // OEMID > + "BXSSDTSUSP", // TABLE ID > + 0x1 // OEM Revision > + ) > +{ > + Scope(\_SB) { > + > + Device(VMGI) { > + Name(_HID, "QEMU0002") > + Name(_CID, "VM_Gen_Counter") > + Name(_DDN, "VM_Gen_Counter") > + > + ACPI_EXTRACT_NAME_DWORD_CONST ssdt_acpi_vm_gid_addr > + Name(VGIA, 0x12345678) > + > + ACPI_EXTRACT_NAME_BUFFER16 ssdt_acpi_vm_gid > + Name(VGID, Buffer(16) { > + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, > + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) IMHO, statically allocating the ID in ACPI like this is a mistake. For example, your guest might be in hybernation, in this case it will not re-read ACPI tables on boot. Also - what guarantees that this buffer is 8 byte aligned? > + > + Method(_STA, 0, NotSerialized) { > + Store(VGIA, Local0) > + If (LEqual(Local0, Zero)) { > + Return (0x00) > + } Else { > + Return (0x0F) > + } > + } > + > + Method(ADDR, 0, Serialized) { > + Store(Package(2) { }, Local0) > + Store(VGIA, Index(Local0, 0)) > + Store(0x0000, Index(Local0, 1)) > + return (Local0) > + } > + } > + } > +} > diff --git a/hw/i386/ssdt-vmgenid.hex.generated b/hw/i386/ssdt-vmgenid.hex.generated > new file mode 100644 > index 0000000..e96cb36 > --- /dev/null > +++ b/hw/i386/ssdt-vmgenid.hex.generated > @@ -0,0 +1,206 @@ > +static unsigned char ssdt_vmgenid_aml[] = { > +0x53, > +0x53, > +0x44, > +0x54, > +0xc6, > +0x0, > +0x0, > +0x0, > +0x1, > +0xeb, > +0x42, > +0x58, > +0x50, > +0x43, > +0x0, > +0x0, > +0x42, > +0x58, > +0x53, > +0x53, > +0x44, > +0x54, > +0x53, > +0x55, > +0x1, > +0x0, > +0x0, > +0x0, > +0x49, > +0x4e, > +0x54, > +0x4c, > +0x24, > +0x4, > +0x14, > +0x20, > +0x10, > +0x41, > +0xa, > +0x5c, > +0x5f, > +0x53, > +0x42, > +0x5f, > +0x5b, > +0x82, > +0x48, > +0x9, > +0x56, > +0x4d, > +0x47, > +0x49, > +0x8, > +0x5f, > +0x48, > +0x49, > +0x44, > +0xd, > +0x51, > +0x45, > +0x4d, > +0x55, > +0x30, > +0x30, > +0x30, > +0x32, > +0x0, > +0x8, > +0x5f, > +0x43, > +0x49, > +0x44, > +0xd, > +0x56, > +0x4d, > +0x5f, > +0x47, > +0x65, > +0x6e, > +0x5f, > +0x43, > +0x6f, > +0x75, > +0x6e, > +0x74, > +0x65, > +0x72, > +0x0, > +0x8, > +0x5f, > +0x44, > +0x44, > +0x4e, > +0xd, > +0x56, > +0x4d, > +0x5f, > +0x47, > +0x65, > +0x6e, > +0x5f, > +0x43, > +0x6f, > +0x75, > +0x6e, > +0x74, > +0x65, > +0x72, > +0x0, > +0x8, > +0x56, > +0x47, > +0x49, > +0x41, > +0xc, > +0x78, > +0x56, > +0x34, > +0x12, > +0x8, > +0x56, > +0x47, > +0x49, > +0x44, > +0x11, > +0x13, > +0xa, > +0x10, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x0, > +0x14, > +0x18, > +0x5f, > +0x53, > +0x54, > +0x41, > +0x0, > +0x70, > +0x56, > +0x47, > +0x49, > +0x41, > +0x60, > +0xa0, > +0x6, > +0x93, > +0x60, > +0x0, > +0xa4, > +0x0, > +0xa1, > +0x4, > +0xa4, > +0xa, > +0xf, > +0x14, > +0x1c, > +0x41, > +0x44, > +0x44, > +0x52, > +0x8, > +0x70, > +0x12, > +0x2, > +0x2, > +0x60, > +0x70, > +0x56, > +0x47, > +0x49, > +0x41, > +0x88, > +0x60, > +0x0, > +0x0, > +0x70, > +0x0, > +0x88, > +0x60, > +0x1, > +0x0, > +0xa4, > +0x60 > +}; > +static unsigned char ssdt_acpi_vm_gid_addr[] = { > +0x73 > +}; > +static unsigned char ssdt_acpi_vm_gid[] = { > +0x80 > +}; > diff --git a/hw/misc/Makefile.objs b/hw/misc/Makefile.objs > index 979e532..c18b800 100644 > --- a/hw/misc/Makefile.objs > +++ b/hw/misc/Makefile.objs > @@ -41,3 +41,4 @@ obj-$(CONFIG_SLAVIO) += slavio_misc.o > obj-$(CONFIG_ZYNQ) += zynq_slcr.o > > obj-$(CONFIG_PVPANIC) += pvpanic.o > +obj-$(CONFIG_VMGENID) += vmgenid.o > diff --git a/hw/misc/vmgenid.c b/hw/misc/vmgenid.c > new file mode 100644 > index 0000000..81cc49e > --- /dev/null > +++ b/hw/misc/vmgenid.c > @@ -0,0 +1,84 @@ > +/* > + * Virtual Machine Generation ID Device > + * > + * Copyright (C) 2014 Red Hat Inc. > + * > + * Authors: Gal Hammer <ghammer@redhat.com> > + * > + * This work is licensed under the terms of the GNU GPL, version 2 or later. > + * See the COPYING file in the top-level directory. > + * > + */ > + > +#include "hw/i386/pc.h" > +#include "hw/sysbus.h" > + > +#define VMGENID_DEVICE "vmgenid" > + > +#define PROPERTY_UUID "uuid" > + > +#define VMGENID(obj) OBJECT_CHECK(VmGenIdState, (obj), VMGENID_DEVICE) > + > +typedef struct VmGenIdState { > + SysBusDevice parent_obj; > + char *guid_arg; > +} VmGenIdState; > + > +bool vm_generation_id(uint8_t id[16]) > +{ > + Object *o = object_resolve_path_type("", VMGENID_DEVICE, NULL); > + char *guid; > + > + if (!o) { > + return false; > + } > + guid = object_property_get_str(o, PROPERTY_UUID, NULL); > + /* actual uuid validation was checked during realize. */ > + (void)qemu_uuid_parse(guid, id); > + return true; > +} > + > +static void vmgenid_realize(DeviceState *dev, Error **errp) > +{ > + VmGenIdState *s = VMGENID(dev); > + uint8_t id[16]; > + > + if (!s->guid_arg) { > + error_setg(errp, "missing uuid."); > + return; > + } > + > + if (qemu_uuid_parse(s->guid_arg, id) < 0) { > + error_setg(errp, "Fail to parse UUID string."); > + return; > + } > +} > + > +static Property vmgenid_device_properties[] = { > + DEFINE_PROP_STRING(PROPERTY_UUID, VmGenIdState, guid_arg), > + DEFINE_PROP_END_OF_LIST(), > +}; > + > +static void vmgenid_class_init(ObjectClass *klass, void *data) > +{ > + DeviceClass *dc = DEVICE_CLASS(klass); > + > + dc->realize = vmgenid_realize; > + dc->props = vmgenid_device_properties; > + dc->cannot_instantiate_with_device_add_yet = false; > + set_bit(DEVICE_CATEGORY_MISC, dc->categories); > +} > + > +static const TypeInfo vmgenid_device_info = { > + .name = VMGENID_DEVICE, > + .parent = TYPE_SYS_BUS_DEVICE, > + .instance_size = sizeof(VmGenIdState), > + .class_init = vmgenid_class_init, > +}; > + > +static void vmgenid_register_types(void) > +{ > + type_register_static(&vmgenid_device_info); > +} > + > +type_init(vmgenid_register_types) > diff --git a/include/hw/i386/pc.h b/include/hw/i386/pc.h > index 77316d5..40ecccb 100644 > --- a/include/hw/i386/pc.h > +++ b/include/hw/i386/pc.h > @@ -290,6 +290,9 @@ void pc_system_firmware_init(MemoryRegion *rom_memory, > /* pvpanic.c */ > uint16_t pvpanic_port(void); > > +/* vmgenid.c */ > +bool vm_generation_id(uint8_t id[16]); > + > /* e820 types */ > #define E820_RAM 1 > #define E820_RESERVED 2 > -- > 1.9.3 > ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 2/2] i386: Add a Virtual Machine Generation ID device. 2014-10-02 12:49 ` Michael S. Tsirkin @ 2014-10-02 13:14 ` Gal Hammer 2014-10-02 13:30 ` Michael S. Tsirkin 0 siblings, 1 reply; 20+ messages in thread From: Gal Hammer @ 2014-10-02 13:14 UTC (permalink / raw) To: Michael S. Tsirkin; +Cc: Paolo Bonzini, qemu-devel, Igor Mammedov On 02/10/2014 15:49, Michael S. Tsirkin wrote: > On Wed, Sep 17, 2014 at 02:39:52PM +0300, Gal Hammer wrote: >> Based on Microsoft's sepecifications (paper can be dowloaded from >> http://go.microsoft.com/fwlink/?LinkId=260709), add a device >> description to the SSDT ACPI table. >> >> The GUID is set using a new "vmgenid" device. >> >> Signed-off-by: Gal Hammer <ghammer@redhat.com> >> Reviewed-By: Igor Mammedov <imammedo@redhat.com> >> --- >> default-configs/i386-softmmu.mak | 1 + >> default-configs/x86_64-softmmu.mak | 1 + >> hw/i386/Makefile.objs | 2 +- >> hw/i386/acpi-build.c | 39 +++++++ >> hw/i386/ssdt-vmgenid.dsl | 63 ++++++++++++ >> hw/i386/ssdt-vmgenid.hex.generated | 206 +++++++++++++++++++++++++++++++++++++ >> hw/misc/Makefile.objs | 1 + >> hw/misc/vmgenid.c | 84 +++++++++++++++ >> include/hw/i386/pc.h | 3 + > > Patch scripts/update-acpi.sh as well please. I understand what should be changed there. The script just copy all the *.hex files to *.hex.generated. >> 9 files changed, 399 insertions(+), 1 deletion(-) >> create mode 100644 hw/i386/ssdt-vmgenid.dsl >> create mode 100644 hw/i386/ssdt-vmgenid.hex.generated >> create mode 100644 hw/misc/vmgenid.c >> >> diff --git a/default-configs/i386-softmmu.mak b/default-configs/i386-softmmu.mak >> index 8e08841..bd33c75 100644 >> --- a/default-configs/i386-softmmu.mak >> +++ b/default-configs/i386-softmmu.mak >> @@ -45,3 +45,4 @@ CONFIG_IOAPIC=y >> CONFIG_ICC_BUS=y >> CONFIG_PVPANIC=y >> CONFIG_MEM_HOTPLUG=y >> +CONFIG_VMGENID=y >> diff --git a/default-configs/x86_64-softmmu.mak b/default-configs/x86_64-softmmu.mak >> index 66557ac..006fc7c 100644 >> --- a/default-configs/x86_64-softmmu.mak >> +++ b/default-configs/x86_64-softmmu.mak >> @@ -45,3 +45,4 @@ CONFIG_IOAPIC=y >> CONFIG_ICC_BUS=y >> CONFIG_PVPANIC=y >> CONFIG_MEM_HOTPLUG=y >> +CONFIG_VMGENID=y >> diff --git a/hw/i386/Makefile.objs b/hw/i386/Makefile.objs >> index 9d419ad..cd1beb3 100644 >> --- a/hw/i386/Makefile.objs >> +++ b/hw/i386/Makefile.objs >> @@ -12,7 +12,7 @@ hw/i386/acpi-build.o: hw/i386/acpi-build.c hw/i386/acpi-dsdt.hex \ >> hw/i386/ssdt-proc.hex hw/i386/ssdt-pcihp.hex hw/i386/ssdt-misc.hex \ >> hw/i386/acpi-dsdt.hex hw/i386/q35-acpi-dsdt.hex \ >> hw/i386/q35-acpi-dsdt.hex hw/i386/ssdt-mem.hex \ >> - hw/i386/ssdt-tpm.hex >> + hw/i386/ssdt-tpm.hex hw/i386/ssdt-vmgenid.hex >> >> iasl-option=$(shell if test -z "`$(1) $(2) 2>&1 > /dev/null`" \ >> ; then echo "$(2)"; else echo "$(3)"; fi ;) >> diff --git a/hw/i386/acpi-build.c b/hw/i386/acpi-build.c >> index a313321..72d5a88 100644 >> --- a/hw/i386/acpi-build.c >> +++ b/hw/i386/acpi-build.c >> @@ -96,6 +96,8 @@ typedef struct AcpiMiscInfo { >> const unsigned char *dsdt_code; >> unsigned dsdt_size; >> uint16_t pvpanic_port; >> + bool vm_generation_id_set; >> + uint8_t vm_generation_id[16]; >> } AcpiMiscInfo; >> >> typedef struct AcpiBuildPciBusHotplugState { >> @@ -216,6 +218,7 @@ static void acpi_get_misc_info(AcpiMiscInfo *info) >> info->has_hpet = hpet_find(); >> info->has_tpm = tpm_find(); >> info->pvpanic_port = pvpanic_port(); >> + info->vm_generation_id_set = vm_generation_id(info->vm_generation_id); >> } >> >> static void acpi_get_pci_info(PcPciInfo *info) >> @@ -710,6 +713,7 @@ static inline char acpi_get_hex(uint32_t val) >> #include "hw/i386/ssdt-misc.hex" >> #include "hw/i386/ssdt-pcihp.hex" >> #include "hw/i386/ssdt-tpm.hex" >> +#include "hw/i386/ssdt-vmgenid.hex" >> >> static void >> build_append_notify_method(GArray *device, const char *name, >> @@ -1246,6 +1250,37 @@ build_tpm_ssdt(GArray *table_data, GArray *linker) >> memcpy(tpm_ptr, ssdt_tpm_aml, sizeof(ssdt_tpm_aml)); >> } >> >> +static void >> +build_vmgenid_ssdt(GArray *table_data, GArray *linker, AcpiMiscInfo *info) >> +{ >> + int vgid_start = table_data->len; >> + void *vgid_ptr; >> + uint8_t *vm_gid_ptr; >> + uint32_t vm_gid_physical_address; >> + >> + vgid_ptr = acpi_data_push(table_data, sizeof(ssdt_vmgenid_aml)); >> + memcpy(vgid_ptr, ssdt_vmgenid_aml, sizeof(ssdt_vmgenid_aml)); >> + >> + vm_gid_ptr = acpi_data_get_ptr(vgid_ptr, sizeof(ssdt_vmgenid_aml), >> + *ssdt_acpi_vm_gid, >> + sizeof(info->vm_generation_id)); >> + memcpy(vm_gid_ptr, info->vm_generation_id, >> + sizeof(info->vm_generation_id)); >> + >> + bios_linker_loader_add_pointer(linker, ACPI_BUILD_TABLE_FILE, >> + ACPI_BUILD_TABLE_FILE, >> + table_data, >> + vgid_ptr + *ssdt_acpi_vm_gid_addr, >> + sizeof(uint32_t)); >> + >> + vm_gid_physical_address = vgid_start + *ssdt_acpi_vm_gid; >> + ACPI_BUILD_SET_LE(vgid_ptr, sizeof(ssdt_vmgenid_aml), >> + *ssdt_acpi_vm_gid_addr, 32, vm_gid_physical_address); >> + >> + build_header(linker, table_data, vgid_ptr, "SSDT", >> + sizeof(ssdt_vmgenid_aml), 1); >> +} >> + >> typedef enum { >> MEM_AFFINITY_NOFLAGS = 0, >> MEM_AFFINITY_ENABLED = (1 << 0), >> @@ -1617,6 +1652,10 @@ void acpi_build(PcGuestInfo *guest_info, AcpiBuildTables *tables) >> acpi_add_table(table_offsets, tables->table_data); >> build_tpm_ssdt(tables->table_data, tables->linker); >> } >> + if (misc.vm_generation_id_set) { >> + acpi_add_table(table_offsets, tables->table_data); >> + build_vmgenid_ssdt(tables->table_data, tables->linker, &misc); >> + } >> if (guest_info->numa_nodes) { >> acpi_add_table(table_offsets, tables->table_data); >> build_srat(tables->table_data, tables->linker, &cpu, guest_info); >> diff --git a/hw/i386/ssdt-vmgenid.dsl b/hw/i386/ssdt-vmgenid.dsl >> new file mode 100644 >> index 0000000..fee376f >> --- /dev/null >> +++ b/hw/i386/ssdt-vmgenid.dsl >> @@ -0,0 +1,63 @@ >> +/* >> + * This program is free software; you can redistribute it and/or modify >> + * it under the terms of the GNU General Public License as published by >> + * the Free Software Foundation; either version 2 of the License, or >> + * (at your option) any later version. >> + >> + * This program is distributed in the hope that it will be useful, >> + * but WITHOUT ANY WARRANTY; without even the implied warranty of >> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the >> + * GNU General Public License for more details. >> + >> + * You should have received a copy of the GNU General Public License along >> + * with this program; if not, see <http://www.gnu.org/licenses/>. >> + */ >> + >> +/**************************************************************** >> + * Virtual Machine Generation ID Device >> + ****************************************************************/ >> + >> +ACPI_EXTRACT_ALL_CODE ssdt_vmgenid_aml >> + >> +DefinitionBlock ( >> + "ssdt-vmgenid.aml", // Output Filename >> + "SSDT", // Signature >> + 0x01, // SSDT Compliance Revision >> + "BXPC", // OEMID >> + "BXSSDTSUSP", // TABLE ID >> + 0x1 // OEM Revision >> + ) >> +{ >> + Scope(\_SB) { >> + >> + Device(VMGI) { >> + Name(_HID, "QEMU0002") >> + Name(_CID, "VM_Gen_Counter") >> + Name(_DDN, "VM_Gen_Counter") >> + >> + ACPI_EXTRACT_NAME_DWORD_CONST ssdt_acpi_vm_gid_addr >> + Name(VGIA, 0x12345678) >> + >> + ACPI_EXTRACT_NAME_BUFFER16 ssdt_acpi_vm_gid >> + Name(VGID, Buffer(16) { >> + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, >> + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) > > IMHO, statically allocating the ID in ACPI like this is a mistake. Do you have an idea where else it can be allocated? Since it is just an ACPI declared device without resources. A PCI device with a memory region looks over-kill just to have a known physical address. > For example, your guest might be in hybernation, in this > case it will not re-read ACPI tables on boot. In this case the VGID physical address should stay the same and only the value is updated. So I don't think should be a problem. > Also - what guarantees that this buffer is 8 byte aligned? The spec say nothing about the memory-alignment of the VGID's physical address. If the driver can't read an unaligned address I guess it can do a simple pointers calculation and read from the closest aligned address and beyond the VGID buffer, no? >> + >> + Method(_STA, 0, NotSerialized) { >> + Store(VGIA, Local0) >> + If (LEqual(Local0, Zero)) { >> + Return (0x00) >> + } Else { >> + Return (0x0F) >> + } >> + } >> + >> + Method(ADDR, 0, Serialized) { >> + Store(Package(2) { }, Local0) >> + Store(VGIA, Index(Local0, 0)) >> + Store(0x0000, Index(Local0, 1)) >> + return (Local0) >> + } >> + } >> + } >> +} >> diff --git a/hw/i386/ssdt-vmgenid.hex.generated b/hw/i386/ssdt-vmgenid.hex.generated >> new file mode 100644 >> index 0000000..e96cb36 >> --- /dev/null >> +++ b/hw/i386/ssdt-vmgenid.hex.generated >> @@ -0,0 +1,206 @@ >> +static unsigned char ssdt_vmgenid_aml[] = { >> +0x53, >> +0x53, >> +0x44, >> +0x54, >> +0xc6, >> +0x0, >> +0x0, >> +0x0, >> +0x1, >> +0xeb, >> +0x42, >> +0x58, >> +0x50, >> +0x43, >> +0x0, >> +0x0, >> +0x42, >> +0x58, >> +0x53, >> +0x53, >> +0x44, >> +0x54, >> +0x53, >> +0x55, >> +0x1, >> +0x0, >> +0x0, >> +0x0, >> +0x49, >> +0x4e, >> +0x54, >> +0x4c, >> +0x24, >> +0x4, >> +0x14, >> +0x20, >> +0x10, >> +0x41, >> +0xa, >> +0x5c, >> +0x5f, >> +0x53, >> +0x42, >> +0x5f, >> +0x5b, >> +0x82, >> +0x48, >> +0x9, >> +0x56, >> +0x4d, >> +0x47, >> +0x49, >> +0x8, >> +0x5f, >> +0x48, >> +0x49, >> +0x44, >> +0xd, >> +0x51, >> +0x45, >> +0x4d, >> +0x55, >> +0x30, >> +0x30, >> +0x30, >> +0x32, >> +0x0, >> +0x8, >> +0x5f, >> +0x43, >> +0x49, >> +0x44, >> +0xd, >> +0x56, >> +0x4d, >> +0x5f, >> +0x47, >> +0x65, >> +0x6e, >> +0x5f, >> +0x43, >> +0x6f, >> +0x75, >> +0x6e, >> +0x74, >> +0x65, >> +0x72, >> +0x0, >> +0x8, >> +0x5f, >> +0x44, >> +0x44, >> +0x4e, >> +0xd, >> +0x56, >> +0x4d, >> +0x5f, >> +0x47, >> +0x65, >> +0x6e, >> +0x5f, >> +0x43, >> +0x6f, >> +0x75, >> +0x6e, >> +0x74, >> +0x65, >> +0x72, >> +0x0, >> +0x8, >> +0x56, >> +0x47, >> +0x49, >> +0x41, >> +0xc, >> +0x78, >> +0x56, >> +0x34, >> +0x12, >> +0x8, >> +0x56, >> +0x47, >> +0x49, >> +0x44, >> +0x11, >> +0x13, >> +0xa, >> +0x10, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x0, >> +0x14, >> +0x18, >> +0x5f, >> +0x53, >> +0x54, >> +0x41, >> +0x0, >> +0x70, >> +0x56, >> +0x47, >> +0x49, >> +0x41, >> +0x60, >> +0xa0, >> +0x6, >> +0x93, >> +0x60, >> +0x0, >> +0xa4, >> +0x0, >> +0xa1, >> +0x4, >> +0xa4, >> +0xa, >> +0xf, >> +0x14, >> +0x1c, >> +0x41, >> +0x44, >> +0x44, >> +0x52, >> +0x8, >> +0x70, >> +0x12, >> +0x2, >> +0x2, >> +0x60, >> +0x70, >> +0x56, >> +0x47, >> +0x49, >> +0x41, >> +0x88, >> +0x60, >> +0x0, >> +0x0, >> +0x70, >> +0x0, >> +0x88, >> +0x60, >> +0x1, >> +0x0, >> +0xa4, >> +0x60 >> +}; >> +static unsigned char ssdt_acpi_vm_gid_addr[] = { >> +0x73 >> +}; >> +static unsigned char ssdt_acpi_vm_gid[] = { >> +0x80 >> +}; >> diff --git a/hw/misc/Makefile.objs b/hw/misc/Makefile.objs >> index 979e532..c18b800 100644 >> --- a/hw/misc/Makefile.objs >> +++ b/hw/misc/Makefile.objs >> @@ -41,3 +41,4 @@ obj-$(CONFIG_SLAVIO) += slavio_misc.o >> obj-$(CONFIG_ZYNQ) += zynq_slcr.o >> >> obj-$(CONFIG_PVPANIC) += pvpanic.o >> +obj-$(CONFIG_VMGENID) += vmgenid.o >> diff --git a/hw/misc/vmgenid.c b/hw/misc/vmgenid.c >> new file mode 100644 >> index 0000000..81cc49e >> --- /dev/null >> +++ b/hw/misc/vmgenid.c >> @@ -0,0 +1,84 @@ >> +/* >> + * Virtual Machine Generation ID Device >> + * >> + * Copyright (C) 2014 Red Hat Inc. >> + * >> + * Authors: Gal Hammer <ghammer@redhat.com> >> + * >> + * This work is licensed under the terms of the GNU GPL, version 2 or later. >> + * See the COPYING file in the top-level directory. >> + * >> + */ >> + >> +#include "hw/i386/pc.h" >> +#include "hw/sysbus.h" >> + >> +#define VMGENID_DEVICE "vmgenid" >> + >> +#define PROPERTY_UUID "uuid" >> + >> +#define VMGENID(obj) OBJECT_CHECK(VmGenIdState, (obj), VMGENID_DEVICE) >> + >> +typedef struct VmGenIdState { >> + SysBusDevice parent_obj; >> + char *guid_arg; >> +} VmGenIdState; >> + >> +bool vm_generation_id(uint8_t id[16]) >> +{ >> + Object *o = object_resolve_path_type("", VMGENID_DEVICE, NULL); >> + char *guid; >> + >> + if (!o) { >> + return false; >> + } >> + guid = object_property_get_str(o, PROPERTY_UUID, NULL); >> + /* actual uuid validation was checked during realize. */ >> + (void)qemu_uuid_parse(guid, id); >> + return true; >> +} >> + >> +static void vmgenid_realize(DeviceState *dev, Error **errp) >> +{ >> + VmGenIdState *s = VMGENID(dev); >> + uint8_t id[16]; >> + >> + if (!s->guid_arg) { >> + error_setg(errp, "missing uuid."); >> + return; >> + } >> + >> + if (qemu_uuid_parse(s->guid_arg, id) < 0) { >> + error_setg(errp, "Fail to parse UUID string."); >> + return; >> + } >> +} >> + >> +static Property vmgenid_device_properties[] = { >> + DEFINE_PROP_STRING(PROPERTY_UUID, VmGenIdState, guid_arg), >> + DEFINE_PROP_END_OF_LIST(), >> +}; >> + >> +static void vmgenid_class_init(ObjectClass *klass, void *data) >> +{ >> + DeviceClass *dc = DEVICE_CLASS(klass); >> + >> + dc->realize = vmgenid_realize; >> + dc->props = vmgenid_device_properties; >> + dc->cannot_instantiate_with_device_add_yet = false; >> + set_bit(DEVICE_CATEGORY_MISC, dc->categories); >> +} >> + >> +static const TypeInfo vmgenid_device_info = { >> + .name = VMGENID_DEVICE, >> + .parent = TYPE_SYS_BUS_DEVICE, >> + .instance_size = sizeof(VmGenIdState), >> + .class_init = vmgenid_class_init, >> +}; >> + >> +static void vmgenid_register_types(void) >> +{ >> + type_register_static(&vmgenid_device_info); >> +} >> + >> +type_init(vmgenid_register_types) >> diff --git a/include/hw/i386/pc.h b/include/hw/i386/pc.h >> index 77316d5..40ecccb 100644 >> --- a/include/hw/i386/pc.h >> +++ b/include/hw/i386/pc.h >> @@ -290,6 +290,9 @@ void pc_system_firmware_init(MemoryRegion *rom_memory, >> /* pvpanic.c */ >> uint16_t pvpanic_port(void); >> >> +/* vmgenid.c */ >> +bool vm_generation_id(uint8_t id[16]); >> + >> /* e820 types */ >> #define E820_RAM 1 >> #define E820_RESERVED 2 >> -- >> 1.9.3 >> ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 2/2] i386: Add a Virtual Machine Generation ID device. 2014-10-02 13:14 ` Gal Hammer @ 2014-10-02 13:30 ` Michael S. Tsirkin 0 siblings, 0 replies; 20+ messages in thread From: Michael S. Tsirkin @ 2014-10-02 13:30 UTC (permalink / raw) To: Gal Hammer; +Cc: Paolo Bonzini, qemu-devel, Igor Mammedov On Thu, Oct 02, 2014 at 04:14:05PM +0300, Gal Hammer wrote: > On 02/10/2014 15:49, Michael S. Tsirkin wrote: > >On Wed, Sep 17, 2014 at 02:39:52PM +0300, Gal Hammer wrote: > >>Based on Microsoft's sepecifications (paper can be dowloaded from > >>http://go.microsoft.com/fwlink/?LinkId=260709), add a device > >>description to the SSDT ACPI table. > >> > >>The GUID is set using a new "vmgenid" device. > >> > >>Signed-off-by: Gal Hammer <ghammer@redhat.com> > >>Reviewed-By: Igor Mammedov <imammedo@redhat.com> > >>--- > >> default-configs/i386-softmmu.mak | 1 + > >> default-configs/x86_64-softmmu.mak | 1 + > >> hw/i386/Makefile.objs | 2 +- > >> hw/i386/acpi-build.c | 39 +++++++ > >> hw/i386/ssdt-vmgenid.dsl | 63 ++++++++++++ > >> hw/i386/ssdt-vmgenid.hex.generated | 206 +++++++++++++++++++++++++++++++++++++ > >> hw/misc/Makefile.objs | 1 + > >> hw/misc/vmgenid.c | 84 +++++++++++++++ > >> include/hw/i386/pc.h | 3 + > > > >Patch scripts/update-acpi.sh as well please. > > I understand what should be changed there. The script just copy all the > *.hex files to *.hex.generated. > > >> 9 files changed, 399 insertions(+), 1 deletion(-) > >> create mode 100644 hw/i386/ssdt-vmgenid.dsl > >> create mode 100644 hw/i386/ssdt-vmgenid.hex.generated > >> create mode 100644 hw/misc/vmgenid.c > >> > >>diff --git a/default-configs/i386-softmmu.mak b/default-configs/i386-softmmu.mak > >>index 8e08841..bd33c75 100644 > >>--- a/default-configs/i386-softmmu.mak > >>+++ b/default-configs/i386-softmmu.mak > >>@@ -45,3 +45,4 @@ CONFIG_IOAPIC=y > >> CONFIG_ICC_BUS=y > >> CONFIG_PVPANIC=y > >> CONFIG_MEM_HOTPLUG=y > >>+CONFIG_VMGENID=y > >>diff --git a/default-configs/x86_64-softmmu.mak b/default-configs/x86_64-softmmu.mak > >>index 66557ac..006fc7c 100644 > >>--- a/default-configs/x86_64-softmmu.mak > >>+++ b/default-configs/x86_64-softmmu.mak > >>@@ -45,3 +45,4 @@ CONFIG_IOAPIC=y > >> CONFIG_ICC_BUS=y > >> CONFIG_PVPANIC=y > >> CONFIG_MEM_HOTPLUG=y > >>+CONFIG_VMGENID=y > >>diff --git a/hw/i386/Makefile.objs b/hw/i386/Makefile.objs > >>index 9d419ad..cd1beb3 100644 > >>--- a/hw/i386/Makefile.objs > >>+++ b/hw/i386/Makefile.objs > >>@@ -12,7 +12,7 @@ hw/i386/acpi-build.o: hw/i386/acpi-build.c hw/i386/acpi-dsdt.hex \ > >> hw/i386/ssdt-proc.hex hw/i386/ssdt-pcihp.hex hw/i386/ssdt-misc.hex \ > >> hw/i386/acpi-dsdt.hex hw/i386/q35-acpi-dsdt.hex \ > >> hw/i386/q35-acpi-dsdt.hex hw/i386/ssdt-mem.hex \ > >>- hw/i386/ssdt-tpm.hex > >>+ hw/i386/ssdt-tpm.hex hw/i386/ssdt-vmgenid.hex > >> > >> iasl-option=$(shell if test -z "`$(1) $(2) 2>&1 > /dev/null`" \ > >> ; then echo "$(2)"; else echo "$(3)"; fi ;) > >>diff --git a/hw/i386/acpi-build.c b/hw/i386/acpi-build.c > >>index a313321..72d5a88 100644 > >>--- a/hw/i386/acpi-build.c > >>+++ b/hw/i386/acpi-build.c > >>@@ -96,6 +96,8 @@ typedef struct AcpiMiscInfo { > >> const unsigned char *dsdt_code; > >> unsigned dsdt_size; > >> uint16_t pvpanic_port; > >>+ bool vm_generation_id_set; > >>+ uint8_t vm_generation_id[16]; > >> } AcpiMiscInfo; > >> > >> typedef struct AcpiBuildPciBusHotplugState { > >>@@ -216,6 +218,7 @@ static void acpi_get_misc_info(AcpiMiscInfo *info) > >> info->has_hpet = hpet_find(); > >> info->has_tpm = tpm_find(); > >> info->pvpanic_port = pvpanic_port(); > >>+ info->vm_generation_id_set = vm_generation_id(info->vm_generation_id); > >> } > >> > >> static void acpi_get_pci_info(PcPciInfo *info) > >>@@ -710,6 +713,7 @@ static inline char acpi_get_hex(uint32_t val) > >> #include "hw/i386/ssdt-misc.hex" > >> #include "hw/i386/ssdt-pcihp.hex" > >> #include "hw/i386/ssdt-tpm.hex" > >>+#include "hw/i386/ssdt-vmgenid.hex" > >> > >> static void > >> build_append_notify_method(GArray *device, const char *name, > >>@@ -1246,6 +1250,37 @@ build_tpm_ssdt(GArray *table_data, GArray *linker) > >> memcpy(tpm_ptr, ssdt_tpm_aml, sizeof(ssdt_tpm_aml)); > >> } > >> > >>+static void > >>+build_vmgenid_ssdt(GArray *table_data, GArray *linker, AcpiMiscInfo *info) > >>+{ > >>+ int vgid_start = table_data->len; > >>+ void *vgid_ptr; > >>+ uint8_t *vm_gid_ptr; > >>+ uint32_t vm_gid_physical_address; > >>+ > >>+ vgid_ptr = acpi_data_push(table_data, sizeof(ssdt_vmgenid_aml)); > >>+ memcpy(vgid_ptr, ssdt_vmgenid_aml, sizeof(ssdt_vmgenid_aml)); > >>+ > >>+ vm_gid_ptr = acpi_data_get_ptr(vgid_ptr, sizeof(ssdt_vmgenid_aml), > >>+ *ssdt_acpi_vm_gid, > >>+ sizeof(info->vm_generation_id)); > >>+ memcpy(vm_gid_ptr, info->vm_generation_id, > >>+ sizeof(info->vm_generation_id)); > >>+ > >>+ bios_linker_loader_add_pointer(linker, ACPI_BUILD_TABLE_FILE, > >>+ ACPI_BUILD_TABLE_FILE, > >>+ table_data, > >>+ vgid_ptr + *ssdt_acpi_vm_gid_addr, > >>+ sizeof(uint32_t)); > >>+ > >>+ vm_gid_physical_address = vgid_start + *ssdt_acpi_vm_gid; > >>+ ACPI_BUILD_SET_LE(vgid_ptr, sizeof(ssdt_vmgenid_aml), > >>+ *ssdt_acpi_vm_gid_addr, 32, vm_gid_physical_address); > >>+ > >>+ build_header(linker, table_data, vgid_ptr, "SSDT", > >>+ sizeof(ssdt_vmgenid_aml), 1); > >>+} > >>+ > >> typedef enum { > >> MEM_AFFINITY_NOFLAGS = 0, > >> MEM_AFFINITY_ENABLED = (1 << 0), > >>@@ -1617,6 +1652,10 @@ void acpi_build(PcGuestInfo *guest_info, AcpiBuildTables *tables) > >> acpi_add_table(table_offsets, tables->table_data); > >> build_tpm_ssdt(tables->table_data, tables->linker); > >> } > >>+ if (misc.vm_generation_id_set) { > >>+ acpi_add_table(table_offsets, tables->table_data); > >>+ build_vmgenid_ssdt(tables->table_data, tables->linker, &misc); > >>+ } > >> if (guest_info->numa_nodes) { > >> acpi_add_table(table_offsets, tables->table_data); > >> build_srat(tables->table_data, tables->linker, &cpu, guest_info); > >>diff --git a/hw/i386/ssdt-vmgenid.dsl b/hw/i386/ssdt-vmgenid.dsl > >>new file mode 100644 > >>index 0000000..fee376f > >>--- /dev/null > >>+++ b/hw/i386/ssdt-vmgenid.dsl > >>@@ -0,0 +1,63 @@ > >>+/* > >>+ * This program is free software; you can redistribute it and/or modify > >>+ * it under the terms of the GNU General Public License as published by > >>+ * the Free Software Foundation; either version 2 of the License, or > >>+ * (at your option) any later version. > >>+ > >>+ * This program is distributed in the hope that it will be useful, > >>+ * but WITHOUT ANY WARRANTY; without even the implied warranty of > >>+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > >>+ * GNU General Public License for more details. > >>+ > >>+ * You should have received a copy of the GNU General Public License along > >>+ * with this program; if not, see <http://www.gnu.org/licenses/>. > >>+ */ > >>+ > >>+/**************************************************************** > >>+ * Virtual Machine Generation ID Device > >>+ ****************************************************************/ > >>+ > >>+ACPI_EXTRACT_ALL_CODE ssdt_vmgenid_aml > >>+ > >>+DefinitionBlock ( > >>+ "ssdt-vmgenid.aml", // Output Filename > >>+ "SSDT", // Signature > >>+ 0x01, // SSDT Compliance Revision > >>+ "BXPC", // OEMID > >>+ "BXSSDTSUSP", // TABLE ID > >>+ 0x1 // OEM Revision > >>+ ) > >>+{ > >>+ Scope(\_SB) { > >>+ > >>+ Device(VMGI) { > >>+ Name(_HID, "QEMU0002") > >>+ Name(_CID, "VM_Gen_Counter") > >>+ Name(_DDN, "VM_Gen_Counter") > >>+ > >>+ ACPI_EXTRACT_NAME_DWORD_CONST ssdt_acpi_vm_gid_addr > >>+ Name(VGIA, 0x12345678) > >>+ > >>+ ACPI_EXTRACT_NAME_BUFFER16 ssdt_acpi_vm_gid > >>+ Name(VGID, Buffer(16) { > >>+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, > >>+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) > > > >IMHO, statically allocating the ID in ACPI like this is a mistake. > > Do you have an idea where else it can be allocated? Since it is just an ACPI > declared device without resources. A PCI device with a memory region looks > over-kill just to have a known physical address. I guess you can reserve some memory in E820, but that's pretty involved. It might be a better idea to allocate buffer e.g. like TPM does, but fill the data in from hypervisor, by passing the physical address back to host. _INI might work for this. > >For example, your guest might be in hybernation, in this > >case it will not re-read ACPI tables on boot. > > In this case the VGID physical address should stay the same and only the > value is updated. So I don't think should be a problem. What will update the value? ACPI tables in qemu are ignored. > >Also - what guarantees that this buffer is 8 byte aligned? > > The spec say nothing about the memory-alignment of the VGID's physical > address. > If the driver can't read an unaligned address I guess it can do a > simple pointers calculation and read from the closest aligned address and > beyond the VGID buffer, no? > >>+ > >>+ Method(_STA, 0, NotSerialized) { > >>+ Store(VGIA, Local0) > >>+ If (LEqual(Local0, Zero)) { > >>+ Return (0x00) > >>+ } Else { > >>+ Return (0x0F) > >>+ } > >>+ } > >>+ > >>+ Method(ADDR, 0, Serialized) { > >>+ Store(Package(2) { }, Local0) > >>+ Store(VGIA, Index(Local0, 0)) > >>+ Store(0x0000, Index(Local0, 1)) > >>+ return (Local0) > >>+ } > >>+ } > >>+ } > >>+} > >>diff --git a/hw/i386/ssdt-vmgenid.hex.generated b/hw/i386/ssdt-vmgenid.hex.generated > >>new file mode 100644 > >>index 0000000..e96cb36 > >>--- /dev/null > >>+++ b/hw/i386/ssdt-vmgenid.hex.generated > >>@@ -0,0 +1,206 @@ > >>+static unsigned char ssdt_vmgenid_aml[] = { > >>+0x53, > >>+0x53, > >>+0x44, > >>+0x54, > >>+0xc6, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x1, > >>+0xeb, > >>+0x42, > >>+0x58, > >>+0x50, > >>+0x43, > >>+0x0, > >>+0x0, > >>+0x42, > >>+0x58, > >>+0x53, > >>+0x53, > >>+0x44, > >>+0x54, > >>+0x53, > >>+0x55, > >>+0x1, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x49, > >>+0x4e, > >>+0x54, > >>+0x4c, > >>+0x24, > >>+0x4, > >>+0x14, > >>+0x20, > >>+0x10, > >>+0x41, > >>+0xa, > >>+0x5c, > >>+0x5f, > >>+0x53, > >>+0x42, > >>+0x5f, > >>+0x5b, > >>+0x82, > >>+0x48, > >>+0x9, > >>+0x56, > >>+0x4d, > >>+0x47, > >>+0x49, > >>+0x8, > >>+0x5f, > >>+0x48, > >>+0x49, > >>+0x44, > >>+0xd, > >>+0x51, > >>+0x45, > >>+0x4d, > >>+0x55, > >>+0x30, > >>+0x30, > >>+0x30, > >>+0x32, > >>+0x0, > >>+0x8, > >>+0x5f, > >>+0x43, > >>+0x49, > >>+0x44, > >>+0xd, > >>+0x56, > >>+0x4d, > >>+0x5f, > >>+0x47, > >>+0x65, > >>+0x6e, > >>+0x5f, > >>+0x43, > >>+0x6f, > >>+0x75, > >>+0x6e, > >>+0x74, > >>+0x65, > >>+0x72, > >>+0x0, > >>+0x8, > >>+0x5f, > >>+0x44, > >>+0x44, > >>+0x4e, > >>+0xd, > >>+0x56, > >>+0x4d, > >>+0x5f, > >>+0x47, > >>+0x65, > >>+0x6e, > >>+0x5f, > >>+0x43, > >>+0x6f, > >>+0x75, > >>+0x6e, > >>+0x74, > >>+0x65, > >>+0x72, > >>+0x0, > >>+0x8, > >>+0x56, > >>+0x47, > >>+0x49, > >>+0x41, > >>+0xc, > >>+0x78, > >>+0x56, > >>+0x34, > >>+0x12, > >>+0x8, > >>+0x56, > >>+0x47, > >>+0x49, > >>+0x44, > >>+0x11, > >>+0x13, > >>+0xa, > >>+0x10, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x0, > >>+0x14, > >>+0x18, > >>+0x5f, > >>+0x53, > >>+0x54, > >>+0x41, > >>+0x0, > >>+0x70, > >>+0x56, > >>+0x47, > >>+0x49, > >>+0x41, > >>+0x60, > >>+0xa0, > >>+0x6, > >>+0x93, > >>+0x60, > >>+0x0, > >>+0xa4, > >>+0x0, > >>+0xa1, > >>+0x4, > >>+0xa4, > >>+0xa, > >>+0xf, > >>+0x14, > >>+0x1c, > >>+0x41, > >>+0x44, > >>+0x44, > >>+0x52, > >>+0x8, > >>+0x70, > >>+0x12, > >>+0x2, > >>+0x2, > >>+0x60, > >>+0x70, > >>+0x56, > >>+0x47, > >>+0x49, > >>+0x41, > >>+0x88, > >>+0x60, > >>+0x0, > >>+0x0, > >>+0x70, > >>+0x0, > >>+0x88, > >>+0x60, > >>+0x1, > >>+0x0, > >>+0xa4, > >>+0x60 > >>+}; > >>+static unsigned char ssdt_acpi_vm_gid_addr[] = { > >>+0x73 > >>+}; > >>+static unsigned char ssdt_acpi_vm_gid[] = { > >>+0x80 > >>+}; > >>diff --git a/hw/misc/Makefile.objs b/hw/misc/Makefile.objs > >>index 979e532..c18b800 100644 > >>--- a/hw/misc/Makefile.objs > >>+++ b/hw/misc/Makefile.objs > >>@@ -41,3 +41,4 @@ obj-$(CONFIG_SLAVIO) += slavio_misc.o > >> obj-$(CONFIG_ZYNQ) += zynq_slcr.o > >> > >> obj-$(CONFIG_PVPANIC) += pvpanic.o > >>+obj-$(CONFIG_VMGENID) += vmgenid.o > >>diff --git a/hw/misc/vmgenid.c b/hw/misc/vmgenid.c > >>new file mode 100644 > >>index 0000000..81cc49e > >>--- /dev/null > >>+++ b/hw/misc/vmgenid.c > >>@@ -0,0 +1,84 @@ > >>+/* > >>+ * Virtual Machine Generation ID Device > >>+ * > >>+ * Copyright (C) 2014 Red Hat Inc. > >>+ * > >>+ * Authors: Gal Hammer <ghammer@redhat.com> > >>+ * > >>+ * This work is licensed under the terms of the GNU GPL, version 2 or later. > >>+ * See the COPYING file in the top-level directory. > >>+ * > >>+ */ > >>+ > >>+#include "hw/i386/pc.h" > >>+#include "hw/sysbus.h" > >>+ > >>+#define VMGENID_DEVICE "vmgenid" > >>+ > >>+#define PROPERTY_UUID "uuid" > >>+ > >>+#define VMGENID(obj) OBJECT_CHECK(VmGenIdState, (obj), VMGENID_DEVICE) > >>+ > >>+typedef struct VmGenIdState { > >>+ SysBusDevice parent_obj; > >>+ char *guid_arg; > >>+} VmGenIdState; > >>+ > >>+bool vm_generation_id(uint8_t id[16]) > >>+{ > >>+ Object *o = object_resolve_path_type("", VMGENID_DEVICE, NULL); > >>+ char *guid; > >>+ > >>+ if (!o) { > >>+ return false; > >>+ } > >>+ guid = object_property_get_str(o, PROPERTY_UUID, NULL); > >>+ /* actual uuid validation was checked during realize. */ > >>+ (void)qemu_uuid_parse(guid, id); > >>+ return true; > >>+} > >>+ > >>+static void vmgenid_realize(DeviceState *dev, Error **errp) > >>+{ > >>+ VmGenIdState *s = VMGENID(dev); > >>+ uint8_t id[16]; > >>+ > >>+ if (!s->guid_arg) { > >>+ error_setg(errp, "missing uuid."); > >>+ return; > >>+ } > >>+ > >>+ if (qemu_uuid_parse(s->guid_arg, id) < 0) { > >>+ error_setg(errp, "Fail to parse UUID string."); > >>+ return; > >>+ } > >>+} > >>+ > >>+static Property vmgenid_device_properties[] = { > >>+ DEFINE_PROP_STRING(PROPERTY_UUID, VmGenIdState, guid_arg), > >>+ DEFINE_PROP_END_OF_LIST(), > >>+}; > >>+ > >>+static void vmgenid_class_init(ObjectClass *klass, void *data) > >>+{ > >>+ DeviceClass *dc = DEVICE_CLASS(klass); > >>+ > >>+ dc->realize = vmgenid_realize; > >>+ dc->props = vmgenid_device_properties; > >>+ dc->cannot_instantiate_with_device_add_yet = false; > >>+ set_bit(DEVICE_CATEGORY_MISC, dc->categories); > >>+} > >>+ > >>+static const TypeInfo vmgenid_device_info = { > >>+ .name = VMGENID_DEVICE, > >>+ .parent = TYPE_SYS_BUS_DEVICE, > >>+ .instance_size = sizeof(VmGenIdState), > >>+ .class_init = vmgenid_class_init, > >>+}; > >>+ > >>+static void vmgenid_register_types(void) > >>+{ > >>+ type_register_static(&vmgenid_device_info); > >>+} > >>+ > >>+type_init(vmgenid_register_types) > >>diff --git a/include/hw/i386/pc.h b/include/hw/i386/pc.h > >>index 77316d5..40ecccb 100644 > >>--- a/include/hw/i386/pc.h > >>+++ b/include/hw/i386/pc.h > >>@@ -290,6 +290,9 @@ void pc_system_firmware_init(MemoryRegion *rom_memory, > >> /* pvpanic.c */ > >> uint16_t pvpanic_port(void); > >> > >>+/* vmgenid.c */ > >>+bool vm_generation_id(uint8_t id[16]); > >>+ > >> /* e820 types */ > >> #define E820_RAM 1 > >> #define E820_RESERVED 2 > >>-- > >>1.9.3 > >> ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID 2014-09-17 11:39 [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID Gal Hammer 2014-09-17 11:39 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 2014-09-17 11:39 ` [Qemu-devel] [PATCH 2/2] i386: Add a Virtual Machine Generation ID device Gal Hammer @ 2014-10-01 8:58 ` Markus Armbruster 2014-10-02 8:32 ` Gal Hammer 2014-10-02 12:12 ` Michael S. Tsirkin 2014-10-06 9:06 ` Daniel P. Berrange 4 siblings, 1 reply; 20+ messages in thread From: Markus Armbruster @ 2014-10-01 8:58 UTC (permalink / raw) To: Gal Hammer; +Cc: Paolo Bonzini, qemu-devel, Igor Mammedov Did this get stuck? Gal Hammer <ghammer@redhat.com> writes: > Hi, > > A two parts patch to add a QEmu support for Microsoft's Virtual Machine > Generation ID device. > > The first one add a new ACPI directive which allow to use a 16-bytes > buffer in an ACPI table. This buffer is for storing the VM's UUID. > > The second is the ACPI tables changes and the actual device. > > Your comment are welcomed. > > Thanks, > > Gal. > > V5: - include the pre-compiled ASL file > - remove an empty line at end of files. > > V4: - Move device's description to SSDT table (dynamic build). > > V3: - Fix a typo in error message string. > - Move device's description from DSDT back to SSDT table. > > V2: - Remove "-uuid" command line parameter. > - Move device's description from SSDT to DSDT table. > - Add new "vmgenid" sysbus device. ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID 2014-10-01 8:58 ` [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID Markus Armbruster @ 2014-10-02 8:32 ` Gal Hammer 2014-10-02 8:46 ` Michael S. Tsirkin 0 siblings, 1 reply; 20+ messages in thread From: Gal Hammer @ 2014-10-02 8:32 UTC (permalink / raw) To: Markus Armbruster; +Cc: Paolo Bonzini, mst, qemu-devel, Igor Mammedov On 01/10/2014 11:58, Markus Armbruster wrote: > Did this get stuck? I think so. Did I miss a comment which was not handled in the last version of the patch? Gal. > Gal Hammer <ghammer@redhat.com> writes: > >> Hi, >> >> A two parts patch to add a QEmu support for Microsoft's Virtual Machine >> Generation ID device. >> >> The first one add a new ACPI directive which allow to use a 16-bytes >> buffer in an ACPI table. This buffer is for storing the VM's UUID. >> >> The second is the ACPI tables changes and the actual device. >> >> Your comment are welcomed. >> >> Thanks, >> >> Gal. >> >> V5: - include the pre-compiled ASL file >> - remove an empty line at end of files. >> >> V4: - Move device's description to SSDT table (dynamic build). >> >> V3: - Fix a typo in error message string. >> - Move device's description from DSDT back to SSDT table. >> >> V2: - Remove "-uuid" command line parameter. >> - Move device's description from SSDT to DSDT table. >> - Add new "vmgenid" sysbus device. ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID 2014-10-02 8:32 ` Gal Hammer @ 2014-10-02 8:46 ` Michael S. Tsirkin 0 siblings, 0 replies; 20+ messages in thread From: Michael S. Tsirkin @ 2014-10-02 8:46 UTC (permalink / raw) To: Gal Hammer; +Cc: Paolo Bonzini, Igor Mammedov, Markus Armbruster, qemu-devel On Thu, Oct 02, 2014 at 11:32:42AM +0300, Gal Hammer wrote: > On 01/10/2014 11:58, Markus Armbruster wrote: > >Did this get stuck? > > I think so. Did I miss a comment which was not handled in the last version > of the patch? > > Gal. I don't think you did but you have to Cc maintainers if you want your patches to be applied :) I'll queue this for review, thanks! > >Gal Hammer <ghammer@redhat.com> writes: > > > >>Hi, > >> > >>A two parts patch to add a QEmu support for Microsoft's Virtual Machine > >>Generation ID device. > >> > >>The first one add a new ACPI directive which allow to use a 16-bytes > >>buffer in an ACPI table. This buffer is for storing the VM's UUID. > >> > >>The second is the ACPI tables changes and the actual device. > >> > >>Your comment are welcomed. > >> > >>Thanks, > >> > >> Gal. > >> > >>V5: - include the pre-compiled ASL file > >> - remove an empty line at end of files. > >> > >>V4: - Move device's description to SSDT table (dynamic build). > >> > >>V3: - Fix a typo in error message string. > >> - Move device's description from DSDT back to SSDT table. > >> > >>V2: - Remove "-uuid" command line parameter. > >> - Move device's description from SSDT to DSDT table. > >> - Add new "vmgenid" sysbus device. > ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID 2014-09-17 11:39 [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID Gal Hammer ` (2 preceding siblings ...) 2014-10-01 8:58 ` [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID Markus Armbruster @ 2014-10-02 12:12 ` Michael S. Tsirkin 2014-10-02 12:16 ` Michael S. Tsirkin 2014-10-06 9:06 ` Daniel P. Berrange 4 siblings, 1 reply; 20+ messages in thread From: Michael S. Tsirkin @ 2014-10-02 12:12 UTC (permalink / raw) To: Gal Hammer; +Cc: Paolo Bonzini, qemu-devel, Igor Mammedov On Wed, Sep 17, 2014 at 02:39:50PM +0300, Gal Hammer wrote: > Hi, > > A two parts patch to add a QEmu support for Microsoft's Virtual Machine > Generation ID device. > > The first one add a new ACPI directive which allow to use a 16-bytes > buffer in an ACPI table. This buffer is for storing the VM's UUID. > > The second is the ACPI tables changes and the actual device. > > Your comment are welcomed. > > Thanks, > > Gal. I applied this, thanks! > V5: - include the pre-compiled ASL file > - remove an empty line at end of files. > > V4: - Move device's description to SSDT table (dynamic build). > > V3: - Fix a typo in error message string. > - Move device's description from DSDT back to SSDT table. > > V2: - Remove "-uuid" command line parameter. > - Move device's description from SSDT to DSDT table. > - Add new "vmgenid" sysbus device. > > Gal Hammer (2): > i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. > i386: Add a Virtual Machine Generation ID device. > > default-configs/i386-softmmu.mak | 1 + > default-configs/x86_64-softmmu.mak | 1 + > hw/i386/Makefile.objs | 2 +- > hw/i386/acpi-build.c | 39 +++++++ > hw/i386/ssdt-vmgenid.dsl | 63 ++++++++++++ > hw/i386/ssdt-vmgenid.hex.generated | 206 +++++++++++++++++++++++++++++++++++++ > hw/misc/Makefile.objs | 1 + > hw/misc/vmgenid.c | 84 +++++++++++++++ > include/hw/i386/pc.h | 3 + > scripts/acpi_extract.py | 23 +++-- > 10 files changed, 413 insertions(+), 10 deletions(-) > create mode 100644 hw/i386/ssdt-vmgenid.dsl > create mode 100644 hw/i386/ssdt-vmgenid.hex.generated > create mode 100644 hw/misc/vmgenid.c > > -- > 1.9.3 > ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID 2014-10-02 12:12 ` Michael S. Tsirkin @ 2014-10-02 12:16 ` Michael S. Tsirkin 0 siblings, 0 replies; 20+ messages in thread From: Michael S. Tsirkin @ 2014-10-02 12:16 UTC (permalink / raw) To: Gal Hammer; +Cc: Paolo Bonzini, qemu-devel, Igor Mammedov On Thu, Oct 02, 2014 at 03:12:53PM +0300, Michael S. Tsirkin wrote: > On Wed, Sep 17, 2014 at 02:39:50PM +0300, Gal Hammer wrote: > > Hi, > > > > A two parts patch to add a QEmu support for Microsoft's Virtual Machine > > Generation ID device. > > > > The first one add a new ACPI directive which allow to use a 16-bytes > > buffer in an ACPI table. This buffer is for storing the VM's UUID. > > > > The second is the ACPI tables changes and the actual device. > > > > Your comment are welcomed. > > > > Thanks, > > > > Gal. > > I applied this, thanks! Ooops wrong thread :( I will review this now though. > > V5: - include the pre-compiled ASL file > > - remove an empty line at end of files. > > > > V4: - Move device's description to SSDT table (dynamic build). > > > > V3: - Fix a typo in error message string. > > - Move device's description from DSDT back to SSDT table. > > > > V2: - Remove "-uuid" command line parameter. > > - Move device's description from SSDT to DSDT table. > > - Add new "vmgenid" sysbus device. > > > > Gal Hammer (2): > > i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. > > i386: Add a Virtual Machine Generation ID device. > > > > default-configs/i386-softmmu.mak | 1 + > > default-configs/x86_64-softmmu.mak | 1 + > > hw/i386/Makefile.objs | 2 +- > > hw/i386/acpi-build.c | 39 +++++++ > > hw/i386/ssdt-vmgenid.dsl | 63 ++++++++++++ > > hw/i386/ssdt-vmgenid.hex.generated | 206 +++++++++++++++++++++++++++++++++++++ > > hw/misc/Makefile.objs | 1 + > > hw/misc/vmgenid.c | 84 +++++++++++++++ > > include/hw/i386/pc.h | 3 + > > scripts/acpi_extract.py | 23 +++-- > > 10 files changed, 413 insertions(+), 10 deletions(-) > > create mode 100644 hw/i386/ssdt-vmgenid.dsl > > create mode 100644 hw/i386/ssdt-vmgenid.hex.generated > > create mode 100644 hw/misc/vmgenid.c > > > > -- > > 1.9.3 > > ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID 2014-09-17 11:39 [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID Gal Hammer ` (3 preceding siblings ...) 2014-10-02 12:12 ` Michael S. Tsirkin @ 2014-10-06 9:06 ` Daniel P. Berrange 2014-10-06 12:48 ` Paolo Bonzini 4 siblings, 1 reply; 20+ messages in thread From: Daniel P. Berrange @ 2014-10-06 9:06 UTC (permalink / raw) To: Gal Hammer; +Cc: Paolo Bonzini, qemu-devel, Igor Mammedov On Wed, Sep 17, 2014 at 02:39:50PM +0300, Gal Hammer wrote: > Hi, > > A two parts patch to add a QEmu support for Microsoft's Virtual Machine > Generation ID device. > > The first one add a new ACPI directive which allow to use a 16-bytes > buffer in an ACPI table. This buffer is for storing the VM's UUID. > > The second is the ACPI tables changes and the actual device. > > Your comment are welcomed. There are some rules on when the VM generation ID *must* change Virtual machine is paused or resumed: No Virtual machine reboots: No Virtual machine host reboots: No Virtual machine starts executing a snapshot (every time): Yes Virtual machine is recovered from backup: Yes Virtual machine is failed over in a disaster recovery environment: Yes Virtual machine is live migrated: No Virtual machine is imported, copied, or cloned: Yes Virtual machine is failed over in a clustered environment: No Virtual machine's configuration changes: Unspecified Now this can largely be accomplished by libvirt by simply changing the value of the -vmgenid command line parameter, because most of these scenarios involve the spawning of a new QEMU process. The exception I think is when a running guest is reverted to a previous snapshot, because that is done via a monitor command and not restarting QEMU. So for this VM Generation ID work to be considered complete we need to have a way to dynamically change the VM generation ID on the fly, atomatically with reverting snapshots from the POV of the guest. eg we must load the snapshot state, change the generation ID, and only then start CPUs again. IOW I think this patch series is incomplete wrt the Microsoft spec on generation ID semantics. Regards, Daniel -- |: http://berrange.com -o- http://www.flickr.com/photos/dberrange/ :| |: http://libvirt.org -o- http://virt-manager.org :| |: http://autobuild.org -o- http://search.cpan.org/~danberr/ :| |: http://entangle-photo.org -o- http://live.gnome.org/gtk-vnc :| ^ permalink raw reply [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID 2014-10-06 9:06 ` Daniel P. Berrange @ 2014-10-06 12:48 ` Paolo Bonzini 0 siblings, 0 replies; 20+ messages in thread From: Paolo Bonzini @ 2014-10-06 12:48 UTC (permalink / raw) To: Daniel P. Berrange, Gal Hammer; +Cc: Igor Mammedov, qemu-devel Il 06/10/2014 11:06, Daniel P. Berrange ha scritto: > Now this can largely be accomplished by libvirt by simply changing the > value of the -vmgenid command line parameter, because most of these > scenarios involve the spawning of a new QEMU process. The exception > I think is when a running guest is reverted to a previous snapshot, > because that is done via a monitor command and not restarting QEMU. > So for this VM Generation ID work to be considered complete we need > to have a way to dynamically change the VM generation ID on the fly, > atomatically with reverting snapshots from the POV of the guest. > eg we must load the snapshot state, change the generation ID, and > only then start CPUs again. > > IOW I think this patch series is incomplete wrt the Microsoft spec > on generation ID semantics. I think this should not be a problem, as long as there is an idea of how to implement on-the-fly changes to the vmgenid. Gal, do you know how to find back the address of the VM generation ID? Can we put the offset into the DSDT in the migration stream, and then find the ACPI tables in the f-segment at post_load time? Paolo ^ permalink raw reply [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 0/2 V4] Virtual Machine Generation ID @ 2014-09-16 13:04 Gal Hammer 2014-09-16 13:04 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 0 siblings, 1 reply; 20+ messages in thread From: Gal Hammer @ 2014-09-16 13:04 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, pbonzini Hi, A two parts patch to add a QEmu support for Microsoft's Virtual Machine Generation ID device. The first one add a new ACPI directive which allow to use a 16-bytes buffer in an ACPI table. This buffer is for storing the VM's UUID. The second is the ACPI tables changes and the actual device. Your comment are welcomed. Thanks, Gal. V4: - Move device's description to SSDT table (dynamic build). V3: - Fix a typo in error message string. - Move device's description from DSDT back to SSDT table. V2: - Remove "-uuid" command line parameter. - Move device's description from SSDT to DSDT table. - Add new "vmgenid" sysbus device. Gal Hammer (2): i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. i386: Add a Virtual Machine Generation ID device. default-configs/i386-softmmu.mak | 1 + default-configs/x86_64-softmmu.mak | 1 + hw/i386/Makefile.objs | 2 +- hw/i386/acpi-build.c | 39 +++++++++++++++++ hw/i386/ssdt-vmgenid.dsl | 64 ++++++++++++++++++++++++++++ hw/misc/Makefile.objs | 1 + hw/misc/vmgenid.c | 85 ++++++++++++++++++++++++++++++++++++++ include/hw/i386/pc.h | 3 ++ scripts/acpi_extract.py | 23 +++++++---- 9 files changed, 209 insertions(+), 10 deletions(-) create mode 100644 hw/i386/ssdt-vmgenid.dsl create mode 100644 hw/misc/vmgenid.c -- 1.9.3 ^ permalink raw reply [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. 2014-09-16 13:04 [Qemu-devel] [PATCH 0/2 V4] " Gal Hammer @ 2014-09-16 13:04 ` Gal Hammer 0 siblings, 0 replies; 20+ messages in thread From: Gal Hammer @ 2014-09-16 13:04 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, pbonzini Add a 16-bytes buffer to allow storing a 128-bit UUID value in an ACPI table. Signed-off-by: Gal Hammer <ghammer@redhat.com> --- scripts/acpi_extract.py | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/scripts/acpi_extract.py b/scripts/acpi_extract.py index 22ea468..10c1ffb 100755 --- a/scripts/acpi_extract.py +++ b/scripts/acpi_extract.py @@ -139,13 +139,16 @@ def aml_name_string(offset): offset += 1 return offset; -# Given data offset, find 8 byte buffer offset -def aml_data_buffer8(offset): - #0x08 NameOp NameString DataRef - expect = [0x11, 0x0B, 0x0A, 0x08] +# Given data offset, find variable length byte buffer offset +def aml_data_buffer(offset, length): + #0x11 PkgLength BufferSize ByteList + if (length > 63): + die( "Name offset 0x%x: expected a one byte PkgLength (length<=63)" % + (offset)); + expect = [0x11, length+3, 0x0A, length] if (aml[offset:offset+4] != expect): die( "Name offset 0x%x: expected %s actual %s" % - (offset, aml[offset:offset+4], expect)) + (offset, expect, aml[offset:offset+4])) return offset + len(expect) # Given data offset, find dword const offset @@ -172,9 +175,9 @@ def aml_data_byte_const(offset): (offset, aml[offset])); return offset + 1; -# Find name'd buffer8 -def aml_name_buffer8(offset): - return aml_data_buffer8(aml_name_string(offset) + 4) +# Find name'd buffer +def aml_name_buffer(offset, length): + return aml_data_buffer(aml_name_string(offset) + 4, length) # Given name offset, find dword const offset def aml_name_dword_const(offset): @@ -308,7 +311,9 @@ for i in range(len(asl)): output[array] = aml continue if (directive == "ACPI_EXTRACT_NAME_BUFFER8"): - offset = aml_name_buffer8(offset) + offset = aml_name_buffer(offset, 8) + elif (directive == "ACPI_EXTRACT_NAME_BUFFER16"): + offset = aml_name_buffer(offset, 16) elif (directive == "ACPI_EXTRACT_NAME_DWORD_CONST"): offset = aml_name_dword_const(offset) elif (directive == "ACPI_EXTRACT_NAME_WORD_CONST"): -- 1.9.3 ^ permalink raw reply related [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 0/2 V3] Virtual Machine Generation ID @ 2014-09-15 7:27 Gal Hammer 2014-09-15 7:27 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 0 siblings, 1 reply; 20+ messages in thread From: Gal Hammer @ 2014-09-15 7:27 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, pbonzini Hi, A two parts patch to add a QEmu support for Microsoft's Virtual Machine Generation ID device. The first one add a new ACPI directive which allow to use a 16-bytes buffer in an ACPI table. This buffer is for storing the VM's UUID. The second is the ACPI tables changes and the actual device. Your comment are welcomed. Thanks, Gal. V3: - Fix a typo in error message string. - Move device's description from DSDT back to SSDT table. V2: - Remove "-uuid" command line parameter. - Move device's description from SSDT to DDST table. - Add new "vmgenid" sysbus device. Gal Hammer (2): i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. i386: Add a Virtual Machine Generation ID device. default-configs/i386-softmmu.mak | 1 + default-configs/x86_64-softmmu.mak | 1 + hw/i386/acpi-build.c | 18 ++++++++ hw/i386/ssdt-misc.dsl | 36 ++++++++++++++++ hw/misc/Makefile.objs | 1 + hw/misc/vmgenid.c | 85 ++++++++++++++++++++++++++++++++++++++ include/hw/i386/pc.h | 3 ++ scripts/acpi_extract.py | 23 +++++++---- 8 files changed, 159 insertions(+), 9 deletions(-) create mode 100644 hw/misc/vmgenid.c -- 1.9.3 ^ permalink raw reply [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. 2014-09-15 7:27 [Qemu-devel] [PATCH 0/2 V3] Virtual Machine Generation ID Gal Hammer @ 2014-09-15 7:27 ` Gal Hammer 0 siblings, 0 replies; 20+ messages in thread From: Gal Hammer @ 2014-09-15 7:27 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, pbonzini Add a 16-bytes buffer to allow storing a 128-bit UUID value in an ACPI table. Signed-off-by: Gal Hammer <ghammer@redhat.com> --- scripts/acpi_extract.py | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/scripts/acpi_extract.py b/scripts/acpi_extract.py index 22ea468..10c1ffb 100755 --- a/scripts/acpi_extract.py +++ b/scripts/acpi_extract.py @@ -139,13 +139,16 @@ def aml_name_string(offset): offset += 1 return offset; -# Given data offset, find 8 byte buffer offset -def aml_data_buffer8(offset): - #0x08 NameOp NameString DataRef - expect = [0x11, 0x0B, 0x0A, 0x08] +# Given data offset, find variable length byte buffer offset +def aml_data_buffer(offset, length): + #0x11 PkgLength BufferSize ByteList + if (length > 63): + die( "Name offset 0x%x: expected a one byte PkgLength (length<=63)" % + (offset)); + expect = [0x11, length+3, 0x0A, length] if (aml[offset:offset+4] != expect): die( "Name offset 0x%x: expected %s actual %s" % - (offset, aml[offset:offset+4], expect)) + (offset, expect, aml[offset:offset+4])) return offset + len(expect) # Given data offset, find dword const offset @@ -172,9 +175,9 @@ def aml_data_byte_const(offset): (offset, aml[offset])); return offset + 1; -# Find name'd buffer8 -def aml_name_buffer8(offset): - return aml_data_buffer8(aml_name_string(offset) + 4) +# Find name'd buffer +def aml_name_buffer(offset, length): + return aml_data_buffer(aml_name_string(offset) + 4, length) # Given name offset, find dword const offset def aml_name_dword_const(offset): @@ -308,7 +311,9 @@ for i in range(len(asl)): output[array] = aml continue if (directive == "ACPI_EXTRACT_NAME_BUFFER8"): - offset = aml_name_buffer8(offset) + offset = aml_name_buffer(offset, 8) + elif (directive == "ACPI_EXTRACT_NAME_BUFFER16"): + offset = aml_name_buffer(offset, 16) elif (directive == "ACPI_EXTRACT_NAME_DWORD_CONST"): offset = aml_name_dword_const(offset) elif (directive == "ACPI_EXTRACT_NAME_WORD_CONST"): -- 1.9.3 ^ permalink raw reply related [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH RESEND 0/2 V2] Virtual Machine Generation ID @ 2014-09-14 6:25 Gal Hammer 2014-09-14 6:25 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 0 siblings, 1 reply; 20+ messages in thread From: Gal Hammer @ 2014-09-14 6:25 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, pbonzini, armbru Hi, A two parts patch to add a QEmu support for Microsoft's Virtual Machine Generation ID device. The first one add a new ACPI directive which allow to use a 16-bytes buffer in an ACPI table. This buffer is for storing the VM's UUID. The second is the ACPI tables changes and the actual device. Your comment are welcomed. Thanks, Gal. V2: - Remove "-uuid" command line parameter. - Move device's description from SSDT to DDST table. - Add new "vmgenid" sysbus device. Gal Hammer (2): i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. i386: Add a Virtual Machine Generation ID device. default-configs/i386-softmmu.mak | 1 + default-configs/x86_64-softmmu.mak | 1 + hw/i386/acpi-build.c | 23 ++++++++++- hw/i386/acpi-dsdt.dsl | 37 +++++++++++++++++ hw/misc/Makefile.objs | 1 + hw/misc/vmgenid.c | 85 ++++++++++++++++++++++++++++++++++++++ include/hw/i386/pc.h | 3 ++ scripts/acpi_extract.py | 23 +++++++---- 8 files changed, 163 insertions(+), 11 deletions(-) create mode 100644 hw/misc/vmgenid.c -- 1.9.3 ^ permalink raw reply [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. 2014-09-14 6:25 [Qemu-devel] [PATCH RESEND 0/2 V2] Virtual Machine Generation ID Gal Hammer @ 2014-09-14 6:25 ` Gal Hammer 2014-09-14 8:48 ` Paolo Bonzini 0 siblings, 1 reply; 20+ messages in thread From: Gal Hammer @ 2014-09-14 6:25 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, pbonzini, armbru Add a 16-bytes buffer to allow storing a 128-bit UUID value in an ACPI table. Signed-off-by: Gal Hammer <ghammer@redhat.com> --- scripts/acpi_extract.py | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/scripts/acpi_extract.py b/scripts/acpi_extract.py index 22ea468..88314fc 100755 --- a/scripts/acpi_extract.py +++ b/scripts/acpi_extract.py @@ -139,13 +139,16 @@ def aml_name_string(offset): offset += 1 return offset; -# Given data offset, find 8 byte buffer offset -def aml_data_buffer8(offset): - #0x08 NameOp NameString DataRef - expect = [0x11, 0x0B, 0x0A, 0x08] +# Given data offset, find variable length byte buffer offset +def aml_data_buffer(offset, length): + #0x11 PkgLength BufferSize ByteList + if (length > 63): + die( "Name offset 0x%x: expected an one byte PkgLength (length<=63)" % + (offset)); + expect = [0x11, length+3, 0x0A, length] if (aml[offset:offset+4] != expect): die( "Name offset 0x%x: expected %s actual %s" % - (offset, aml[offset:offset+4], expect)) + (offset, expect, aml[offset:offset+4])) return offset + len(expect) # Given data offset, find dword const offset @@ -172,9 +175,9 @@ def aml_data_byte_const(offset): (offset, aml[offset])); return offset + 1; -# Find name'd buffer8 -def aml_name_buffer8(offset): - return aml_data_buffer8(aml_name_string(offset) + 4) +# Find name'd buffer +def aml_name_buffer(offset, length): + return aml_data_buffer(aml_name_string(offset) + 4, length) # Given name offset, find dword const offset def aml_name_dword_const(offset): @@ -308,7 +311,9 @@ for i in range(len(asl)): output[array] = aml continue if (directive == "ACPI_EXTRACT_NAME_BUFFER8"): - offset = aml_name_buffer8(offset) + offset = aml_name_buffer(offset, 8) + elif (directive == "ACPI_EXTRACT_NAME_BUFFER16"): + offset = aml_name_buffer(offset, 16) elif (directive == "ACPI_EXTRACT_NAME_DWORD_CONST"): offset = aml_name_dword_const(offset) elif (directive == "ACPI_EXTRACT_NAME_WORD_CONST"): -- 1.9.3 ^ permalink raw reply related [flat|nested] 20+ messages in thread
* Re: [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. 2014-09-14 6:25 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer @ 2014-09-14 8:48 ` Paolo Bonzini 0 siblings, 0 replies; 20+ messages in thread From: Paolo Bonzini @ 2014-09-14 8:48 UTC (permalink / raw) To: Gal Hammer, qemu-devel; +Cc: armbru Il 14/09/2014 08:25, Gal Hammer ha scritto: > Add a 16-bytes buffer to allow storing a 128-bit UUID value in an > ACPI table. > > Signed-off-by: Gal Hammer <ghammer@redhat.com> > --- > scripts/acpi_extract.py | 23 ++++++++++++++--------- > 1 file changed, 14 insertions(+), 9 deletions(-) > > diff --git a/scripts/acpi_extract.py b/scripts/acpi_extract.py > index 22ea468..88314fc 100755 > --- a/scripts/acpi_extract.py > +++ b/scripts/acpi_extract.py > @@ -139,13 +139,16 @@ def aml_name_string(offset): > offset += 1 > return offset; > > -# Given data offset, find 8 byte buffer offset > -def aml_data_buffer8(offset): > - #0x08 NameOp NameString DataRef > - expect = [0x11, 0x0B, 0x0A, 0x08] > +# Given data offset, find variable length byte buffer offset > +def aml_data_buffer(offset, length): > + #0x11 PkgLength BufferSize ByteList > + if (length > 63): > + die( "Name offset 0x%x: expected an one byte PkgLength (length<=63)" % s/an/a/ > + (offset)); > + expect = [0x11, length+3, 0x0A, length] > if (aml[offset:offset+4] != expect): > die( "Name offset 0x%x: expected %s actual %s" % > - (offset, aml[offset:offset+4], expect)) > + (offset, expect, aml[offset:offset+4])) > return offset + len(expect) > > # Given data offset, find dword const offset > @@ -172,9 +175,9 @@ def aml_data_byte_const(offset): > (offset, aml[offset])); > return offset + 1; > > -# Find name'd buffer8 > -def aml_name_buffer8(offset): > - return aml_data_buffer8(aml_name_string(offset) + 4) > +# Find name'd buffer > +def aml_name_buffer(offset, length): > + return aml_data_buffer(aml_name_string(offset) + 4, length) > > # Given name offset, find dword const offset > def aml_name_dword_const(offset): > @@ -308,7 +311,9 @@ for i in range(len(asl)): > output[array] = aml > continue > if (directive == "ACPI_EXTRACT_NAME_BUFFER8"): > - offset = aml_name_buffer8(offset) > + offset = aml_name_buffer(offset, 8) > + elif (directive == "ACPI_EXTRACT_NAME_BUFFER16"): > + offset = aml_name_buffer(offset, 16) > elif (directive == "ACPI_EXTRACT_NAME_DWORD_CONST"): > offset = aml_name_dword_const(offset) > elif (directive == "ACPI_EXTRACT_NAME_WORD_CONST"): > Apart from the above grammatical nit, Reviewed-by: Paolo Bonzini <pbonzini@redhat.com> Paolo ^ permalink raw reply [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 0/2 V2] Virtual Machine Generation ID @ 2014-09-02 12:53 Gal Hammer 2014-09-02 12:53 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 0 siblings, 1 reply; 20+ messages in thread From: Gal Hammer @ 2014-09-02 12:53 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, pbonzini, armbru Hi, A two parts patch to add a QEmu support for Microsoft's Virtual Machine Generation ID device. The first one add a new ACPI directive which allow to use a 16-bytes buffer in an ACPI table. This buffer is for storing the VM's UUID. The second is the ACPI tables changes and the actual device. Your comment are welcomed. Thanks, Gal. V2: - Remove "-uuid" command line parameter. - Move device's description from SSDT to DDST table. - Add new "vmgenid" sysbus device. Gal Hammer (2): i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. i386: Add a Virtual Machine Generation ID device. default-configs/i386-softmmu.mak | 1 + default-configs/x86_64-softmmu.mak | 1 + hw/i386/acpi-build.c | 23 ++++++++++- hw/i386/acpi-dsdt.dsl | 37 +++++++++++++++++ hw/misc/Makefile.objs | 1 + hw/misc/vmgenid.c | 85 ++++++++++++++++++++++++++++++++++++++ include/hw/i386/pc.h | 3 ++ scripts/acpi_extract.py | 23 +++++++---- 8 files changed, 163 insertions(+), 11 deletions(-) create mode 100644 hw/misc/vmgenid.c -- 1.9.3 ^ permalink raw reply [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. 2014-09-02 12:53 [Qemu-devel] [PATCH 0/2 V2] Virtual Machine Generation ID Gal Hammer @ 2014-09-02 12:53 ` Gal Hammer 0 siblings, 0 replies; 20+ messages in thread From: Gal Hammer @ 2014-09-02 12:53 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer, pbonzini, armbru Add a 16-bytes buffer to allow storing a 128-bit UUID value in an ACPI table. Signed-off-by: Gal Hammer <ghammer@redhat.com> --- scripts/acpi_extract.py | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/scripts/acpi_extract.py b/scripts/acpi_extract.py index 22ea468..88314fc 100755 --- a/scripts/acpi_extract.py +++ b/scripts/acpi_extract.py @@ -139,13 +139,16 @@ def aml_name_string(offset): offset += 1 return offset; -# Given data offset, find 8 byte buffer offset -def aml_data_buffer8(offset): - #0x08 NameOp NameString DataRef - expect = [0x11, 0x0B, 0x0A, 0x08] +# Given data offset, find variable length byte buffer offset +def aml_data_buffer(offset, length): + #0x11 PkgLength BufferSize ByteList + if (length > 63): + die( "Name offset 0x%x: expected an one byte PkgLength (length<=63)" % + (offset)); + expect = [0x11, length+3, 0x0A, length] if (aml[offset:offset+4] != expect): die( "Name offset 0x%x: expected %s actual %s" % - (offset, aml[offset:offset+4], expect)) + (offset, expect, aml[offset:offset+4])) return offset + len(expect) # Given data offset, find dword const offset @@ -172,9 +175,9 @@ def aml_data_byte_const(offset): (offset, aml[offset])); return offset + 1; -# Find name'd buffer8 -def aml_name_buffer8(offset): - return aml_data_buffer8(aml_name_string(offset) + 4) +# Find name'd buffer +def aml_name_buffer(offset, length): + return aml_data_buffer(aml_name_string(offset) + 4, length) # Given name offset, find dword const offset def aml_name_dword_const(offset): @@ -308,7 +311,9 @@ for i in range(len(asl)): output[array] = aml continue if (directive == "ACPI_EXTRACT_NAME_BUFFER8"): - offset = aml_name_buffer8(offset) + offset = aml_name_buffer(offset, 8) + elif (directive == "ACPI_EXTRACT_NAME_BUFFER16"): + offset = aml_name_buffer(offset, 16) elif (directive == "ACPI_EXTRACT_NAME_DWORD_CONST"): offset = aml_name_dword_const(offset) elif (directive == "ACPI_EXTRACT_NAME_WORD_CONST"): -- 1.9.3 ^ permalink raw reply related [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 0/2] Virtual Machine Generation ID @ 2014-08-10 11:32 Gal Hammer 2014-08-10 11:32 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 0 siblings, 1 reply; 20+ messages in thread From: Gal Hammer @ 2014-08-10 11:32 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer Hi, A two parts patch to add a QEmu support for Microsoft's Virtual Machine Generation ID device. The first one add a new ACPI directive which allow to use a 16-bytes buffer in an ACPI table. This buffer is for storing the VM's UUID. The second is the ACPI tables changes and the required command line parameter. Your comment are welcomed. Thanks, Gal. Gal Hammer (2): i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. i386: Add a Virtual Machine Generation ID device. hw/i386/acpi-build.c | 23 +++++++++++++++++++++++ hw/i386/ssdt-misc.dsl | 33 +++++++++++++++++++++++++++++++++ qemu-options.hx | 9 +++++++++ scripts/acpi_extract.py | 23 ++++++++++++++--------- vl.c | 11 +++++++++++ 5 files changed, 90 insertions(+), 9 deletions(-) -- 1.9.3 ^ permalink raw reply [flat|nested] 20+ messages in thread
* [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive. 2014-08-10 11:32 [Qemu-devel] [PATCH 0/2] Virtual Machine Generation ID Gal Hammer @ 2014-08-10 11:32 ` Gal Hammer 0 siblings, 0 replies; 20+ messages in thread From: Gal Hammer @ 2014-08-10 11:32 UTC (permalink / raw) To: qemu-devel; +Cc: Gal Hammer Add a 16-bytes buffer to allow storing a 128-bit UUID value in an ACPI table. Signed-off-by: Gal Hammer <ghammer@redhat.com> --- scripts/acpi_extract.py | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/scripts/acpi_extract.py b/scripts/acpi_extract.py index 22ea468..88314fc 100755 --- a/scripts/acpi_extract.py +++ b/scripts/acpi_extract.py @@ -139,13 +139,16 @@ def aml_name_string(offset): offset += 1 return offset; -# Given data offset, find 8 byte buffer offset -def aml_data_buffer8(offset): - #0x08 NameOp NameString DataRef - expect = [0x11, 0x0B, 0x0A, 0x08] +# Given data offset, find variable length byte buffer offset +def aml_data_buffer(offset, length): + #0x11 PkgLength BufferSize ByteList + if (length > 63): + die( "Name offset 0x%x: expected an one byte PkgLength (length<=63)" % + (offset)); + expect = [0x11, length+3, 0x0A, length] if (aml[offset:offset+4] != expect): die( "Name offset 0x%x: expected %s actual %s" % - (offset, aml[offset:offset+4], expect)) + (offset, expect, aml[offset:offset+4])) return offset + len(expect) # Given data offset, find dword const offset @@ -172,9 +175,9 @@ def aml_data_byte_const(offset): (offset, aml[offset])); return offset + 1; -# Find name'd buffer8 -def aml_name_buffer8(offset): - return aml_data_buffer8(aml_name_string(offset) + 4) +# Find name'd buffer +def aml_name_buffer(offset, length): + return aml_data_buffer(aml_name_string(offset) + 4, length) # Given name offset, find dword const offset def aml_name_dword_const(offset): @@ -308,7 +311,9 @@ for i in range(len(asl)): output[array] = aml continue if (directive == "ACPI_EXTRACT_NAME_BUFFER8"): - offset = aml_name_buffer8(offset) + offset = aml_name_buffer(offset, 8) + elif (directive == "ACPI_EXTRACT_NAME_BUFFER16"): + offset = aml_name_buffer(offset, 16) elif (directive == "ACPI_EXTRACT_NAME_DWORD_CONST"): offset = aml_name_dword_const(offset) elif (directive == "ACPI_EXTRACT_NAME_WORD_CONST"): -- 1.9.3 ^ permalink raw reply related [flat|nested] 20+ messages in thread
end of thread, other threads:[~2014-10-06 12:48 UTC | newest] Thread overview: 20+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2014-09-17 11:39 [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID Gal Hammer 2014-09-17 11:39 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 2014-10-02 12:20 ` Michael S. Tsirkin 2014-09-17 11:39 ` [Qemu-devel] [PATCH 2/2] i386: Add a Virtual Machine Generation ID device Gal Hammer 2014-10-02 12:49 ` Michael S. Tsirkin 2014-10-02 13:14 ` Gal Hammer 2014-10-02 13:30 ` Michael S. Tsirkin 2014-10-01 8:58 ` [Qemu-devel] [PATCH 0/2 V5] Virtual Machine Generation ID Markus Armbruster 2014-10-02 8:32 ` Gal Hammer 2014-10-02 8:46 ` Michael S. Tsirkin 2014-10-02 12:12 ` Michael S. Tsirkin 2014-10-02 12:16 ` Michael S. Tsirkin 2014-10-06 9:06 ` Daniel P. Berrange 2014-10-06 12:48 ` Paolo Bonzini -- strict thread matches above, loose matches on Subject: below -- 2014-09-16 13:04 [Qemu-devel] [PATCH 0/2 V4] " Gal Hammer 2014-09-16 13:04 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 2014-09-15 7:27 [Qemu-devel] [PATCH 0/2 V3] Virtual Machine Generation ID Gal Hammer 2014-09-15 7:27 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 2014-09-14 6:25 [Qemu-devel] [PATCH RESEND 0/2 V2] Virtual Machine Generation ID Gal Hammer 2014-09-14 6:25 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 2014-09-14 8:48 ` Paolo Bonzini 2014-09-02 12:53 [Qemu-devel] [PATCH 0/2 V2] Virtual Machine Generation ID Gal Hammer 2014-09-02 12:53 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer 2014-08-10 11:32 [Qemu-devel] [PATCH 0/2] Virtual Machine Generation ID Gal Hammer 2014-08-10 11:32 ` [Qemu-devel] [PATCH 1/2] i386: Add an ACPI_EXTRACT_NAME_BUFFER16 directive Gal Hammer
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).