Blame SOURCES/0008-OvmfPkg-allow-exclusion-of-the-shell-from-the-firmwa.patch

be6997
From 8c739e3281704f16973cf1e93f544d9475bcbecf Mon Sep 17 00:00:00 2001
7439a5
From: Laszlo Ersek <lersek@redhat.com>
7439a5
Date: Tue, 4 Nov 2014 23:02:53 +0100
7439a5
Subject: OvmfPkg: allow exclusion of the shell from the firmware image (RH
7439a5
 only)
7439a5
7439a5
Notes about the RHEL-8.3/20200603-ca407c7246bf [edk2-stable202005] ->
7439a5
RHEL-8.5/20210520-e1999b264f1f [edk2-stable202105] rebase:
7439a5
7439a5
- No manual / explicit code change is necessary, because the newly
7439a5
  inherited OvmfPkg/AmdSev platform already has its own BUILD_SHELL
7439a5
  build-time macro (feature test flag), with default value FALSE -- from
7439a5
  upstream commit b261a30c900a ("OvmfPkg/AmdSev: add Grub Firmware Volume
7439a5
  Package", 2020-12-14).
7439a5
7439a5
- Contextual differences from new upstream commits 2d8ca4f90eae ("OvmfPkg:
7439a5
  enable HttpDynamicCommand", 2020-10-01) and 5ab6a0e1c8e9 ("OvmfPkg:
7439a5
  introduce VirtioFsDxe", 2020-12-21) have been auto-resolved by
7439a5
  git-cherry-pick.
7439a5
7439a5
- Remove obsolete commit message tags related to downstream patch
7439a5
  management: Message-id, Patchwork-id, O-Subject, Acked-by
7439a5
  (RHBZ#1846481).
7439a5
7439a5
Notes about the RHEL-8.2/20190904-37eef91017ad [edk2-stable201908] ->
7439a5
RHEL-8.3/20200603-ca407c7246bf [edk2-stable202005] rebase:
7439a5
7439a5
- context difference from upstream commit ec41733cfd10 ("OvmfPkg: add the
7439a5
  'initrd' dynamic shell command", 2020-03-04) correctly auto-resolved
7439a5
7439a5
Notes about the RHEL-8.1/20190308-89910a39dcfd [edk2-stable201903] ->
7439a5
RHEL-8.2/20190904-37eef91017ad [edk2-stable201908] rebase:
7439a5
7439a5
- no change
7439a5
7439a5
Notes about the RHEL-8.0/20180508-ee3198e672e2 ->
7439a5
RHEL-8.1/20190308-89910a39dcfd rebase:
7439a5
7439a5
- update the patch against the following upstream commits:
7439a5
  - 4b888334d234 ("OvmfPkg: Remove EdkShellBinPkg in FDF", 2018-11-19)
7439a5
  - 277a3958d93a ("OvmfPkg: Don't include TftpDynamicCommand in XCODE5
7439a5
                  tool chain", 2018-11-27)
7439a5
7439a5
Notes about the RHEL-7.6/ovmf-20180508-2.gitee3198e672e2.el7 ->
7439a5
RHEL-8.0/20180508-ee3198e672e2 rebase:
7439a5
7439a5
- reorder the rebase changelog in the commit message so that it reads like
7439a5
  a blog: place more recent entries near the top
7439a5
- no changes to the patch body
7439a5
7439a5
Notes about the 20171011-92d07e48907f -> 20180508-ee3198e672e2 rebase:
7439a5
7439a5
- no change
7439a5
7439a5
Notes about the 20170228-c325e41585e3 -> 20171011-92d07e48907f rebase:
7439a5
7439a5
- no changes
7439a5
7439a5
Notes about the 20160608b-988715a -> 20170228-c325e41585e3 rebase:
7439a5
7439a5
- no changes
7439a5
7439a5
Bugzilla: 1147592
7439a5
7439a5
When '-D EXCLUDE_SHELL_FROM_FD' is passed to 'build', exclude the shell
7439a5
binary from the firmware image.
7439a5
7439a5
Peter Jones advised us that firmware vendors for physical systems disable
7439a5
the memory-mapped, firmware image-contained UEFI shell in
7439a5
SecureBoot-enabled builds. The reason being that the memory-mapped shell
7439a5
can always load, it may have direct access to various hardware in the
7439a5
system, and it can run UEFI shell scripts (which cannot be signed at all).
7439a5
7439a5
Intended use of the new build option:
7439a5
7439a5
- In-tree builds: don't pass '-D EXCLUDE_SHELL_FROM_FD'. The resultant
7439a5
  firmware image will contain a shell binary, independently of SecureBoot
7439a5
  enablement, which is flexible for interactive development. (Ie. no
7439a5
  change for in-tree builds.)
7439a5
7439a5
- RPM builds: pass both '-D SECURE_BOOT_ENABLE' and
7439a5
  '-D EXCLUDE_SHELL_FROM_FD'. The resultant RPM will provide:
7439a5
7439a5
  - OVMF_CODE.fd: SecureBoot-enabled firmware, without builtin UEFI shell,
7439a5
7439a5
  - OVMF_VARS.fd: variable store template matching OVMF_CODE.fd,
7439a5
7439a5
  - UefiShell.iso: a bootable ISO image with the shell on it as default
7439a5
    boot loader. The shell binary will load when SecureBoot is turned off,
7439a5
    and won't load when SecureBoot is turned on (because it is not
7439a5
    signed).
7439a5
7439a5
    UefiShell.iso is the reason we're not excluding the shell from the DSC
7439a5
    files as well, only the FDF files -- when '-D EXCLUDE_SHELL_FROM_FD'
7439a5
    is specified, the shell binary needs to be built the same, only it
7439a5
    will be included in UefiShell.iso.
7439a5
7439a5
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
7439a5
(cherry picked from commit 9c391def70366cabae08e6008814299c3372fafd)
7439a5
(cherry picked from commit d9dd9ee42937b2611fe37183cc9ec7f62d946933)
7439a5
(cherry picked from commit 23df46ebbe7b09451d3a05034acd4d3a25e7177b)
7439a5
(cherry picked from commit f0303f71d576c51b01c4ff961b429d0e0e707245)
7439a5
(cherry picked from commit bbd64eb8658e9a33eab4227d9f4e51ad78d9f687)
7439a5
(cherry picked from commit 8628ef1b8d675ebec39d83834abbe3c8c8c42cf4)
7439a5
(cherry picked from commit 229c88dc3ded9baeaca8b87767dc5c41c05afd6e)
7439a5
(cherry picked from commit c2812d7189dee06c780f05a5880eb421c359a687)
7439a5
---
7439a5
 OvmfPkg/OvmfPkgIa32.fdf    | 2 ++
7439a5
 OvmfPkg/OvmfPkgIa32X64.fdf | 2 ++
7439a5
 OvmfPkg/OvmfPkgX64.fdf     | 2 ++
7439a5
 3 files changed, 6 insertions(+)
7439a5
7439a5
diff --git a/OvmfPkg/OvmfPkgIa32.fdf b/OvmfPkg/OvmfPkgIa32.fdf
be6997
index 57d13b7130..69044874e2 100644
7439a5
--- a/OvmfPkg/OvmfPkgIa32.fdf
7439a5
+++ b/OvmfPkg/OvmfPkgIa32.fdf
be6997
@@ -298,12 +298,14 @@ INF  FatPkg/EnhancedFatDxe/Fat.inf
7439a5
 INF  MdeModulePkg/Universal/Disk/UdfDxe/UdfDxe.inf
7439a5
 INF  OvmfPkg/VirtioFsDxe/VirtioFsDxe.inf
7439a5
 
7439a5
+!ifndef $(EXCLUDE_SHELL_FROM_FD)
7439a5
 !if $(TOOL_CHAIN_TAG) != "XCODE5"
7439a5
 INF  ShellPkg/DynamicCommand/TftpDynamicCommand/TftpDynamicCommand.inf
7439a5
 INF  ShellPkg/DynamicCommand/HttpDynamicCommand/HttpDynamicCommand.inf
7439a5
 INF  OvmfPkg/LinuxInitrdDynamicShellCommand/LinuxInitrdDynamicShellCommand.inf
7439a5
 !endif
7439a5
 INF  ShellPkg/Application/Shell/Shell.inf
7439a5
+!endif
7439a5
 
7439a5
 INF MdeModulePkg/Logo/LogoDxe.inf
7439a5
 
7439a5
diff --git a/OvmfPkg/OvmfPkgIa32X64.fdf b/OvmfPkg/OvmfPkgIa32X64.fdf
be6997
index ccde366887..bf535bef42 100644
7439a5
--- a/OvmfPkg/OvmfPkgIa32X64.fdf
7439a5
+++ b/OvmfPkg/OvmfPkgIa32X64.fdf
be6997
@@ -299,12 +299,14 @@ INF  FatPkg/EnhancedFatDxe/Fat.inf
7439a5
 INF  MdeModulePkg/Universal/Disk/UdfDxe/UdfDxe.inf
7439a5
 INF  OvmfPkg/VirtioFsDxe/VirtioFsDxe.inf
7439a5
 
7439a5
+!ifndef $(EXCLUDE_SHELL_FROM_FD)
7439a5
 !if $(TOOL_CHAIN_TAG) != "XCODE5"
7439a5
 INF  ShellPkg/DynamicCommand/TftpDynamicCommand/TftpDynamicCommand.inf
7439a5
 INF  ShellPkg/DynamicCommand/HttpDynamicCommand/HttpDynamicCommand.inf
7439a5
 INF  OvmfPkg/LinuxInitrdDynamicShellCommand/LinuxInitrdDynamicShellCommand.inf
7439a5
 !endif
7439a5
 INF  ShellPkg/Application/Shell/Shell.inf
7439a5
+!endif
7439a5
 
7439a5
 INF MdeModulePkg/Logo/LogoDxe.inf
7439a5
 
7439a5
diff --git a/OvmfPkg/OvmfPkgX64.fdf b/OvmfPkg/OvmfPkgX64.fdf
be6997
index 438806fba8..21e4ce00dd 100644
7439a5
--- a/OvmfPkg/OvmfPkgX64.fdf
7439a5
+++ b/OvmfPkg/OvmfPkgX64.fdf
be6997
@@ -324,12 +324,14 @@ INF  FatPkg/EnhancedFatDxe/Fat.inf
7439a5
 INF  MdeModulePkg/Universal/Disk/UdfDxe/UdfDxe.inf
7439a5
 INF  OvmfPkg/VirtioFsDxe/VirtioFsDxe.inf
7439a5
 
7439a5
+!ifndef $(EXCLUDE_SHELL_FROM_FD)
7439a5
 !if $(TOOL_CHAIN_TAG) != "XCODE5"
7439a5
 INF  ShellPkg/DynamicCommand/TftpDynamicCommand/TftpDynamicCommand.inf
7439a5
 INF  ShellPkg/DynamicCommand/HttpDynamicCommand/HttpDynamicCommand.inf
7439a5
 INF  OvmfPkg/LinuxInitrdDynamicShellCommand/LinuxInitrdDynamicShellCommand.inf
7439a5
 !endif
7439a5
 INF  ShellPkg/Application/Shell/Shell.inf
7439a5
+!endif
7439a5
 
7439a5
 INF MdeModulePkg/Logo/LogoDxe.inf
7439a5
 
7439a5
-- 
be6997
2.31.1
7439a5