From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-qv1-f42.google.com (mail-qv1-f42.google.com [209.85.219.42]) by mx.groups.io with SMTP id smtpd.web09.26061.1612135517827492709 for ; Sun, 31 Jan 2021 15:25:18 -0800 Authentication-Results: mx.groups.io; dkim=pass header.i=@nuviainc-com.20150623.gappssmtp.com header.s=20150623 header.b=a1erZpB3; spf=pass (domain: nuviainc.com, ip: 209.85.219.42, mailfrom: rebecca@nuviainc.com) Received: by mail-qv1-f42.google.com with SMTP id ew18so7359727qvb.4 for ; Sun, 31 Jan 2021 15:25:17 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nuviainc-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=fk6t+x6wB3XDoiotOxX7RayoVra+5Y71okE1gGH2rSg=; b=a1erZpB3xM6vBOm1+qSd0cPnw28/IjhmmRDvLBVhy8QHuVmERE+Uc9Mv1BH+lK8Pze g6jDh1mWx2VhpGyJ4RWa7rh6n948gHNBbcRzpJGXvJoksn9C7HBj2LOu6Dq6+OumKgkB eqUAIT29l6x8vS91mQf3X6Q4gPH1AhQCAn/BgLf4RJqs6P5Z7N61ifR1avjVBZco0CHs lAsfiEG9bI2R4hWlKdGR4v3iFqmnUk0C4LmLUuo+JdVdjoouB+iOOhTs1U9Wftr1gplS Gol282xZyDSm5wCgddDzTfHTuYU8YG8stxOM4x3onSAdGzHKGy0BFZ7wo5LPQyFGX+2G 0WlQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=fk6t+x6wB3XDoiotOxX7RayoVra+5Y71okE1gGH2rSg=; b=QoO4Z9F1k2phw5br39brpbgwnaF0MeUZ+LP0yO4Ck2FsSufI1J0loAszhdCxz5nBB+ /W34v/OMNvlomeDc6+tZeK2dBxcG8BQUHVo8p7X5lJfSKdRmPm0/n1ISoOHlO8KLtYxG wAa3WiQtECZ+4vfzf0O47Ze1b7hxqqypbD5enxsb69nX00C1JlWudDGz7HZnOJf84q/J QZ4k4AYz5JBs9v8jSUo1YocUO2GAahDHiwlGt7GW+0fokq7Ldtfu3mRl5EwftKpKNuNO x4sMJ9+Xd8rniCBigcXBE7PqAM4FPnGovkKJpwTyKYQx6HQT0KsUeqLGXAuw6SaOrKW7 RgoA== X-Gm-Message-State: AOAM532dHrgM/rkiPf3ienBclwpzF0awOPOWBRNBN8wAzRlzrrcP5Hc+ CJvBrWAcu7c7waqtpXj9ESKk16BERCc7aSMcMZ7mzWTrlTggAPZzfEB15YNoYnZPG+zr6HzUuYg 0hX8EPERdnX/nnhFUyin8RXg4RTURj4yWOjy2J+N5pzYw760sg1Wlr/kwdmDpYDAt44psDw== X-Google-Smtp-Source: ABdhPJxdryK/9nl9EsuQpu2kYWne+HoGlQZJt3lI6FpCVM91KnBxJtMPHV89chhg7AmbJg4G0K4aEQ== X-Received: by 2002:a05:6214:118e:: with SMTP id t14mr13121609qvv.50.1612135516632; Sun, 31 Jan 2021 15:25:16 -0800 (PST) Return-Path: Received: from cube.int.bluestop.org (c-174-52-16-57.hsd1.ut.comcast.net. [174.52.16.57]) by smtp.gmail.com with ESMTPSA id 12sm11809361qkg.39.2021.01.31.15.25.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 31 Jan 2021 15:25:16 -0800 (PST) From: "Rebecca Cran" To: devel@edk2.groups.io Cc: Rebecca Cran , leif@nuviainc.com, Ard Biesheuvel , nd@arm.com, Sami Mujawar , Liming Gao , Michael D Kinney , Zhiguang Liu , Samer El-Haj-Mahmoud , =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= Subject: [PATCH v7 00/21] ArmPkg,MdePkg: Add Universal/Smbios, and related changes Date: Sun, 31 Jan 2021 16:24:50 -0700 Message-Id: <20210131232511.18340-1-rebecca@nuviainc.com> X-Mailer: git-send-email 2.26.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit 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,7,13,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. Changes from v6 to v7: o Fixed CCSIDR2 vs CSSIDR2 typo. o Extracted Arm and Aarch64 functionality from ProcessorSubClass.c into SmbiosProcessorAArch64.c, SmbiosProcessorArm.c and SmbiosProcessorArmCommon.c. o Fixed various whitespace issues. More changes are needed to support reporting boot status etc., but with the series getting rather large I think it might be good to get this committed and make a follow-up series with the additional changes. Testing: o Ran Ecc tool and fixed various issues. Several remain, but I think they're bogus. o Ran FWTS. o Ran smbiosview in the UEFI Shell, and dmidecode in Linux. Rebecca Cran (21): ArmPkg: Add ARM SMC Architecture functions to ArmStdSmc.h MdePkg: Update IndustryStandard/SmBios.h with processor status data ArmPkg: Add register encoding definition for MMFR2 ArmPkg: Add helper to read the Memory Model Features Register 2 ArmPkg: Add helper function to read the Memory Model Feature Register 4 ArmPkg: Fix the return type of the ReadCCSIDR function ArmPkg: Update ArmLibPrivate.h with cache register definitions ArmPkg: Add definition of the maximum cache level in ARMv8-A ArmPkg: Add helper to read CCIDX status ArmPkg: Add helper to read the CCSIDR2 register ArmPkg: Add Library/OemMiscLib.h ArmPkg: Add Universal/Smbios/OemMiscLibNull ArmPkg: Add Universal/Smbios/ProcessorSubClassDxe ArmPkg: Add Universal/Smbios/SmbiosMiscDxe/Type00 ArmPkg: Add Universal/Smbios/SmbiosMiscDxe/Type01 ArmPkg: Add Universal/Smbios/SmbiosMiscDxe/Type02 ArmPkg: Add Universal/Smbios/SmbiosMiscDxe/Type03 ArmPkg: Add Universal/Smbios/SmbiosMiscDxe/Type13 ArmPkg: Add Universal/Smbios/SmbiosMiscDxe/Type32 ArmPkg: Add SMBIOS PCDs to ArmPkg.dec ArmPkg: Add Universal/Smbios/SmbiosMiscDxe ArmPkg/ArmPkg.dec | 17 + ArmPkg/ArmPkg.dsc | 5 + ArmPkg/Universal/Smbios/OemMiscLibNull/OemMiscLibNull.inf | 31 + ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClassDxe.inf | 65 ++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscDxe.inf | 89 +++ ArmPkg/Include/Chipset/AArch64.h | 4 + ArmPkg/Include/IndustryStandard/ArmStdSmc.h | 16 + ArmPkg/Include/Library/ArmLib.h | 15 + ArmPkg/Include/Library/OemMiscLib.h | 166 +++++ ArmPkg/Library/ArmLib/AArch64/AArch64Lib.h | 11 + ArmPkg/Library/ArmLib/Arm/ArmV7Lib.h | 8 +- ArmPkg/Library/ArmLib/ArmLibPrivate.h | 117 ++- ArmPkg/Universal/Smbios/ProcessorSubClassDxe/SmbiosProcessor.h | 106 +++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMisc.h | 134 ++++ MdePkg/Include/IndustryStandard/SmBios.h | 13 + ArmPkg/Library/ArmLib/AArch64/AArch64Lib.c | 19 +- ArmPkg/Library/ArmLib/Arm/ArmV7Lib.c | 19 +- ArmPkg/Universal/Smbios/OemMiscLibNull/OemMiscLib.c | 143 ++++ ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClass.c | 766 ++++++++++++++++++++ ArmPkg/Universal/Smbios/ProcessorSubClassDxe/SmbiosProcessorAArch64.c | 97 +++ ArmPkg/Universal/Smbios/ProcessorSubClassDxe/SmbiosProcessorArm.c | 103 +++ ArmPkg/Universal/Smbios/ProcessorSubClassDxe/SmbiosProcessorArmCommon.c | 250 +++++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscDataTable.c | 62 ++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscEntryPoint.c | 223 ++++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type00/MiscBiosVendorData.c | 93 +++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type00/MiscBiosVendorFunction.c | 296 ++++++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturerData.c | 36 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturerFunction.c | 196 +++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type02/MiscBaseBoardManufacturerData.c | 46 ++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type02/MiscBaseBoardManufacturerFunction.c | 230 ++++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturerData.c | 52 ++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturerFunction.c | 224 ++++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type13/MiscNumberOfInstallableLanguagesData.c | 33 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type13/MiscNumberOfInstallableLanguagesFunction.c | 166 +++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type32/MiscBootInformationData.c | 32 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type32/MiscBootInformationFunction.c | 73 ++ ArmPkg/Library/ArmLib/AArch64/AArch64Support.S | 3 + ArmPkg/Library/ArmLib/AArch64/ArmLibSupportV8.S | 2 +- ArmPkg/Library/ArmLib/Arm/ArmLibSupportV7.S | 16 +- ArmPkg/Library/ArmLib/Arm/ArmLibSupportV7.asm | 16 +- ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClassStrings.uni | 24 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscDxeStrings.uni | 22 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type00/MiscBiosVendor.uni | 18 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturer.uni | 20 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type02/MiscBaseBoardManufacturer.uni | 20 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturer.uni | 18 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type13/MiscNumberOfInstallableLanguages.uni | 43 ++ 47 files changed, 4150 insertions(+), 8 deletions(-) create mode 100644 ArmPkg/Universal/Smbios/OemMiscLibNull/OemMiscLibNull.inf create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClassDxe.inf create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscDxe.inf create mode 100644 ArmPkg/Include/Library/OemMiscLib.h create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/SmbiosProcessor.h create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMisc.h create mode 100644 ArmPkg/Universal/Smbios/OemMiscLibNull/OemMiscLib.c create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClass.c create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/SmbiosProcessorAArch64.c create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/SmbiosProcessorArm.c create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/SmbiosProcessorArmCommon.c create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscDataTable.c create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscEntryPoint.c 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/MiscSystemManufacturerData.c create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturerFunction.c 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/MiscChassisManufacturerData.c create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturerFunction.c 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 create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClassStrings.uni create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscDxeStrings.uni create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type00/MiscBiosVendor.uni create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturer.uni create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type02/MiscBaseBoardManufacturer.uni create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturer.uni create mode 100644 ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type13/MiscNumberOfInstallableLanguages.uni -- 2.26.2