From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-pj1-f51.google.com (mail-pj1-f51.google.com [209.85.216.51]) by mx.groups.io with SMTP id smtpd.web12.138.1607363679719127897 for ; Mon, 07 Dec 2020 09:54:39 -0800 Authentication-Results: mx.groups.io; dkim=pass header.i=@nuviainc-com.20150623.gappssmtp.com header.s=20150623 header.b=O7/B7+xM; spf=pass (domain: nuviainc.com, ip: 209.85.216.51, mailfrom: rebecca@nuviainc.com) Received: by mail-pj1-f51.google.com with SMTP id l23so43781pjg.1 for ; Mon, 07 Dec 2020 09:54:39 -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=4TpXj9CnU5EolMV3eJBpsWsMG6Z5CLgovCioUWryaV8=; b=O7/B7+xMdbuUtzm7Xr+XB78GXbKyl8jv2TwJFlWL4LBXZj9xklvBPgFy6RKtMzf5WV utJE7fUz0bupMJkZRv1zreXQw6BX7jh0D9S6Ds7mXYU3LID+TJrc/xVYJ0HihxIyoaCm /WZqEXgJ5h7r8ihaJLNBf0VOE63xj9jftx/GDm0L8bpJPCtYbxTvRB9uLETSGZzYjE1C gZFlunVKx4s5aw44kOdUfiDNlzWvRkq9piDG67qKsRVOmNrH4oe3TY1kwvraU48Ff/IQ Yx1+MxEbGRhgPhZuj7yk4jX9lm6/VIOxp/tey+bnBtvNLzr4aiHAdqm6kcfSefDrqyPV xzQQ== 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=4TpXj9CnU5EolMV3eJBpsWsMG6Z5CLgovCioUWryaV8=; b=eWqEpJ/sYI+tGf3IaIpiABNBxCpQU8eb22y5p8XjmXV1r5goK+O7wkPbjpLZVnCKKy bsQiZtirMRUSZlKKz1k8k7CTj3dRey+FDjjVaFkLIC6C+tIl90GrVikbQMAjHa/1BU6E 5oC+A/Cw4m6YtPfjf4zsWbfvDLdbzMTGfkJuuqJkSumi3yXyoMfkHNKXFLKo1H+fL67a h/MHf79QMWD7MVn6e/Exyg9TUjCN0dVrwq0+UsDgH0jcWx0oLcQHLeIrXtm5u+GcGS3w +SBFNSXej92CYKJLRMv6d1/heIQ6953f/FVgxboJK3bJoJzAEVFzovtOR2gpp8toAW8v UdaA== X-Gm-Message-State: AOAM5338pY0/I18l7c/qilz6QieBJTTmQduPKQpoVzSkZYxvJ1s3LNff 0y1p4l0Mqz+9PIOpyQvC1ztIbvjs5Wvi+Na2ZdfgQw4AFHruiGILL5k4U1Cn49OFpYZD0Gw76/J Ws4AZO+P9tTiaPxwD3ZupBdpUtL2lsCSq4mWXge2jyqt5ZGHczHtMNAfSWDyoVjLvuJZQIFb1 X-Google-Smtp-Source: ABdhPJwrElbN7oH2x4NfO/5ro4LxD2SCjcubIGPa4Hmwc4gyxlz1ZoV9yM/JX9g0hz9HF1CPqGbbTQ== X-Received: by 2002:a17:90a:1bc7:: with SMTP id r7mr13676184pjr.33.1607363678827; Mon, 07 Dec 2020 09:54:38 -0800 (PST) Return-Path: Received: from cube.nuviainc.com (c-174-52-16-57.hsd1.ut.comcast.net. [174.52.16.57]) by smtp.gmail.com with ESMTPSA id nm6sm2369pjb.25.2020.12.07.09.54.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 07 Dec 2020 09:54:38 -0800 (PST) From: "Rebecca Cran" To: devel@edk2.groups.io Cc: Rebecca Cran , Michael D Kinney , Liming Gao , Zhiguang Liu , Leif Lindholm , Ard Biesheuvel Subject: [PATCH v4 00/10] ArmPkg,MdePkg: Add Universal/Smbios, and related changes Date: Mon, 7 Dec 2020 10:54:17 -0700 Message-Id: <20201207175427.28712-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,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. Note: this series is based on top of the pending SmBios.h typo fixes series. Changes from v3 to v4: - Incorporated changes based on v3 feedback. - Improved code style to more closely match the coding standard. - Added Doxygen comments. - Removed the VersionInfo driver, instead integrating code into Universal/Smbios Rebecca Cran (10): 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: Add helper to read CCIDX status 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 Universal/Smbios, a generic SMBIOS library for ARM ArmPkg/ArmPkg.dec | 14 + ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClassDxe.inf | 56 ++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscDxe.inf | 86 ++ ArmPkg/Include/Chipset/AArch64.h | 4 + ArmPkg/Include/IndustryStandard/ArmStdSmc.h | 13 + ArmPkg/Include/Library/ArmLib.h | 10 + ArmPkg/Include/Library/OemMiscLib.h | 95 +++ ArmPkg/Library/ArmLib/AArch64/AArch64Lib.h | 6 + ArmPkg/Library/ArmLib/Arm/ArmV7Lib.h | 6 + ArmPkg/Library/ArmLib/ArmLibPrivate.h | 93 ++- ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMisc.h | 136 ++++ MdePkg/Include/IndustryStandard/SmBios.h | 13 + ArmPkg/Library/ArmLib/AArch64/AArch64Lib.c | 12 + ArmPkg/Library/ArmLib/Arm/ArmV7Lib.c | 12 + ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClass.c | 835 ++++++++++++++++++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscDataTable.c | 61 ++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscEntryPoint.c | 178 +++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type00/MiscBiosVendorData.c | 92 +++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type00/MiscBiosVendorFunction.c | 263 ++++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturerData.c | 35 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturerFunction.c | 173 ++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type02/MiscBaseBoardManufacturerData.c | 45 ++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type02/MiscBaseBoardManufacturerFunction.c | 201 +++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturerData.c | 51 ++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturerFunction.c | 200 +++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type13/MiscNumberOfInstallableLanguagesData.c | 32 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type13/MiscNumberOfInstallableLanguagesFunction.c | 154 ++++ ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type32/MiscBootInformationData.c | 34 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type32/MiscBootInformationFunction.c | 67 ++ ArmPkg/Library/ArmLib/AArch64/AArch64Support.S | 3 + ArmPkg/Library/ArmLib/AArch64/ArmLibSupportV8.S | 2 +- ArmPkg/Library/ArmLib/Arm/ArmLibSupportV7.S | 4 + ArmPkg/Library/ArmLib/Arm/ArmLibSupportV7.asm | 6 +- ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClassStrings.uni | 23 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/SmbiosMiscLibStrings.uni | 21 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type00/MiscBiosVendor.uni | 17 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type01/MiscSystemManufacturer.uni | 20 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type02/MiscBaseBoardManufacturer.uni | 20 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type03/MiscChassisManufacturer.uni | 17 + ArmPkg/Universal/Smbios/SmbiosMiscDxe/Type13/MiscNumberOfInstallableLanguages.uni | 42 + 40 files changed, 3149 insertions(+), 3 deletions(-) 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/SmbiosMiscDxe/SmbiosMisc.h create mode 100644 ArmPkg/Universal/Smbios/ProcessorSubClassDxe/ProcessorSubClass.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/SmbiosMiscLibStrings.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