BruceX Wang
aad98d915a
UefiPayloadPkg: Fix incorrect code on AddSectionHeader
...
Fix incorrect code on AddSectionHeader32() and AddSectionHeader64()
Cc: Guo Dong <guo.dong@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Signed-off-by: BruceX Wang <brucex.wang@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
2023-06-14 14:49:52 +00:00
MarsX Lin
51bb8eb76c
UefiPayloadPkg: Add CAPSULE_SUPPORT in UPL and set it as FALSE in default
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4479
Add CAPSULE_SUPPORT to optionally select CapsuleLib instance,
default value is FALSE.
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Cc: Guo Dong <guo.dong@intel.com >
Signed-off-by: MarsX Lin <marsx.lin@intel.com >
2023-06-13 06:36:16 +00:00
Gua Guo
69abcf1e78
UefiPayloadPkg: Enhance build script for BuildEntryOnly
...
Currently, have two command for pre-build binary support
1. --BuildEntryOnly: build UPL Entry file
2. --PreBuildUplBinary: build UPL binary based on UPL
And these two commands should be exclusived, shouldn't
have chance run it in the meantime.
Case1: Build UPL entry with CLANGDWARF
python UefiPayloadPkg/UniversalPayloadBuild.py --BuildEntryOnly
Case2: Use pre-built UPL entry and build other fv by VS2019
python UefiPayloadPkg/UniversalPayloadBuild.py -t VS2019 \
--PreBuildUplBinary UniversalPayload.elf
Case3: Build UPL Entry with CLANGDWARF and build other fv by VS2019
python UefiPayloadPkg/UniversalPayloadBuild.py -t VS2019
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Signed-off-by: Gua Guo <gua.guo@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
2023-06-07 18:22:28 +00:00
Jiaxin Wu
d8e5d35ede
UefiPayloadPkg: Add CpuPageTableLib required by SecCore & CpuMpPei
...
Add CpuPageTableLib required by SecCore & CpuMpPei in UefiPayloadPkg.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Zeng Star <star.zeng@intel.com >
Signed-off-by: Jiaxin Wu <jiaxin.wu@intel.com >
Reviewed-by: Ray Ni <ray.ni@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
2023-05-31 04:48:36 +00:00
Guo Dong
cafb4f3f36
UefiPayloadPkg: Fix boot shell issue for universal UEFI payload
...
After moving BDS driver to a new FV for universal UEFI payload,
the shell boot option path is not correct since it used the BDS
FV instead of DXE FV in its device path.
This patch would find the correct FV by reading shell file.
It also removed PcdShellFile by using gUefiShellFileGuid.
Signed-off-by: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Reviewed-by: Mike Maslenkin <mike.maslenkin@gmail.com >
2023-05-15 21:26:04 +00:00
PaytonX Hsieh
23c71536ef
UefiPayloadPkg: Fix issues when MULTIPLE_DEBUG_PORT_SUPPORT is true
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4427
1. Since UART speed is slower than CPU, BIOS need to check the write
buffer is empty, to avoid overwrite the buffer content.
2. LPSS UART might disable MMIO space for Windows debug usage during
ExitBootServices event. BIOS need to avoid access the MMIO space
after ExitBootServices.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: PaytonX Hsieh <paytonx.hsieh@intel.com >
2023-05-02 07:11:21 +00:00
BruceX Wang
95ef765839
UefiPayloadPkg: Clang dependency removal
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4426
Use Python to replace llvm-objcopy in UniversalPayloadBuild.py.
1. AddSection32() and AddSection64(): Make a section named
<section> with the contents of <file>.
2. RemoveSection32() and RemoveSection64(): Remove <section>.
3. ReplaceFv (): remove the section before add the section
if the file exists.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Signed-off-by: BruceX Wang <brucex.wang@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
2023-04-28 05:54:26 +00:00
Linus Wu
67b5dba791
UefiPayloadPkg: Move Network modules from Dxe FV to Network FV in elf
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4417
Since UefiPayload had supported multiple FV,
move Network.fdf.inc to new firmware volume and
add this network FV into elf file.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Signed-off-by: Linus Wu <linusx.wu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
2023-04-20 18:47:10 +00:00
Sean Rhodes
89520115b8
UefiPayloadPkg: Update default memory type information for S4
...
Copied values from OVMF, these are sufficient for a debug build.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Reviewed-by: Sean Rhodes <sean@starlabs.systems >
Signed-off-by: Benjamin Doron <benjamin.doron00@gmail.com >
Signed-off-by: Sean Rhodes <sean@starlabs.systems >
2023-04-12 11:50:30 +00:00
Benjamin Doron
dc5f2905eb
UefiPayloadPkg: Always build MemoryTypeInformation HOB for DXE GCD
...
MemoryType information assists GCD with defragmenting the memory map.
When the DXE core starts, GCD adds memory descriptors for the resource
descriptors HOBs. This allocates heap space which can be reused later
as the bins by memory type. It seems memory allocation prefers low
ranges.
It seems "below 4G" is an artifact of this heap reuse. However, the
memory type information determines the DXE core's
`MinimalMemorySizeNeeded`, determining which system memory descriptor
HOB may be used by DXE. Furthermore, it's important that the memory
type information be correct, for an S4 memory map.
Therefore, follow other bootloaders, such as [MinPlatform][1], and do
this unconditionally. As of [edk2-stable202011][2], it was.
[1]: b6f9674389/Platform/Intel/MinPlatformPkg/PlatformInit/PlatformInitPei/PlatformInitPreMem.c (L164-L201)
[2]: https://github.com/tianocore/edk2/blob/edk2-stable202011/UefiPayloadPkg/BlSupportPei/BlSupportPei.c#L462-L466
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Reviewed-by: Sean Rhodes <sean@starlabs.systems >
Signed-off-by: Benjamin Doron <benjamin.doron00@gmail.com >
2023-04-12 11:50:30 +00:00
Rebecca Cran
33f30cfec2
UefiPayloadPkg: Update code to be more C11 compliant by using __func__
...
__FUNCTION__ is a pre-standard extension that gcc and Visual C++ among
others support, while __func__ was standardized in C99.
Since it's more standard, replace __FUNCTION__ with __func__ throughout
UefiPayloadPkg.
Signed-off-by: Rebecca Cran <rebecca@bsdio.com >
Reviewed-by: Michael D Kinney <michael.d.kinney@intel.com >
Reviewed-by: Ard Biesheuvel <ardb@kernel.org >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
2023-04-10 14:19:57 +00:00
KasimX Liu
cdf6ff1719
UefiPayloadPkg:Add new build commands for UniversalPayload
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4375
add '-pb' command of build bios with exist PreUniversalPayload file.
'-e' command of olny build the UniversalPayloadentry file.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: KasimX Liu <kasimx.liu@intel.com >
2023-04-07 03:47:30 +00:00
Linus Wu
e3e88d90e8
UefiPayloadPkg: Support more input parameter
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4386
Add additional input parameter support
--SpecRevision: user input spec version
--Revision: user input revision
--ProducerId: producer company name
1. UniversalPayloadBuild.py
2. Downgrade spec revision from 0.9 to 0.7
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: Linus Wu <linusx.wu@intel.com >
2023-03-30 02:25:13 +00:00
Gua Guo
1bfc89414d
UefiPayloadPkg: Add gUefiAcpiBoardInfoGuid support
...
if system both exist gUefiAcpiBoardInfoGuid and rsdp,
we may need to use gUefiAcpiBoardInfoGuid as final
config to have backward support.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Reviewed-by: James Lu <james.lu@intel.com >
Signed-off-by: Gua Guo <gua.guo@intel.com >
2023-03-27 04:21:28 +00:00
MarsX Lin
961792c9d6
UefiPayloadPkg: Correct MAX_LOGICAL_PROCESSORS value
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4372
Correct MAX_LOGICAL_PROCESSORS value to 1024
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: MarsX Lin <marsx.lin@intel.com >
2023-03-14 09:51:58 +00:00
Yu Pu
a4c9c2b0f0
UefiPayloadPkg: Remove UefiCpuLib from module INFs.
...
Because UefiCpuPkg/UefiCpuLib is merged to MdePkg/CpuLib, remove the
dependency of UefiCpuLib.
Reviewed-by: Guo Dong <guo.dong@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Maurice Ma <maurice.ma@intel.com >
Cc: Benjamin You <benjamin.you@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Signed-off-by: Yu Pu <yu.pu@intel.com >
Reviewed-by: Ray Ni <ray.ni@intel.com >
2023-03-10 08:23:56 +00:00
Xie, Yuanhao
6bc74286e7
UefiPayloadPkg: Add CpuPageTableLib required by MpInitLib.
...
Add CpuPageTableLib required by MpInitLib in UefiPayloadPkg.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Signed-off-by: Yuanhao Xie <yuanhao.xie@intel.com >
Acked-by: Gerd Hoffmann <kraxel@redhat.com >
Tested-by: Gerd Hoffmann <kraxel@redhat.com >
Reviewed-by: Ray Ni <ray.ni@intel.com >
2023-03-07 08:14:59 +00:00
MarsX Lin
1eeca0750a
UefiPayloadPkg: remove the change that get platform specific logic
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4241
Since UefiPayloadPkg had supported multiple firmware volume,
remove the platform specific logic via protocol
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: Gua Guo <gua.guo@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Guo Dong <guo.dong@intel.com >
Signed-off-by: MarsX Lin <marsx.lin@intel.com >
2023-02-23 07:47:12 +00:00
KasimX Liu
2f2fd79fc4
UefiPayloadPkg: Set RTC dynamic PCD to PeiPCDdatabase
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4193
In order to remove RTC_INDEX/RTC_TARGET from
the UplBuild macro list,change the RTC_INDEX
/RTC_TARGET type from PcdsFixedAtBuild to PcdsDynamicEx
Reviewed-by: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: KasimX Liu <kasimx.liu@intel.com >
2023-01-31 15:04:26 +00:00
Ning Feng
2cc6d4c8ed
UefiPayloadPkg: Fix debug print error level hob not save correct
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4264
Fix debug print error level hob not save correct DebugPrintErrorlevel
Should cover the case:
Header.Length == UNIVERSAL_PAYLOAD_SIZEOF_THROUGH_FIELD ()
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Signed-off-by: Ning Feng <ning.feng@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
2023-01-10 03:44:38 +00:00
Yuanhao Xie
5ef3990735
Revert "UefiPayloadPkg: Add CpuPageTableLib required by MpInitLib."
...
This reverts commit 3f378450df
, since the
commit 73ccde8
introduced CpuPageTableLib dependency which resolved
for UefiPayloadPkg need to be reverted.
Ref: https://bugzilla.tianocore.org/show_bug.cgi?id=4234
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Reviewed-by: Laszlo Ersek <lersek@redhat.com >
Signed-off-by: Yuanhao Xie <yuanhao.xie@intel.com >
2023-01-09 17:53:41 +00:00
KasimX Liu
d8d829b89d
UefiPayloadPkg: Move RTC PCD to dynamic PCD
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4193
In order to remove RTC_INDEX/RTC_TARGET from
the UplBuild macro list,change the RTC_INDEX
/RTC_TARGET type from PcdsFixedAtBuild to PcdsDynamicEx
Reviewed-by: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: KasimX Liu <kasimx.liu@intel.com >
2023-01-06 16:10:13 +00:00
Guo Dong
d8d4abdff9
UefiPayloadPkg: Fix boot issue for non-universal payload
...
BDS module was moved from DXEFV to newly created BDSFV recently.
Non-universal UEFI payload doesn't support multiple FV, so it failed
to boot since BDS module could not be found.
This patch add BDS back to DXEFV when UNIVERSAL_PAYLOAD is not set.
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Signed-off-by: Guo Dong <guo.dong@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
2022-12-22 17:16:54 +00:00
MarsX Lin
3c16e6fb97
UefiPayloadPkg: Fixed that The UPL info section is not aligned at 4-byte
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4196
Align .upld_info with 4-byte boundary by spec
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: MarsX Lin <marsx.lin@intel.com >
2022-12-21 04:44:29 +00:00
Yuanhao Xie
3f378450df
UefiPayloadPkg: Add CpuPageTableLib required by MpInitLib.
...
Add CpuPageTableLib required by MpInitLib in UefiPayloadPkg.
Signed-off-by: Yuanhao Xie <yuanhao.xie@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Reviewed-by: Ray Ni <ray.ni@intel.com >
2022-12-20 08:38:28 +00:00
Kavya
6937fc8338
UefiPayloadPkg/SerialPortLib: Enhance multi port behaviour
...
Add condition to return success if mUartCount is greater
than zero in SerialPortInitialize() to avoid filling mUartInfo
with the same hob data when SerialPortInitialize() is called
multiple times. Also add proper conditions in SerialPortRead
function to read the data properly from multiple UART's.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: Kavya <k.kavyax.sravanthi@intel.com >
2022-12-20 07:53:41 +00:00
jdzhang
560f9bb063
UefiPayloadPkg: Define default values for the DynamicEX PCDs
...
The following PCDs have no value in UefiPayloadPkg.dsc
and they can not pass the Ecc tool check, so assign
the default values the same as they are in *.dec file.
1. gEfiMdeModulePkgTokenSpaceGuid.PcdAriSupport
2. gEfiMdeModulePkgTokenSpaceGuid.PcdMrIovSupport
3. gEfiMdeModulePkgTokenSpaceGuid.PcdSrIovSuppor
4. gEfiMdeModulePkgTokenSpaceGuid.PcdSrIovSystemPageSize
5. gUefiCpuPkgTokenSpaceGuid.PcdCpuApInitTimeOutInMicroSeconds
6. gUefiCpuPkgTokenSpaceGuid.PcdCpuApLoopMode
7. gUefiCpuPkgTokenSpaceGuid.PcdCpuMicrocodePatchAddress
8. gUefiCpuPkgTokenSpaceGuid.PcdCpuMicrocodePatchRegionSize
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: jdzhang <jdzhang@kunluntech.com.cn >
2022-12-20 03:53:47 +00:00
MarsX Lin
05da2d24b0
UefiPayloadPkg: Move bdsdxe.inf from DXEFV to BDSFV
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4196
Since UefiPayload had supported multiple fv,
move bdsdxe.inf to new firmware volume and
modify the script of UniversalPayloadPkgBuild.py to
support bdsdxe fv in elf file
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: MarsX Lin <marsx.lin@intel.com >
2022-12-19 07:28:55 +00:00
MarsX Lin
a639248bd0
UefiPayloadPkg: Support multiple firmware volume
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4164
To support multiple FVs provided by UPL
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: MarsX Lin <marsx.lin@intel.com >
2022-12-06 10:13:54 +00:00
VictorX Hsu
85d805ed32
UefiPayloadPkg: The UPL info section is not aligned at 4-byte boundary
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4153
1.Upgrade spec revision to 0.9
2.Align .upld_info with 4-byte boundary by spec
Reviewed-by: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Signed-off-by: VictorX Hsu <victorx.hsu@intel.com >
2022-11-28 06:59:08 +00:00
Min M Xu
a89f558d3c
OvmfPkg/UefiCpuPkg/UefiPayloadPkg: Rename VmgExitLib to CcExitLib
...
BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=4123
VmgExitLib once was designed to provide interfaces to support #VC handler
and issue VMGEXIT instruction. After TDVF (enable TDX feature in OVMF) is
introduced, this library is updated to support #VE as well. Now the name
of VmgExitLib cannot reflect what the lib does.
This patch renames VmgExitLib to CcExitLib (Cc means Confidential
Computing). This is a simple renaming and there is no logic changes.
After renaming all the VmgExitLib related codes are updated with
CcExitLib. These changes are in OvmfPkg/UefiCpuPkg/UefiPayloadPkg.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Cc: Eric Dong <eric.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Brijesh Singh <brijesh.singh@amd.com >
Cc: Erdem Aktas <erdemaktas@google.com >
Cc: Gerd Hoffmann <kraxel@redhat.com >
Cc: James Bottomley <jejb@linux.ibm.com >
Cc: Jiewen Yao <jiewen.yao@intel.com >
Cc: Tom Lendacky <thomas.lendacky@amd.com >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Reviewed-by: Jiewen Yao <jiewen.yao@intel.com >
Reviewed-by: Ray Ni <ray.ni@intel.com >
Signed-off-by: Min Xu <min.m.xu@intel.com >
2022-11-14 04:55:34 +00:00
VictorX Hsu
2695e49219
UefiPayloadPkg: Boot mode in PHIT HOB will not be updated
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4136
System will depend on Boot Mode value to do different behavior
Update during Capsule Update process. So UPL need to support
update boot mode.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: VictorX Hsu <victorx.hsu@intel.com >
2022-11-04 12:38:29 +08:00
Gua Guo
5bd2dbc698
UefiPayloadPkg: Remove deprecate Crypto Service
...
REF : https://bugzilla.tianocore.org/show_bug.cgi?id=4096
TDES and ARC4 services are deprecated so set it as disable.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Signed-off-by: Gua Guo <gua.guo@intel.com >
2022-10-13 10:43:52 +08:00
VictorX Hsu
3c0d567c37
UefiPayloadPkg: Provide a wrapper for UniversalPayloadBuild.py
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4071
Provide a wrapper to wrap UniversalPayloadBuild.py
Reviewed-by: Guo Dong <guo.dong@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Signed-off-by: VictorX Hsu <victorx.hsu@intel.com >
2022-09-28 17:52:34 +08:00
James Lu
415fc406d6
UefiPayloadPkg/PayloadLoaderPeim: remove GCC build warning
...
Fix the gcc build warning:
variable PldInfo set but not used [-Wunused-but-set-variable]
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Zhiguang Liu <zhiguang.liu@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Michael D Kinney <michael.d.kinney@intel.com >
Cc: Liming Gao <gaoliming@byosoft.com.cn >
Signed-off-by: Gang Chen <gang.c.chen@intel.com >
2022-09-16 15:46:22 +08:00
Kavya
54c8d5e432
UefiPayloadPkg: Allow DxeMain.inf to consume the new SerialPortLib
...
Let DxeMain.inf consume new SerialPortLib to support multiple
channel debug message on early DXE if the macro
MULTIPLE_DEBUG_PORT_SUPPORT is TRUE.
Reviewed-by: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: Kavya <k.kavyax.sravanthi@intel.com >
2022-09-07 15:30:24 +00:00
Kavya
11a04bb4a6
UefiPayloadPkg: Implement a new SerialPortLib instance
...
Add new Serial port library instance that consumes the HOB defined
in MdeModulePkg/Include/UniversalPayload/SerialPortInfo.h to support
multiple UART's.
Reviewed-by: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Cc: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: Kavya <k.kavyax.sravanthi@intel.com >
2022-09-07 15:30:24 +00:00
KasimX Liu
08522341c4
UefiPayloadPkg: To replace the libraries for the capsule driver.
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4030
For the system support the Capsule function in UPL,
we replace the libraries for the Capsule driver.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: KasimX Liu <kasimx.liu@intel.com >
2022-09-05 02:56:07 +00:00
James Lu
dfdba857a6
UefiPayloadPkg: Fix Coverity report defect
...
https://bugzilla.tianocore.org/show_bug.cgi?id=4018
Coverity report FORWARD_NULL and OVERFLOW_BEFORE_WIDEN potential defect
in UefiPayloadPkg.
Signed-off-by: Gregx Yeh <gregx.yeh@intel.com >
Reviewed-by: Guo Dong <guo.dong@intel.com >
Reviewed-by: James Lu <james.lu@intel.com >
2022-08-23 04:03:01 +00:00
Kavya
c15c9fa420
UefiPayloadPkg: Add macro to control NvmExpressDxe
...
Add NVME_ENABLE macro to control NvmExpressDxe driver.
Reviewed-by: Guo Dong <guo.dong@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: Kavya <k.kavyax.sravanthi@intel.com >
2022-08-23 01:31:35 +00:00
Kavya
2bb0020675
UefiPayloadPkg: Return PciRootBridges instead of NULL
...
Return PciRootBridges instead of NULL and set
PcdPciDisableBusEnumeration to FALSE when
root bridge count is zero.
Reviewed-by: Guo Dong <guo.dong@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: Kavya <k.kavyax.sravanthi@intel.com >
2022-08-23 01:04:17 +00:00
Dun Tan
803ed060ee
UefiPayloadPkg: Remove clearing CR0.WP when protecting pagetable
...
Remove clearing CR0.WP when marking the memory used for page table
as read-only in the page table itself created by UefiPayloadEntry.
This page table address is written to Cr3 after these protection
steps. Till this, the memory used for page table is always RW.
Signed-off-by: Dun Tan <dun.tan@intel.com >
Reviewed-by: Guo Dong <guo.dong@intel.com >
Cc: Maurice Ma <maurice.ma@intel.com >
Cc: Benjamin You <benjamin.you@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Reviewed-by: Ray Ni <ray.ni@intel.com >
2022-08-15 05:15:43 +00:00
Sean Rhodes
444260d45e
UefiPayloadPkg: Load Boot Logo into ACPI table
...
If the boot logo is enabled, this will allow edk2 to pass the logo
to the OS via ACPI.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Signed-off-by: Sean Rhodes <sean@starlabs.systems >
2022-08-03 22:15:00 +00:00
Sean Rhodes
79aab22fca
UefiPayloadPkg: Add a Macro to enable Boot Logo
...
Add a macro called BOOTSPLASH_IMAGE, which when enabled, will
display a logo at boot time.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Signed-off-by: Sean Rhodes <sean@starlabs.systems >
2022-08-03 22:15:00 +00:00
Sean Rhodes
d219119721
UefiPayloadPkg/PlatformBootManagerLib: Correct spacing in boot prompt
...
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Maurice Ma <maurice.ma@intel.com >
Cc: Benjamin You <benjamin.you@intel.com >
Signed-off-by: Sean Rhodes <sean@starlabs.systems >
2022-08-03 21:47:22 +00:00
Benjamin Doron
f26b70cb9f
UefiPayloadPkg: Add support for logging to CBMEM console
...
Writes TianoCore debug logs into the CBMEM console ringbuffer, from
where the user can retrieve them with the `cbmem` userspace utility.
The intention is to aid in debugging non-fatal issues even in release
builds, or simply make TianoCore's logs available to those interested.
Consequently, MDEPKG_NDEBUG must be masked. As an in-memory debug
logging library, ASSERTs must be non-fatal to be seen, so they neither
dead-loop nor create a breakpoint. It is assumed that ASSERT() neither
enforces fatal conditions nor security integrity, as release builds do
not call DebugAssert() from the ASSERT macro.
More detailed debug logs are produced with the DEBUG_CODE macro, but
this guards other debug-related code throughout the codebase. To avoid
changing behaviour on release builds, this is only set for debug builds.
Tested on QEMU, dumping the appropriate memory region in the UEFI shell
shows the TianoCore log. An improved revision of the debug library used
in several coreboot-related EDK2 forks, including MrChromebox's.
Previous revisions also tested on an Acer Aspire VN7-572G laptop.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Maurice Ma <maurice.ma@intel.com >
Cc: Benjamin You <benjamin.you@intel.com >
Cc: Sean Rhodes <sean@starlabs.systems >
Signed-off-by: Benjamin Doron <benjamin.doron00@gmail.com >
2022-07-27 20:54:35 +00:00
James Lu
2677286307
UefiPayloadPkg: Fix RelaAddress type always mismatch in if condition
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3984
Under function RolocateElfDynamic() in Elf32Lib.c
if (RelaAddress == MAX_UINT64) is always FALSE while RelaAddress is UINT32
Fix is to modify if condition check to "if (RelaAddress == MAX_UINT32)"
Cc: Ray Ni <ray.ni@intel.com >
Cc: Guo Dong <guo.dong@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Signed-off-by: James Lu <james.lu@intel.com >
Reviewed-by: Guo Dong <guo.dong@intel.com >
2022-07-27 17:00:40 +00:00
PaytonX Hsieh
a47241f133
UefiPayloadPkg: Add macro to support selection of CryptoDxe driver
...
REF : https://bugzilla.tianocore.org/show_bug.cgi?id=4006
Add CRYPTO_PROTOCOL_SUPPORT to decide CryptoDxe built into UPL.efi
If CRYPTO_PROTOCOL_SUPPORT is true, BIOS will use crypto protocol
instead of building OpensslLib into drivers.
Reviewed-by: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: James Lu <james.lu@intel.com >
Reviewed-by: Gua Guo <gua.guo@intel.com >
Signed-off-by: PaytonX Hsieh <paytonx.hsieh@intel.com >
2022-07-25 16:32:42 +00:00
James Lu
e21b203911
UefiPayloadPkg: Add macro to support selective driver in UPL
...
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3967
Add macros to decide modules built into UPL.elf.
Macro list:
- GENERIC_MEMORY_TEST_ENABLE: GenericMemoryTestDxe
- MEMORY_TEST: NullMemoryTestDxe or GenericMemoryDxe
- ATA_ENABLE: SataControllerDxe, AtaBusDxe
- SD_ENABLE: SdMmcPciDxe, EmmcDxe, SdDxe
- PS2_MOUSE_ENABLE: Ps2MouseDxe
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Gua Guo <gua.guo@intel.com >
Signed-off-by: James Lu <james.lu@intel.com >
Reviewed-by: Ray Ni <Ray.ni@intel.com >
Reviewed-by: Guo Dong <guo.dong@intel.com >
2022-07-18 22:18:16 +00:00
Sean Rhodes
07c8e5e59b
UefiPayloadPkg/PlatformBootManagerLib: Evenly space boot prompt
...
Add 4 spaces before the boot prompt "F2 or Down..." so that the
spacing is equadistant from the top, which is spaced with a `\n`,
and the left.
Cc: Guo Dong <guo.dong@intel.com >
Cc: Ray Ni <ray.ni@intel.com >
Cc: Maurice Ma <maurice.ma@intel.com >
Cc: Benjamin You <benjamin.you@intel.com >
Signed-off-by: Sean Rhodes <sean@starlabs.systems >
Reviewed-by: Guo Dong <guo.dong@intel.com >
2022-07-16 02:57:38 +00:00