diff options
author | Patrick Rudolph <patrick.rudolph@9elements.com> | 2025-03-16 09:32:56 +0100 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2025-04-03 11:38:14 -0600 |
commit | 636b62c265f8932f12b2fe1ce8b256868d16fbda (patch) | |
tree | 9170dd832df702b9e89d02ebb644549da432158a | |
parent | 9c748576402cbc1381498e72800ecaeb99d2b355 (diff) |
test: acpi: Add IORT tests
Add tests for IORT table generation:
- SMMU_V3 node
- RC node
Signed-off-by: Patrick Rudolph <patrick.rudolph@9elements.com>
-rw-r--r-- | test/dm/acpigen.c | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/test/dm/acpigen.c b/test/dm/acpigen.c index 23c16bd9866..ee9517f9c29 100644 --- a/test/dm/acpigen.c +++ b/test/dm/acpigen.c @@ -1742,3 +1742,118 @@ static int dm_test_acpi_write_tsd_package(struct unit_test_state *uts) return 0; } DM_TEST(dm_test_acpi_write_tsd_package, 0); + +static int dm_test_acpi_iort_smmu_v3(struct unit_test_state *uts) +{ + struct acpi_ctx *ctx; + int smmu_offset; + u8 *ptr; + + ut_assertok(alloc_context(&ctx)); + ctx->tab_start = ctx->current; + acpi_inc(ctx, sizeof(struct acpi_table_iort)); + + ptr = acpigen_get_current(ctx); + + smmu_offset = acpi_iort_add_smmu_v3(ctx, + 0xaabbccddeeffULL, // Base address + 1, // Flags + 0xffeeddccaabbULL, // VATOS address + 0, // SMMUv3 Model + 3, // Event + 4, // Pri + 5, // Gerror + 6, // Sync + 7, // Proximity domain + 8, // DevIDMappingIndex + 0, + NULL); + ut_assert(smmu_offset); + + ut_asserteq(ACPI_IORT_NODE_SMMU_V3, ptr[0]); + ut_asserteq(68, get_unaligned((u16 *)(ptr + 1))); + ut_asserteq(0, get_unaligned((u16 *)(ptr + 4))); + ut_asserteq(0, get_unaligned((u32 *)(ptr + 8))); + ut_asserteq(0, get_unaligned((u32 *)(ptr + 12))); + + ut_asserteq_64(0xaabbccddeeffULL, get_unaligned((u64 *)(ptr + 16))); + ut_asserteq(1, get_unaligned((u32 *)(ptr + 24))); + ut_asserteq(0, get_unaligned((u32 *)(ptr + 28))); + ut_asserteq_64(0xffeeddccaabbULL, get_unaligned((u64 *)(ptr + 32))); + ut_asserteq(0, get_unaligned((u32 *)(ptr + 40))); + ut_asserteq(3, get_unaligned((u32 *)(ptr + 44))); + ut_asserteq(4, get_unaligned((u32 *)(ptr + 48))); + ut_asserteq(5, get_unaligned((u32 *)(ptr + 52))); + ut_asserteq(6, get_unaligned((u32 *)(ptr + 56))); + ut_asserteq(7, get_unaligned((u32 *)(ptr + 60))); + ut_asserteq(8, get_unaligned((u32 *)(ptr + 64))); + + free_context(&ctx); + + return 0; +} +DM_TEST(dm_test_acpi_iort_smmu_v3, 0); + +static int dm_test_acpi_iort_rc(struct unit_test_state *uts) +{ + struct acpi_ctx *ctx; + int its_group_offset, offset; + u8 *ptr; + + ut_assertok(alloc_context(&ctx)); + ctx->tab_start = ctx->current; + acpi_inc(ctx, sizeof(struct acpi_table_iort)); + + u32 identifiers[] = { 0 }; + + its_group_offset = acpi_iort_add_its_group(ctx, ARRAY_SIZE(identifiers), + identifiers); + + ptr = acpigen_get_current(ctx); + + struct acpi_iort_id_mapping map_rc[] = { + {0, 0xfff, 0, its_group_offset, 0}, + {0x1000, 0xffff, 0x1000, its_group_offset, 0} + }; + + offset = acpi_iort_add_rc(ctx, + 0xaabbccddeeffULL, // Mem Access Properties + 2, // ATS attributes + 3, // PCI segment + 4, // Memory address size limit + ARRAY_SIZE(map_rc), + map_rc); + + ut_assert(offset); + ut_asserteq(ACPI_IORT_NODE_PCI_ROOT_COMPLEX, ptr[0]); + ut_asserteq(36 + ARRAY_SIZE(map_rc) * sizeof(struct acpi_iort_id_mapping), + get_unaligned((u16 *)(ptr + 1))); + ut_asserteq(0, get_unaligned((u16 *)(ptr + 4))); + ut_asserteq(2, get_unaligned((u32 *)(ptr + 8))); + ut_asserteq(36, get_unaligned((u32 *)(ptr + 12))); + + ut_asserteq_64(0xaabbccddeeffULL, get_unaligned((u64 *)(ptr + 16))); + ut_asserteq(2, get_unaligned((u32 *)(ptr + 24))); + ut_asserteq(3, get_unaligned((u32 *)(ptr + 28))); + ut_asserteq(4, ptr[32]); + ut_asserteq(0, ptr[33]); + ut_asserteq(0, ptr[34]); + ut_asserteq(0, ptr[35]); + + ut_asserteq(0, get_unaligned((u32 *)(ptr + 36))); + ut_asserteq(0xfff, get_unaligned((u32 *)(ptr + 40))); + ut_asserteq(0, get_unaligned((u32 *)(ptr + 44))); + ut_asserteq(its_group_offset, get_unaligned((u32 *)(ptr + 48))); + ut_asserteq(0, get_unaligned((u32 *)(ptr + 52))); + + ut_asserteq(0x1000, get_unaligned((u32 *)(ptr + 56))); + ut_asserteq(0xffff, get_unaligned((u32 *)(ptr + 60))); + ut_asserteq(0x1000, get_unaligned((u32 *)(ptr + 64))); + ut_asserteq(its_group_offset, get_unaligned((u32 *)(ptr + 68))); + ut_asserteq(0, get_unaligned((u32 *)(ptr + 72))); + + free_context(&ctx); + + return 0; +} +DM_TEST(dm_test_acpi_iort_rc, 0);
\ No newline at end of file |