All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v4 00/35] acpi: refactor error prone build_header() and packed structures usage in ACPI tables
@ 2021-09-24 12:27 Igor Mammedov
  2021-09-24 12:27 ` [PATCH v4 01/35] acpi: add helper routines to initialize " Igor Mammedov
                   ` (34 more replies)
  0 siblings, 35 replies; 40+ messages in thread
From: Igor Mammedov @ 2021-09-24 12:27 UTC (permalink / raw)
  To: qemu-devel; +Cc: ani, mst

v4:
  1. comments fixups and diing missing comments
  2. clean up spurious changes
  3. rebase on top of (4be8bfcb4d hw/i386/acpi-build: Fix a typo)
  4. convert build_iort:
        * keep nb_nodes variable
        * encode 'Memory access properties' as separate entries according to Table 13

v3:
  1. s/acpi_init_table()|acpi_table_composed()/acpi_table_begin()|acpi_table_end()/
  2. arm:madt fix incorrect length
  3. various comment improvments
  4. rewrite IORT conversion patch due to heavy conflicts with bypass iommu code
    merged recently
  5 pick up Eric's Reviewed-By where there wasn't significant change (1)

v2:
  - drop test related patches, they will be sent as a separate series
  - fix bios_loader pointer initialization ordering when using TPM1.2
  - extend commit message of [1/35] and add extra comment about
    table length patching 

Highlights:
  * drop pointer arithmetic in ACPI tables code
  * use endian agnostic API
  * simplifies review of tables. /in most cases just line by line comparision with spec/

Series replaces build_header() with acpi_table_begin()/acpi_table_end()
API that hides pointer/offset arithmetic from user, to prevent
errors caused by it [1].
While doing above, it was necessary to split table header from
packed structure that was describing the table, which is
counter-productive since it still leaves packed structure drawbacks.
So that sort of forced me to rewrite tables that were composed with
help of packed structures to preferred build_append_int_noprefix() API.
In cases where refactoring to build_append_int_noprefix() was small,
it was squashed with acpi_table_begin()/acpi_table_end() patch.
Conversion reduced code size quite a bit despite me adding doc comments
for every table row.

1) commits
   bb9feea43179 x86: acpi: use offset instead of pointer when using build_header()
   4d027afeb3a9 Virt: ACPI: fix qemu assert due to re-assigned table data address

Link to repo with this series and tests to validate it:
   https://gitlab.com/imammedo/qemu/-/commits/acpi_build_header_refactoring_v4

Previous v3 revision can be found at:
   https://lore.kernel.org/qemu-devel/20210907144814.741785-22-imammedo@redhat.com/T/


CC: mst@redhat.com
CC: ani@anisinha.ca


Igor Mammedov (35):
  acpi: add helper routines to initialize ACPI tables
  acpi: build_rsdt: use acpi_table_begin()/acpi_table_end() instead of
    build_header()
  acpi: build_xsdt: use acpi_table_begin()/acpi_table_end() instead of
    build_header()
  acpi: build_slit: use acpi_table_begin()/acpi_table_end() instead of
    build_header()
  acpi: build_fadt: use acpi_table_begin()/acpi_table_end() instead of
    build_header()
  acpi: build_tpm2: use acpi_table_begin()/acpi_table_end() instead of
    build_header()
  acpi: acpi_build_hest: use acpi_table_begin()/acpi_table_end() instead
    of build_header()
  acpi: build_mcfg: use acpi_table_begin()/acpi_table_end() instead of
    build_header()
  acpi: build_hmat: use acpi_table_begin()/acpi_table_end() instead of
    build_header()
  acpi: nvdimm_build_nfit: use acpi_table_begin()/acpi_table_end()
    instead of build_header()
  acpi: nvdimm_build_ssdt: use acpi_table_begin()/acpi_table_end()
    instead of build_header()
  acpi: vmgenid_build_acpi: use acpi_table_begin()/acpi_table_end()
    instead of build_header()
  acpi: x86: build_dsdt: use acpi_table_begin()/acpi_table_end() instead
    of build_header()
  acpi: build_hpet: use acpi_table_begin()/acpi_table_end() instead of
    build_header()
  acpi: build_tpm_tcpa: use acpi_table_begin()/acpi_table_end() instead
    of build_header()
  acpi: arm/x86: build_srat: use acpi_table_begin()/acpi_table_end()
    instead of build_header()
  acpi: use build_append_int_noprefix() API to compose SRAT table
  acpi: build_dmar_q35: use acpi_table_begin()/acpi_table_end() instead
    of build_header()
  acpi: build_waet: use acpi_table_begin()/acpi_table_end() instead of
    build_header()
  acpi: build_amd_iommu: use acpi_table_begin()/acpi_table_end() instead
    of build_header()
  acpi: madt: arm/x86: use acpi_table_begin()/acpi_table_end() instead
    of build_header()
  acpi: x86: remove dead code
  acpi: x86: set enabled when composing _MAT entries
  acpi: x86: madt: use build_append_int_noprefix() API to compose MADT
    table
  acpi: arm/virt: madt: use build_append_int_noprefix() API to compose
    MADT table
  acpi: build_dsdt_microvm: use acpi_table_begin()/acpi_table_end()
    instead of build_header()
  acpi: arm: virt: build_dsdt: use acpi_table_begin()/acpi_table_end()
    instead of build_header()
  acpi: arm: virt: build_iort: use acpi_table_begin()/acpi_table_end()
    instead of build_header()
  acpi: arm/virt: convert build_iort() to endian agnostic
    build_append_FOO() API
  acpi: arm/virt: build_spcr: fix invalid cast
  acpi: arm/virt: build_spcr: use acpi_table_begin()/acpi_table_end()
    instead of build_header()
  acpi: arm/virt: build_gtdt: use acpi_table_begin()/acpi_table_end()
    instead of build_header()
  acpi: build_facs: use build_append_int_noprefix() API to compose table
  acpi: remove no longer used build_header()
  acpi: AcpiGenericAddress no longer used to map/access fields of MMIO,
    drop packed attribute

 include/hw/acpi/acpi-defs.h          | 528 +-----------------------
 include/hw/acpi/acpi_dev_interface.h |   3 +-
 include/hw/acpi/aml-build.h          |  37 +-
 include/hw/i386/pc.h                 |   6 +-
 hw/acpi/acpi-x86-stub.c              |   3 +-
 hw/acpi/aml-build.c                  | 203 ++++++----
 hw/acpi/cpu.c                        |  17 +-
 hw/acpi/ghes.c                       |  10 +-
 hw/acpi/hmat.c                       |  14 +-
 hw/acpi/nvdimm.c                     |  64 ++-
 hw/acpi/pci.c                        |  18 +-
 hw/acpi/vmgenid.c                    |  13 +-
 hw/arm/virt-acpi-build.c             | 577 +++++++++++++++------------
 hw/i386/acpi-build.c                 | 294 ++++++++------
 hw/i386/acpi-common.c                | 160 ++++----
 hw/i386/acpi-microvm.c               |  13 +-
 16 files changed, 801 insertions(+), 1159 deletions(-)

