]> git.dujemihanovic.xyz Git - u-boot.git/commit
x86: all firmware tables must be paragraph aligned
authorHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Mon, 1 Jan 2024 23:11:44 +0000 (00:11 +0100)
committerHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Sat, 20 Apr 2024 08:15:03 +0000 (10:15 +0200)
commit52c62acc349a0ec1ba26ae497913ad34ee3de733
tree05e88b4e7c30aba16e152762a23f1aa802ed604a
parent85177b2cf4e9e92eb8454430ed64ecad69df9f92
x86: all firmware tables must be paragraph aligned

On qemu-x86_64_defconfig the following was observed:

    => efidebug tables
    00000000000f0074  eb9d2d31-2d88-11d3-9a16-0090273fc14d  SMBIOS table

The SMBIOS configuration table does not point to a paragraph-aligned
(16 byte aligned) address. The reason is that in write_tables() rom_addr is
not aligned and copied to gd->arch.smbios_start.

The Simple Firmware Interface requires that the SFI table is paragraph-
aligned but our code does not guarantee this.

As all tables written in write_tables() must be paragraph-aligned, we
should implement the address rounding in write_tables() and not in table
specific routines like copy_pirq_routing_table().

Add paragraph-alignment in write_tables().

Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
arch/x86/lib/tables.c