From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:40505) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1YGPTg-0003mr-Op for qemu-devel@nongnu.org; Wed, 28 Jan 2015 05:04:05 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1YGPTf-00028J-UO for qemu-devel@nongnu.org; Wed, 28 Jan 2015 05:04:04 -0500 Received: from mx1.redhat.com ([209.132.183.28]:41112) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1YGPTf-000288-Nq for qemu-devel@nongnu.org; Wed, 28 Jan 2015 05:04:03 -0500 From: Igor Mammedov Date: Wed, 28 Jan 2015 10:03:33 +0000 Message-Id: <1422439417-5031-10-git-send-email-imammedo@redhat.com> In-Reply-To: <1422439417-5031-1-git-send-email-imammedo@redhat.com> References: <20150128072757.GA12987@redhat.com> <1422439417-5031-1-git-send-email-imammedo@redhat.com> Subject: [Qemu-devel] [PATCH 09/13] acpi: add aml_blob() helper List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: pbonzini@redhat.com, drjones@redhat.com, zhaoshenglong@huawei.com, claudio.fontana@huawei.com, marcel.a@redhat.com it will help to add external (user provided) tables into ACPI tables blob. Signed-off-by: Igor Mammedov --- hw/acpi/acpi-build-utils.c | 8 ++++++++ include/hw/acpi/acpi-build-utils.h | 2 ++ 2 files changed, 10 insertions(+) diff --git a/hw/acpi/acpi-build-utils.c b/hw/acpi/acpi-build-utils.c index bffad1e..41341a4 100644 --- a/hw/acpi/acpi-build-utils.c +++ b/hw/acpi/acpi-build-utils.c @@ -926,6 +926,14 @@ AcpiAml *acpi_def_block(const char *signature, uint8_t revision, return var; } +AcpiAml *aml_blob(const unsigned char *data, int size) +{ + AcpiAml *var = AML_OBJECT(object_new(TYPE_AML_OBJECT)); + + g_array_append_vals(var->buf, data, size); + return var; +} + static void aml_object_initfn(Object *obj) { AcpiAml *aml = AML_OBJECT(obj); diff --git a/include/hw/acpi/acpi-build-utils.h b/include/hw/acpi/acpi-build-utils.h index b2d023e..f36e23a 100644 --- a/include/hw/acpi/acpi-build-utils.h +++ b/include/hw/acpi/acpi-build-utils.h @@ -194,6 +194,8 @@ AcpiAml *acpi_field(const char *name, acpiFieldFlags flags); AcpiAml *acpi_varpackage(uint32_t num_elements); /* other helpers */ +AcpiAml *aml_blob(const unsigned char *data, int size); + GArray *build_alloc_array(void); void build_free_array(GArray *array); void build_prepend_byte(GArray *array, uint8_t val); -- 1.8.3.1