-- 
2.27.0



^ permalink raw reply	[flat|nested] 40+ messages in thread

end of thread, other threads:[~2021-09-27 10:11 UTC | newest]

Thread overview: 40+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-09-24 12:27 [PATCH v4 00/35] acpi: refactor error prone build_header() and packed structures usage in ACPI tables Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 01/35] acpi: add helper routines to initialize " Igor Mammedov
2021-09-24 20:52   ` Stefan Berger
2021-09-26  9:16   ` wangyanan (Y)
2021-09-24 12:27 ` [PATCH v4 02/35] acpi: build_rsdt: use acpi_table_begin()/acpi_table_end() instead of build_header() Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 03/35] acpi: build_xsdt: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 04/35] acpi: build_slit: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 05/35] acpi: build_fadt: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 06/35] acpi: build_tpm2: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 07/35] acpi: acpi_build_hest: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 08/35] acpi: build_mcfg: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 09/35] acpi: build_hmat: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 10/35] acpi: nvdimm_build_nfit: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 11/35] acpi: nvdimm_build_ssdt: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 12/35] acpi: vmgenid_build_acpi: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 13/35] acpi: x86: build_dsdt: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 14/35] acpi: build_hpet: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 15/35] acpi: build_tpm_tcpa: " Igor Mammedov
2021-09-24 20:46   ` Stefan Berger
2021-09-24 12:27 ` [PATCH v4 16/35] acpi: arm/x86: build_srat: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 17/35] acpi: use build_append_int_noprefix() API to compose SRAT table Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 18/35] acpi: build_dmar_q35: use acpi_table_begin()/acpi_table_end() instead of build_header() Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 19/35] acpi: build_waet: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 20/35] acpi: build_amd_iommu: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 21/35] acpi: madt: arm/x86: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 22/35] acpi: x86: remove dead code Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 23/35] acpi: x86: set enabled when composing _MAT entries Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 24/35] acpi: x86: madt: use build_append_int_noprefix() API to compose MADT table Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 25/35] acpi: arm/virt: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 26/35] acpi: build_dsdt_microvm: use acpi_table_begin()/acpi_table_end() instead of build_header() Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 27/35] acpi: arm: virt: build_dsdt: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 28/35] acpi: arm: virt: build_iort: " Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 29/35] acpi: arm/virt: convert build_iort() to endian agnostic build_append_FOO() API Igor Mammedov
2021-09-27  9:56   ` Eric Auger
2021-09-24 12:27 ` [PATCH v4 30/35] acpi: arm/virt: build_spcr: fix invalid cast Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 31/35] acpi: arm/virt: build_spcr: use acpi_table_begin()/acpi_table_end() instead of build_header() Igor Mammedov
2021-09-24 12:27 ` [PATCH v4 32/35] acpi: arm/virt: build_gtdt: " Igor Mammedov
2021-09-24 12:28 ` [PATCH v4 33/35] acpi: build_facs: use build_append_int_noprefix() API to compose table Igor Mammedov
2021-09-24 12:28 ` [PATCH v4 34/35] acpi: remove no longer used build_header() Igor Mammedov
2021-09-24 12:28 ` [PATCH v4 35/35] acpi: AcpiGenericAddress no longer used to map/access fields of MMIO, drop packed attribute Igor Mammedov

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.