Much of the data for the SMBIOS tables is generic, and need not be
duplicated for each platform. This patch series introduces
ArmPkg/Universal/Smbios, which is largely copied from
edk2-platforms/Silicon/HiSilicon/Drivers/Smbios and generates SMBIOS
tables 0,1,2,3,4,713,32 and uses a combination of PCDs and calls into a
new OemMiscLib to get information which varies between platforms.
I plan to submit a patch against SbsaQemu to update it to use this new
functionality.
Rebecca Cran (2):
ArmPkg: Add ARM SMC Architecture calls to ArmStdSmc.h
ArmPkg: add Universal/Smbios as a generic SMBIOS library
ArmPkg/ArmPkg.dec | 16 +
.../Drivers/VersionInfoPeim/VersionInfoPeim.c | 90 +++
.../VersionInfoPeim/VersionInfoPeim.inf | 46 ++
ArmPkg/Include/Guid/VersionInfoHobGuid.h | 29 +
ArmPkg/Include/IndustryStandard/ArmStdSmc.h | 26 +-
ArmPkg/Include/Library/OemMiscLib.h | 140 ++++
ArmPkg/Library/ArmLib/ArmLibPrivate.h | 22 +
.../ProcessorSubClassDxe/ProcessorSubClass.c | 685 ++++++++++++++++++
.../ProcessorSubClassDxe/ProcessorSubClass.h | 40 +
.../ProcessorSubClassDxe.inf | 55 ++
.../ProcessorSubClassStrings.uni | 23 +
.../Smbios/SmbiosMiscDxe/SmbiosMisc.h | 217 ++++++
.../SmbiosMiscDxe/SmbiosMiscDataTable.c | 50 ++
.../Smbios/SmbiosMiscDxe/SmbiosMiscDxe.inf | 89 +++
.../SmbiosMiscDxe/SmbiosMiscEntryPoint.c | 167 +++++
.../SmbiosMiscDxe/SmbiosMiscLibString.uni | 21 +
.../SmbiosMiscDxe/Type00/MiscBiosVendor.uni | 18 +
.../SmbiosMiscDxe/Type00/MiscBiosVendorData.c | 99 +++
.../Type00/MiscBiosVendorFunction.c | 232 ++++++
.../Type01/MiscSystemManufacturer.uni | 21 +
.../Type01/MiscSystemManufacturerData.c | 43 ++
.../Type01/MiscSystemManufacturerFunction.c | 171 +++++
.../Type02/MiscBaseBoardManufacturer.uni | 21 +
.../Type02/MiscBaseBoardManufacturerData.c | 51 ++
.../MiscBaseBoardManufacturerFunction.c | 184 +++++
.../Type03/MiscChassisManufacturer.uni | 18 +
.../Type03/MiscChassisManufacturerData.c | 58 ++
.../Type03/MiscChassisManufacturerFunction.c | 182 +++++
.../MiscNumberOfInstallableLanguages.uni | 43 ++
.../MiscNumberOfInstallableLanguagesData.c | 39 +
...MiscNumberOfInstallableLanguagesFunction.c | 154 ++++
.../Type32/MiscBootInformationData.c | 41 ++
.../Type32/MiscBootInformationFunction.c | 66 ++
33 files changed, 3144 insertions(+), 13 deletions(-)
create mode 100644 ArmPkg/Drivers/VersionInfoPeim/VersionInfoPeim.c
create mode 100644 ArmPkg/Drivers/VersionInfoPeim/VersionInfoPeim.inf
create mode 100644 ArmPkg/Include/Guid/VersionInfoHobGuid.h
create mode 100644 ArmPkg/Include/Library/OemMiscLib.h
create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClass.c
create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClass.h
create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClassDxe.inf
create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClassStrings.uni
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMisc.h
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscDataTable.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscDxe.inf
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscEntryPoint.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscLibString.uni
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type00/MiscBiosVendor.uni
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type00/MiscBiosVendorData.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type00/MiscBiosVendorFunction.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturer.uni
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturerData.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturerFunction.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type02/MiscBaseBoardManufacturer.uni
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type02/MiscBaseBoardManufacturerData.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type02/MiscBaseBoardManufacturerFunction.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturer.uni
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturerData.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturerFunction.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type13/MiscNumberOfInstallableLanguages.uni
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type13/MiscNumberOfInstallableLanguagesData.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type13/MiscNumberOfInstallableLanguagesFunction.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type32/MiscBootInformationData.c
create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type32/MiscBootInformationFunction.c
--
2.26.2
-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#66875): https://edk2.groups.io/g/devel/message/66875
Mute This Topic: https://groups.io/mt/77990688/1787277
Group Owner: devel+owner@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [importer@patchew.org]
-=-=-=-=-=-=-=-=-=-=-=-