# Note: aarch64 is actually still at shim-15-9.el7, as 15.6 does not build # with the RHEL 7 toolchain. The only reason we updated to 15.6 was for SBAT # revocation, and aarch64 isn't signed into the UEFI chain anyhow. Name: shim-signed Version: 15.6 Release: 3%{?dist}%{?buildid} Summary: First-stage UEFI bootloader %define unsigned_release 3.el7 License: BSD URL: https://github.com/rhboot/shim/ # incorporate mokutil for packaging simplicity %global mokutil_version 0.3.0 Source0: https://github.com/lcp/mokutil/archive/mokutil-%{mokutil_version}.tar.gz Source1: redhatsecureboot501.cer Source2: redhatsecurebootca5.cer Source10: shimx64.efi Source11: shimia32.efi Source12: shimaa64.efi Source20: BOOTX64.CSV Source21: BOOTIA32.CSV Source22: BOOTAA64.CSV Source31: mmaa64.efi Source32: fbaa64.efi Source33: mmia32.efi Source34: fbia32.efi Patch0001: 0001-Fix-the-potential-buffer-overflow.patch Patch0002: 0002-Fix-the-32bit-signedness-comparison.patch Patch0003: 0003-Build-with-fshort-wchar-so-toggle-passwords-work-rig.patch Patch0004: 0004-Don-t-allow-sha1-on-the-mokutil-command-line.patch Patch0005: 0005-Make-all-efi_guid_t-const.patch Patch0006: 0006-mokutil-be-explicit-about-file-modes-in-all-cases.patch Patch0007: 0007-Add-bash-completion-file.patch Patch0008: 0008-Fix-typo-in-error-message-when-the-system-lacks-Secu.patch Patch0009: 0009-list_keys_in_var-check-errno-correctly-not-ret-twice.patch Patch0010: 0010-generate_hash-generate_pw_hash-don-t-use-strlen-for-.patch Patch0011: 0011-initial-mok-variables-code.patch %ifarch x86_64 %global efiarch X64 %global efiarchlc x64 %global shimsrc %{SOURCE10} %global bootsrc %{SOURCE20} %global shimsrcia32 %{SOURCE11} %global bootsrcia32 %{SOURCE21} %define unsigned_dir_ia32 %{_datadir}/shim/ia32-%{version}-%{unsigned_release}/ %endif %ifarch aarch64 %global efiarch AA64 %global efiarchlc aa64 %global shimsrc %{SOURCE12} %global bootsrc %{SOURCE22} %endif %define unsigned_dir %{_datadir}/shim/%{efiarchlc}-%{version}-%{unsigned_release}/ BuildRequires: git BuildRequires: openssl-devel openssl BuildRequires: pesign >= 0.106-5%{dist} BuildRequires: efivar-devel %ifarch x86_64 BuildRequires: shim-unsigned-%{efiarchlc} = %{version}-%{unsigned_release} %endif # for mokutil's configure BuildRequires: autoconf automake # Shim is only required on platforms implementing the UEFI secure boot # protocol. The only one of those we currently wish to support is 64-bit x86. # Adding further platforms will require adding appropriate relocation code. ExclusiveArch: x86_64 aarch64 %define debug_package \ %ifnarch noarch\ %global __debug_package 1\ %package -n mokutil-debuginfo\ Summary: Debug information for package %{name}\ Group: Development/Debug\ AutoReqProv: 0\ %description -n mokutil-debuginfo\ This package provides debug information for package %{name}.\ Debug information is useful when developing applications that use this\ package or when debugging this package.\ %files -n mokutil-debuginfo -f debugfiles.list\ %defattr(-,root,root,-)\ %endif\ %{nil} # Figure out the right file path to use %global efidir %(eval echo $(grep ^ID= /etc/os-release | sed -e 's/^ID=//' -e 's/rhel/redhat/')) %define ca_signed_arches x86_64 %define rh_signed_arches x86_64 aarch64 %description Initial UEFI bootloader that handles chaining to a trusted full bootloader under secure boot environments. This package contains the version signed by the UEFI signing service. %package -n shim-%{efiarchlc} Summary: First-stage UEFI bootloader Requires: mokutil = %{version}-%{release} Provides: shim = %{version}-%{release} Obsoletes: shim <= 12 # Shim uses OpenSSL, but cannot use the system copy as the UEFI ABI is not # compatible with SysV (there's no red zone under UEFI) and there isn't a # POSIX-style C library. # BuildRequires: OpenSSL Provides: bundled(openssl) = 0.9.8zb %description -n shim-%{efiarchlc} Initial UEFI bootloader that handles chaining to a trusted full bootloader under secure boot environments. This package contains the version signed by the UEFI signing service. %ifarch x86_64 %package -n shim-ia32 Summary: First-stage UEFI bootloader Requires: mokutil = %{version}-%{release} # Shim uses OpenSSL, but cannot use the system copy as the UEFI ABI is not # compatible with SysV (there's no red zone under UEFI) and there isn't a # POSIX-style C library. # BuildRequires: OpenSSL Provides: bundled(openssl) = 0.9.8zb %description -n shim-ia32 Initial UEFI bootloader that handles chaining to a trusted full bootloader under secure boot environments. This package contains the version signed by the UEFI signing service. %endif %package -n mokutil Summary: Utilities for managing Secure Boot/MoK keys. %description -n mokutil Utilities for managing the "Machine's Own Keys" list. %prep %setup -T -q -a 0 -n shim-signed-%{version} -c git init git config user.email "example@example.com" git config user.name "rpmbuild -bp" git add . git commit -a -q -m "%{version} baseline." cd mokutil-%{mokutil_version} git am --ignore-whitespace --directory=mokutil-%{mokutil_version} %{patches} shim%{efiarchlc}.hash if ! cmp shim%{efiarchlc}.hash %{unsigned_dir}shim%{efiarchlc}.hash ; then echo Invalid signature\! > /dev/stderr echo saved hash is $(cat %{unsigned_dir}shim%{efiarchlc}.hash) > /dev/stderr echo shim%{efiarchlc}.efi hash is $(cat shim%{efiarchlc}.hash) > /dev/stderr exit 1 fi cp %{shimsrc} shim%{efiarchlc}.efi cp %{shimsrcia32} shimia32.efi %endif %ifarch x86_64 %pesign -s -i %{unsigned_dir}shim%{efiarchlc}.efi -a %{SOURCE2} -c %{SOURCE1} -n redhatsecureboot501 -o shim%{efiarchlc}-%{efidir}.efi %pesign -s -i %{SOURCE11} -a %{SOURCE2} -c %{SOURCE1} -n redhatsecureboot501 -o shimia32-%{efidir}.efi %endif %ifarch aarch64 %pesign -s -i %{SOURCE12} -a %{SOURCE2} -c %{SOURCE1} -n redhatsecureboot501 -o shimaa64-%{efidir}.efi %endif %ifarch %{rh_signed_arches} %ifnarch %{ca_signed_arches} cp shim%{efiarchlc}-%{efidir}.efi shim%{efiarchlc}.efi %endif %endif %ifarch x86_64 %pesign -s -i %{unsigned_dir}mm%{efiarchlc}.efi -o mm%{efiarchlc}.efi -a %{SOURCE2} -c %{SOURCE1} -n redhatsecureboot501 %pesign -s -i %{unsigned_dir}fb%{efiarchlc}.efi -o fb%{efiarchlc}.efi -a %{SOURCE2} -c %{SOURCE1} -n redhatsecureboot501 %pesign -s -i %{SOURCE33} -o mmia32.efi -a %{SOURCE2} -c %{SOURCE1} -n redhatsecureboot501 %pesign -s -i %{SOURCE34} -o fbia32.efi -a %{SOURCE2} -c %{SOURCE1} -n redhatsecureboot501 %endif %ifarch aarch64 %pesign -s -i %{SOURCE31} -o mm%{efiarchlc}.efi -a %{SOURCE2} -c %{SOURCE1} -n redhatsecureboot501 %pesign -s -i %{SOURCE32} -o fb%{efiarchlc}.efi -a %{SOURCE2} -c %{SOURCE1} -n redhatsecureboot501 %endif cd mokutil-%{mokutil_version} ./autogen.sh %configure make %{?_smp_mflags} %install rm -rf $RPM_BUILD_ROOT install -D -d -m 0700 $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/ install -m 0700 shim%{efiarchlc}.efi $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/shim%{efiarchlc}.efi install -m 0700 shim%{efiarchlc}-%{efidir}.efi $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/shim%{efiarchlc}-%{efidir}.efi install -m 0700 mm%{efiarchlc}.efi $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/mm%{efiarchlc}.efi install -m 0700 %{bootsrc} $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/BOOT%{efiarch}.CSV install -D -d -m 0700 $RPM_BUILD_ROOT/boot/efi/EFI/BOOT/ install -m 0700 shim%{efiarchlc}.efi $RPM_BUILD_ROOT/boot/efi/EFI/BOOT/BOOT%{efiarch}.EFI install -m 0700 fb%{efiarchlc}.efi $RPM_BUILD_ROOT/boot/efi/EFI/BOOT/fb%{efiarchlc}.efi %ifarch aarch64 # In case old boot entries aren't updated install -m 0700 %{shimsrc} $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/shim.efi %endif %ifarch x86_64 # In case old boot entries aren't updated install -m 0700 shimx64.efi $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/shim.efi install -m 0700 %{bootsrc} $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/BOOT.CSV install -m 0700 shimia32.efi $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/shimia32.efi install -m 0700 shimia32.efi $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/shimia32.efi install -m 0700 shimia32-%{efidir}.efi $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/shimia32-%{efidir}.efi install -m 0700 mmia32.efi $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/mmia32.efi install -m 0700 %{bootsrcia32} $RPM_BUILD_ROOT/boot/efi/EFI/%{efidir}/BOOTIA32.CSV install -m 0700 shimia32.efi $RPM_BUILD_ROOT/boot/efi/EFI/BOOT/BOOTIA32.EFI install -m 0700 fbia32.efi $RPM_BUILD_ROOT/boot/efi/EFI/BOOT/fbia32.efi %endif cd mokutil-%{mokutil_version} make PREFIX=%{_prefix} LIBDIR=%{_libdir} DESTDIR=%{buildroot} install %files -n shim-%{efiarchlc} %defattr(0700,root,root,-) %verify(not mtime) /boot/efi/EFI/%{efidir}/shim%{efiarchlc}.efi %verify(not mtime) /boot/efi/EFI/%{efidir}/shim%{efiarchlc}-%{efidir}.efi %verify(not mtime) /boot/efi/EFI/%{efidir}/mm%{efiarchlc}.efi %verify(not mtime) /boot/efi/EFI/%{efidir}/BOOT%{efiarch}.CSV %verify(not mtime) /boot/efi/EFI/BOOT/BOOT%{efiarch}.EFI %verify(not mtime) /boot/efi/EFI/BOOT/fb%{efiarchlc}.efi %verify(not mtime) /boot/efi/EFI/%{efidir}/shim.efi %ifarch x86_64 %verify(not mtime) /boot/efi/EFI/%{efidir}/BOOT.CSV %files -n shim-ia32 %defattr(0700,root,root,-) %verify(not mtime) /boot/efi/EFI/%{efidir}/shimia32.efi %verify(not mtime) /boot/efi/EFI/%{efidir}/shimia32-%{efidir}.efi %verify(not mtime) /boot/efi/EFI/%{efidir}/mmia32.efi %verify(not mtime) /boot/efi/EFI/%{efidir}/BOOTIA32.CSV %verify(not mtime) /boot/efi/EFI/BOOT/BOOTIA32.EFI %verify(not mtime) /boot/efi/EFI/BOOT/fbia32.efi %endif %files -n mokutil %{!?_licensedir:%global license %%doc} %license mokutil-%{mokutil_version}/COPYING %doc mokutil-%{mokutil_version}/README %{_bindir}/mokutil %{_mandir}/man1/* %{_datadir}/bash-completion/completions/mokutil %changelog * Mon Apr 17 2023 Robbie Harwood - 15.6-3 - Restore old ia32 for compatibility - Resolves: #2007084 * Fri Apr 14 2023 Robbie Harwood - 15.6-2 - Add Provides/Obsoletes for ia32 upgrading - Resolves: #2007084 * Tue Mar 28 2023 Robbie Harwood - 15.6-1 - New version for SBAT support (x64 only) - Drop ia32 - Resolves: #2007084 * Wed Sep 16 2020 Peter Jones - 15-11 - Fix incorrect allocation size in set_second_stage() Resolves: rhbz#1875486 * Fri Aug 21 2020 Peter Jones - 15-10.el7 - 15-9.el7 was built in the wrong tag. Related: rhbz#1868820 * Mon Aug 17 2020 Peter Jones - 15-9.el7 - Add mokutil code to consume data from /sys/firmware/efi/mok-variables/ as well as attempting to consume numbered mok variables from efivarfs when mok-variables aren't present. Resolves: rhbz#1868820 * Fri Jul 31 2020 Peter Jones - 15-8.el7 - Update to fix hang on some systems. Resolves: rhbz#1862045 * Tue Jul 28 2020 Peter Jones - 15-7 - New signing keys Related: CVE-2020-10713 Related: CVE-2020-14308 Related: CVE-2020-14309 Related: CVE-2020-14310 Related: CVE-2020-14311 * Thu Mar 21 2019 Peter Jones - 15-2 - Fix MoK mirroring issue which breaks kdump without intervention Related: rhbz#1649270 * Fri Jul 20 2018 Peter Jones - 15-1 - Update to shim version 15 Resolves: rhbz#1589962 * Wed Jul 11 2018 Peter Jones - 12-3 - Fix broken file owner/modes Resolves: rhbz#1595677 * Sat Jun 23 2018 Peter Jones - 12-2 - Fix /boot/efi/... permissions to match the filesystem's requirements Related: rhbz#1512749 - Minor .spec cleanups Related: rhbz#1512749 * Mon May 01 2017 Peter Jones - 12-1 - Update to 12-1 to work around a signtool.exe bug Resolves: rhbz#1445393 * Mon Apr 24 2017 Peter Jones - 11-4 - Another shot at better obsoletes. Related: rhbz#1310764 * Mon Apr 24 2017 Peter Jones - 11-3 - Fix Obsoletes Related: rhbz#1310764 * Thu Apr 13 2017 Peter Jones - 11-2 - Make sure Aarch64 still has shim.efi as well Related: rhbz#1310766 * Wed Apr 12 2017 Peter Jones - 11-1 - Rebuild with signed shim Related: rhbz#1310766 * Mon Apr 03 2017 Peter Jones - 11-0.1 - Update to 11-0.1 to match shim-11-1 Related: rhbz#1310766 - Fix regression in PE loader Related: rhbz#1310766 - Fix case where BDS invokes us wrong and we exec shim again as a result Related: rhbz#1310766 * Mon Mar 27 2017 Peter Jones - 10-0.1 - Support ia32 Resolves: rhbz#1310766 - Handle various different load option implementation differences - TPM 1 and TPM 2 support. - Update to OpenSSL 1.0.2k * Mon Jul 20 2015 Peter Jones - 0.9-2 - Apparently I'm *never* going to learn to build this in the right target the first time through. Related: rhbz#1100048 * Mon Jun 29 2015 Peter Jones - 0.9-0.1 - Bump version for 0.9 Also use mokutil-0.3.0 Related: rhbz#1100048 * Tue Jun 23 2015 Peter Jones - 0.7-14.1 - Fix mokutil_version usage. Related: rhbz#1100048 * Mon Jun 22 2015 Peter Jones - 0.7-14 - Pull in aarch64 build so they can compose that tree. (-14 to match -unsigned) Related: rhbz#1100048 * Wed Feb 25 2015 Peter Jones - 0.7-12 - Fix some minor build bugs on Aarch64 Related: rhbz#1190191 * Tue Feb 24 2015 Peter Jones - 0.7-11 - Fix section loading on Aarch64 Related: rhbz#1190191 * Wed Dec 17 2014 Peter Jones - 0.7-10 - Rebuild for Aarch64 to get \EFI\BOOT\BOOTAA64.EFI named right. (I managed to fix the inputs but not the outputs in -9.) Related: rhbz#1100048 * Wed Dec 17 2014 Peter Jones - 0.7-9 - Rebuild for Aarch64 to get \EFI\BOOT\BOOTAA64.EFI named right. Related: rhbz#1100048 * Tue Oct 21 2014 Peter Jones - 0.7-8 - Build for aarch64 as well Related: rhbz#1100048 - out-of-bounds memory read flaw in DHCPv6 packet processing Resolves: CVE-2014-3675 - heap-based buffer overflow flaw in IPv6 address parsing Resolves: CVE-2014-3676 - memory corruption flaw when processing Machine Owner Keys (MOKs) Resolves: CVE-2014-3677 * Tue Sep 23 2014 Peter Jones - 0.7-7 - Make sure we use the right keys on Aarch64. (It's only a demo at this stage.) Related: rhbz#1100048 * Tue Sep 23 2014 Peter Jones - 0.7-6 - Add ARM Aarch64. Related: rhbz#1100048 * Thu Feb 27 2014 Peter Jones - 0.7-5.2 - Get the right signatures on shim-redhat.efi Related: rhbz#1064449 * Thu Feb 27 2014 Peter Jones - 0.7-5.1 - Update for signed shim for RHEL 7 Resolves: rhbz#1064449 * Thu Nov 21 2013 Peter Jones - 0.7-5 - Fix shim-unsigned deps. Related: rhbz#1032583 * Thu Nov 21 2013 Peter Jones - 0.7-4 - Make dhcp4 work better. Related: rhbz#1032583 * Thu Nov 14 2013 Peter Jones - 0.7-3 - Make lockdown include UEFI and other KEK/DB entries. Related: rhbz#1030492 * Fri Nov 08 2013 Peter Jones - 0.7-2 - Handle SetupMode better in lockdown as well Related: rhbz#996863 * Wed Nov 06 2013 Peter Jones - 0.7-1 - Don't treat SetupMode variable's presence as meaning we're in SetupMode. Related: rhbz#996863 * Wed Nov 06 2013 Peter Jones - 0.6-3 - Use the correct CA and signer certificates. Related: rhbz#996863 * Thu Oct 31 2013 Peter Jones - 0.6-1 - Update to 0.6-1 Resolves: rhbz#1008379 * Wed Aug 07 2013 Peter Jones - 0.4-3.2 - Depend on newer pesign. Related: rhbz#989442 * Tue Aug 06 2013 Peter Jones - 0.4-3.1 - Rebuild with newer pesign Related: rhbz#989442 * Tue Aug 06 2013 Peter Jones - 0.4-3 - Update for RHEL signing with early test keys. Related: rhbz#989442 * Thu Jun 20 2013 Peter Jones - 0.4-1 - Provide a fallback for uninitialized Boot#### and BootOrder Resolves: rhbz#963359 - Move all signing from shim-unsigned to here - properly compare our generated hash from shim-unsigned with the hash of the signed binary (as opposed to doing it manually) * Fri May 31 2013 Peter Jones - 0.2-4.4 - Re-sign to get alignments that match the new specification. Resolves: rhbz#963361 * Thu Feb 14 2013 Fedora Release Engineering - 0.2-4.3 - Rebuilt for https://fedoraproject.org/wiki/Fedora_19_Mass_Rebuild * Wed Jan 02 2013 Peter Jones - 0.2-3.3 - Add obsoletes and provides for earlier shim-signed packages, to cover the package update cases where previous versions were installed. Related: rhbz#888026 * Mon Dec 17 2012 Peter Jones - 0.2-3.2 - Make the shim-unsigned dep be on the subpackage. * Sun Dec 16 2012 Peter Jones - 0.2-3.1 - Rebuild to provide "shim" package directly instead of just as a Provides: * Sat Dec 15 2012 Peter Jones - 0.2-3 - Also provide shim-fedora.efi, signed only by the fedora signer. - Fix the fedora signature on the result to actually be correct. - Update for shim-unsigned 0.2-3 * Mon Dec 03 2012 Peter Jones - 0.2-2 - Initial build