diff mbox

[for-1.7,1/5] acpi unit-test: load and check facs table

Message ID 1385062405-3800-2-git-send-email-marcel.a@redhat.com
State New
Headers show

Commit Message

Marcel Apfelbaum Nov. 21, 2013, 7:33 p.m. UTC
FACS table does not have a checksum, so we can
check at least the signature (existence).

Signed-off-by: Marcel Apfelbaum <marcel.a@redhat.com>
---
 tests/acpi-test.c | 18 ++++++++++++++++++
 1 file changed, 18 insertions(+)

Comments

Michael S. Tsirkin Dec. 10, 2013, 4:42 p.m. UTC | #1
On Thu, Nov 21, 2013 at 09:33:21PM +0200, Marcel Apfelbaum wrote:
> FACS table does not have a checksum, so we can
> check at least the signature (existence).
> 
> Signed-off-by: Marcel Apfelbaum <marcel.a@redhat.com>

Applied, thanks.

> ---
>  tests/acpi-test.c | 18 ++++++++++++++++++
>  1 file changed, 18 insertions(+)
> 
> diff --git a/tests/acpi-test.c b/tests/acpi-test.c
> index d6ff66f..43775cd 100644
> --- a/tests/acpi-test.c
> +++ b/tests/acpi-test.c
> @@ -30,6 +30,7 @@ typedef struct {
>      AcpiRsdpDescriptor rsdp_table;
>      AcpiRsdtDescriptorRev1 rsdt_table;
>      AcpiFadtDescriptorRev1 fadt_table;
> +    AcpiFacsDescriptorRev1 facs_table;
>      uint32_t *rsdt_tables_addr;
>      int rsdt_tables_nr;
>      AcpiSdtTable dsdt_table;
> @@ -252,6 +253,22 @@ static void test_acpi_fadt_table(test_data *data)
>      g_assert(!acpi_checksum((uint8_t *)fadt_table, fadt_table->length));
>  }
>  
> +static void test_acpi_facs_table(test_data *data)
> +{
> +    AcpiFacsDescriptorRev1 *facs_table = &data->facs_table;
> +    uint32_t addr = data->fadt_table.firmware_ctrl;
> +
> +    ACPI_READ_FIELD(facs_table->signature, addr);
> +    ACPI_READ_FIELD(facs_table->length, addr);
> +    ACPI_READ_FIELD(facs_table->hardware_signature, addr);
> +    ACPI_READ_FIELD(facs_table->firmware_waking_vector, addr);
> +    ACPI_READ_FIELD(facs_table->global_lock, addr);
> +    ACPI_READ_FIELD(facs_table->flags, addr);
> +    ACPI_READ_ARRAY(facs_table->resverved3, addr);
> +
> +    g_assert_cmphex(facs_table->signature, ==, ACPI_FACS_SIGNATURE);
> +}
> +
>  static void test_dst_table(AcpiSdtTable *sdt_table, uint32_t addr)
>  {
>      uint8_t checksum;
> @@ -329,6 +346,7 @@ static void test_acpi_one(const char *params)
>      test_acpi_rsdp_table(&data);
>      test_acpi_rsdt_table(&data);
>      test_acpi_fadt_table(&data);
> +    test_acpi_facs_table(data);
>      test_acpi_dsdt_table(&data);
>      test_acpi_ssdt_tables(&data);
>  
> -- 
> 1.8.3.1
diff mbox

Patch

diff --git a/tests/acpi-test.c b/tests/acpi-test.c
index d6ff66f..43775cd 100644
--- a/tests/acpi-test.c
+++ b/tests/acpi-test.c
@@ -30,6 +30,7 @@  typedef struct {
     AcpiRsdpDescriptor rsdp_table;
     AcpiRsdtDescriptorRev1 rsdt_table;
     AcpiFadtDescriptorRev1 fadt_table;
+    AcpiFacsDescriptorRev1 facs_table;
     uint32_t *rsdt_tables_addr;
     int rsdt_tables_nr;
     AcpiSdtTable dsdt_table;
@@ -252,6 +253,22 @@  static void test_acpi_fadt_table(test_data *data)
     g_assert(!acpi_checksum((uint8_t *)fadt_table, fadt_table->length));
 }
 
+static void test_acpi_facs_table(test_data *data)
+{
+    AcpiFacsDescriptorRev1 *facs_table = &data->facs_table;
+    uint32_t addr = data->fadt_table.firmware_ctrl;
+
+    ACPI_READ_FIELD(facs_table->signature, addr);
+    ACPI_READ_FIELD(facs_table->length, addr);
+    ACPI_READ_FIELD(facs_table->hardware_signature, addr);
+    ACPI_READ_FIELD(facs_table->firmware_waking_vector, addr);
+    ACPI_READ_FIELD(facs_table->global_lock, addr);
+    ACPI_READ_FIELD(facs_table->flags, addr);
+    ACPI_READ_ARRAY(facs_table->resverved3, addr);
+
+    g_assert_cmphex(facs_table->signature, ==, ACPI_FACS_SIGNATURE);
+}
+
 static void test_dst_table(AcpiSdtTable *sdt_table, uint32_t addr)
 {
     uint8_t checksum;
@@ -329,6 +346,7 @@  static void test_acpi_one(const char *params)
     test_acpi_rsdp_table(&data);
     test_acpi_rsdt_table(&data);
     test_acpi_fadt_table(&data);
+    test_acpi_facs_table(data);
     test_acpi_dsdt_table(&data);
     test_acpi_ssdt_tables(&data);