1 # Maintainer: David Runge <dvzrv@archlinux.org>
2 # Contributor: Alexander Epaneshnikov <alex19ep@archlinux.org>
7 pkgname=(edk2-arm edk2-aarch64 edk2-shell edk2-ovmf)
9 _commit=f80f052277c88a67c55e107b550f504eeea947d3 # refs/tags/edk2-stable202302
11 pkgdesc="Modern, feature-rich firmware development environment for the UEFI specifications"
13 url="https://github.com/tianocore/edk2"
29 $pkgbase-softfloat::git+https://github.com/ucb-bar/berkeley-softfloat-3.git
30 https://www.openssl.org/source/openssl-$_openssl_ver.tar.gz{,.asc}
31 https://github.com/google/brotli/archive/v$_brotli_ver/brotli-$_brotli_ver.tar.gz
32 50-edk2-ovmf-i386-secure.json
33 50-edk2-ovmf-i386-secure-4m.json
34 50-edk2-ovmf-x86_64-secure.json
35 50-edk2-ovmf-x86_64-secure-4m.json
36 60-edk2-ovmf-i386.json
37 60-edk2-ovmf-i386-4m.json
38 60-edk2-ovmf-x86_64.json
39 60-edk2-ovmf-x86_64-4m.json
40 60-edk2-ovmf-microvm.json
41 60-edk2-ovmf-microvm-4m.json
44 70-edk2-ovmf-i386-csm.json
45 70-edk2-ovmf-i386-csm-4m.json
46 70-edk2-ovmf-x86_64-csm.json
47 70-edk2-ovmf-x86_64-csm-4m.json
48 80-edk2-ovmf-ia32-on-x86_64-secure.json
49 80-edk2-ovmf-ia32-on-x86_64-secure-4m.json
50 81-edk2-ovmf-ia32-on-x86_64.json
51 81-edk2-ovmf-ia32-on-x86_64-4m.json
52 82-edk2-ovmf-ia32-on-x86_64-csm.json
53 82-edk2-ovmf-ia32-on-x86_64-csm-4m.json
54 $pkgbase-202202-brotli.patch
58 '2ef983f166b5e1bf456ca37938e7e39d58d4cd85e9fc4b5174a05f5c37cc5ad89c3a9af97a6919bcaab128a8a92e4bdc8a045e5d9156d90768da8f73ac67c5b9'
60 'b8e2df955e8796ac1f022eb4ebad29532cb7e3aa6a4b6aee91dbd2c7d637eee84d9a144d3e878895bb5e62800875c2c01c8f737a1261020c54feacf9f676b5f5'
61 '9182615c6f89e4f3c19f1b0f4434aa0a3293f982cf3ed783a2c140c2555d824b417c7c3c7a00ad10616188507f5068226c720b20ffd41d44449605ba0844bad2'
62 '53604279dea69000cb036062d9617f1c7dc5ce3d83fbcb066b9087e4f412c2ea24ae3a37436ab17d5bf9dd6b2da380933c48400163d4b9fde65ea42d37956d5e'
63 'e2e5f3eabb3ced681385ed9d57a3aa83e2155415ea6fd2c16eb15c5a1e685f92e90f1c6f270c1c8da23dde3a0e4a085399f65038b799430c713d1628eb44ac07'
64 'c1f83b3c5f5c43803d4bb1084f6ebdd1987364cab59945a8226a8cf1229daba79c83f638c0a1395ea56acffbd4349b94459659705743a397ff03369b7794a1c6'
65 '25df19b698081c7a21e4c5f37321150ab2f144f4888d887513c3ed926a844909cee390d3e5d80b02c084510074c874b21db3b3d119330342cf8877197ef0a425'
66 'c886b3d6e5f23833c2dc9f8c9f3b21523c680dd2c6bfebbb488f54619d31e53d4019b05b4e1a3dc91abd6e0cab4540d750a2db1b9b4dcf8257e4ba9a2b9b487a'
67 '99f5dcdbc54824976f51c45b939e8bcb4971a70dc2d50b24233d3125ce6cf687f92b8d3896d72280470a2c001637920da8d6e33d576c489beb7f0e898bfb22ab'
68 '9da9de6717b610a181be8f7b34b379a56a1fa31f945f78198eec52359abd178bdf77fda4426157992e64329f53a204af042d5145cb5d3b4b1203915a48815449'
69 'a86e294e5904f52441b86da220f37cc693d7066f7fcb75dafc472a3a72516e865c213be6d0ce245ec5dd680ca9272429d39dca4db4f3e6434b12c479227bc4b0'
70 'b17d3ff5c9230c394ca4ee8229842c801b0cab3d88b546f2094dd0b42f2bc535f5bda3f9faee4b5418482185887648f906daaf0b7307c4c19747f5f0ab504f9a'
71 '126822ef6198e87fb38014a5ba21969c9a163b41df3cdef6825317971ecc8df4a63099113e687634b88648acc93f24917d729e1c44295d2df7012288740307d3'
72 'bbf663d539a985504d5fbc95552a2a60ac860a6bce4a62ecc551292d838b41cba3b5203f580a76a05e9f862ef98e7a3e5da39505c1f39d8ef48c08778fac584a'
73 'b5829aaf5ebae0073de26695eddbda61d117fbfb5e3c9f169fade31127ceb9bbc332af760bf6033d90a277d44c095fc30fe0d69defd81fb1aaf82cba0cf6fb90'
74 '2e03935b57fabbbac4493ba6d54ac5b68abfd75775a56c95f5ba8c4627ba38260a3691a335e597c65096c50ce5038389efbb41ef5822a1ff49a8f312d8e37f75'
75 '6e91029d451c9d43c1488ce0e252e6abc18fb1da48b6938d6ae3644fce58c97da6fff6addc60740b1b9ed5e6b86e9d7e94ee0dd55ea73833a82401b4c6f8c936'
76 '69ec9e9288aad64b585bbffa8566a96a43791c4f899b9e9ba4858645ffe667423cd875ec8d6bed742cc1b1a9e96c8dd81609ff0f48da86b415ecf8cf8089cac2'
77 'cebf9c2cfe8ea7007c68112b4e64d61a98a1637d4b51bceefa22a205e57bb947c757cea8dcc2d01961d8b72b4f289f692d4034d3c38f062e06941b2cc4586377'
78 '95661c2182112a76652507de84b7d0f9bb0d21f6b3b62134952bd7aada8df5cfc727658d11b71a7780a22049d9cafc4361d9a1d515b68d1463e7082465fd4f7e'
79 '8ed6d1d749c3471421a02c41e0e8c3e1ceb62ca6bc09cf2bc85055e2b2661bc149a77b83f480af1aec2f9a948971c6b5aebc92fbc112508fc6293cc6edc7a8a7'
80 'c9dbe7b2b6b8c18b7b8fdfef5bc329d9142c442f2f3dbae3ca4919255dcaf2ab576cd305648228d5dd48040ca3b14f44ee33b05cb6ca13b49e2836947b78ea53'
81 '692e5bdefb61ae7b8d6e2063f163e2b68136b2522d606806766186f10c5fae1f7583fd83cda52c235d0d8eb0651e5a711f505021a8d8d949d8dccfce7f0c82ac'
82 'c699ad500f24569643a4581f4bb5be0e4a90d160f0b3ae7728cf8e27b39665983b80439ca7b853b1bd9a174c8c123cbaf7ed3cd4a17d6460f4fec670c62a1183'
83 'd074c794796d17d77eed7c34201d93d7ef3f1322fe1ea4a2ddd7137fae884d49f94f465ee39cfd8346b026142668a41f5a8671e521409505dd6d002f71c0eebc')
86 'ecd19eaf84dbc80448b51651abe52a89cc0052f024537959c4ebe61528988f235d661244fce6967159a876dd038c817bad19df742e828ca1cbae97ce6a4124bb'
88 '8b9939d5224396ef33b43e019250ba4bc8949903583615e8dc02c85340fc0a1e2d1632161e00b0ee7355d77f05529ac772f482e05d2089afd71a0bf71e803904'
89 '98742b83c2d605772a1bfa64ee434430413516db13d80235f0bc0be3a0e930aa17d737a6d2c95ce3d60f33de9f93679e09f421632d9e3fc9575d662fcf198f4b'
90 'ee28940a8d13a7badf94bcceebd4371c79cd0194ca9f984f39cd75ee64f1ba53059d81f5826c6b5a564d50dce7b9fb5fe8d63ee8d38d38462bc070249124a16b'
91 '8dfd44f35d35d699bb12eef771b08b978cf38ba64494b0eb8c153c72493d47c2d71445869c8d9115c29b28cd206f31be27b43024bd8796a50c8c41a67f87a859'
92 'b9a488c2a6295f3d8eab80150dbfa7acea94720b08928d4e6a4613189fe24922f6c40e1ae8c9856ebb1bc31586ecfb1e02e099a11f7abde575d1f9aa78cc732d'
93 '0a30e819e63b09207c664beca8845f73fb43482d19e831c7f915755594eeafcfc8dccb842f819fb7d20215d87452da31943488e201b9690b733db8169870afcc'
94 'd5d3dc38bf8a09473075a2dd8ab4adcd3af80be30c0ae49fbf55f478b8e0d9a1fde90abceda7099ed3136ee9cadee406bef949a17a070be1b92250adb14c1a7c'
95 'aa1144f31bd391e09d2bf0f55d6cb7a50fab38eca5967989463d58f2931267f7499414709c9692335376f8834b513d69249d995fdc9e90429eadd287348d57e8'
96 '56562116024236f6bb5590fff241d47568a9c1755faa25a62011e8fa3f14b7d74014651b421f5a0c6fb269fb6c05f23b97a5b1ed13929e8141e1c3839f784a5b'
97 'f55e220c6d6a8733bd9233115453e9aca10af91e4cd93be438b4951049198228bdd1b6765b2eae2a781cf3e90beab9b14540c9165ab76af38b9db35b09dde947'
98 '01dbc4cad102535504eace2d9da225a481b62785d37365f1dea2d1210990ca6177485aa0134a074c09d253b539f12ae810706a77a46779ddb7dd4f1b9b934011'
99 'f84ff505702e4b2a38b6fd23fbb732c25d3102a04bb6918b0cc3b3d7528a92626324199cea4ed91955aade98f308f1d1037255f26cc9ee21ace75fc6376e7df6'
100 '04a7eb373d6ea1415d7cd6e8dea0d16b75cbb1fb88572a30b8ce9960dd0404adc7f25fce2ccfb103eb09405411dc4d4e0084236e4c814916d81e957dc6aedfd4'
101 'b4fcc2351b2d77b85cdce35180353aef06900af1554479853bf915d27a756d4bbed50a50e85b72e2e7f4868e6dec3b9c5b27f743d7c112e24e4e0c50cd103a33'
102 '1783b83c6e39c99feb59043c3cff48b24bef55d43949cd9a3097dfbee73a6cf511c180d610a52de876ccea9833fec46d7a88ebce8114e54620b9988232fb9bcc'
103 '1d76eda20067c1bb9928b0304244ab5770a9c4e1f401a74d51da31a47f3a5d6e1e64b5394768cdae6a5bc396b68b6a32eb1a407e1c6377461dd2d5f2f5a2538d'
104 '1debba4546e7cc7d758302a1b5aa3d0a874f39b046beac60e36ecf8aaf8a7690c97508f81fd40eaea807bdd8f4d6c8284e72d6bd61b0791db144a6adcc13ccbf'
105 'c54eb05090280af70ceb44b601752ec38ca80d2af232385cf5ddd6f95ea0504d00a2dd2c82828aa07c41fb456fbb6f174b8bf89b851061206328ae66e589dd2a'
106 'b53bbe532f9a7583bfbcc9436f2172f2dcaa75177c1480753a2a60d97a2fbd5bfb86b97b3f7c27d82e88eb2035c6607abb7e35d39a42e6a2d40c0b54d7c430ef'
107 'dc9a98b8b6d6d8cc2f3aa2b314ba521a2fa8110abf199ca2a6c612ba53df3adad89e5ae0e4cfbe8f5ebf2cefd3cda1716d19f90304a138630f0b8d6e36cd4d10'
108 '0c1e145109de9a25339633b563e47f6c09ea314f636023d09a58559a499dd0bd283a45e050fc99fe34c4d712bd00a035064fa8406734d57029c67b9adb4b11ce'
109 '0ad956e3e662909abafd0b9a2b7ef12e35a8832183cb41e17dcafaa4f5db1e47ef20b3040268644daebb24f66c18b99de07f41e7d62089691c07de688a08f05a'
110 'a44b5ffc35d78925ac7362ec2cf75475d02e05ed0b9e8771c909d090187aaff7436e8d856d58b8a56827990006b813c63318b60a8a7780844c829a2b13a502cf'
111 '644c071dc4fbbccaa64b0b1babcad60395ffce1a7a317a6f5380eff44cbb886be5f29156a8e967ab02b508a33954fcf5602606b43362cc3bb1936a8cfc3a3c07')
113 8657ABB260F056B1E5190839D9C4D26D0E604491 # Matt Caswell <matt@openssl.org>
114 7953AC1FBC3DC8B3B292393ED5E9E43F7DF9EE8C # Richard Levitte <richard@levitte.org>
115 A21FAB74B0088AA361152586B8EF1A6BA9DA2D5C # Tomáš Mráz <tm@t8m.info>
117 _arch_list=(ARM AARCH64 IA32 X64)
123 git describe --tags --abbrev=7 | sed 's/^edk2-stable//;s/\([^-]*-g\)/r\1/;s/-/./g'
127 # patch to be able to use brotli 1.0.9
128 patch -Np1 -d $pkgbase -i ../$pkgbase-202202-brotli.patch
132 # revert commit which breaks microvm blobs: https://github.com/tianocore/edk2/commit/173a7a7daaad560cd69e1000faca1d2b91774c46
133 git revert -n 173a7a7daaad560cd69e1000faca1d2b91774c46
136 git submodule deinit BaseTools/Source/C/BrotliCompress/brotli
137 git submodule deinit CryptoPkg/Library/OpensslLib/openssl
138 git submodule deinit MdeModulePkg/Library/BrotliCustomDecompressLib/brotli
139 git submodule deinit MdeModulePkg/Universal/RegularExpressionDxe/oniguruma
140 git submodule deinit RedfishPkg/Library/JsonLib/jansson
141 git submodule deinit UnitTestFrameworkPkg/Library/CmockaLib/cmocka
142 git submodule deinit UnitTestFrameworkPkg/Library/GoogleTestLib/googletest
143 git config submodule.SoftFloat "$srcdir/$pkgbase-softfloat"
144 git -c protocol.file.allow=always submodule update
146 # symlinking openssl into place
147 rm -rfv CryptoPkg/Library/OpensslLib/openssl
148 ln -sfv "$srcdir/openssl-$_openssl_ver" CryptoPkg/Library/OpensslLib/openssl
150 # symlinking brotli into place
151 rm -rfv BaseTools/Source/C/BrotliCompress/brotli MdeModulePkg/Library/BrotliCustomDecompressLib/brotli
152 ln -sfv "$srcdir/brotli-$_brotli_ver" BaseTools/Source/C/BrotliCompress/brotli
153 ln -sfv "$srcdir/brotli-$_brotli_ver" MdeModulePkg/Library/BrotliCustomDecompressLib/brotli
155 # -Werror, not even once
156 sed -e 's/ -Werror//g' -i BaseTools/Conf/*.template BaseTools/Source/C/Makefiles/*.makefile
158 # copy seabios's CSM binary into place, so that it can be included in the binaries:
159 cp -v /usr/share/qemu/bios-csm.bin OvmfPkg/Csm/Csm16/Csm16.bin
162 # TODO: check TPM_ENABLE/TPM2_ENABLE
165 local _build_options=()
166 # shared targets for all
172 # shared targets for all EFI binaries
174 -D NETWORK_IP6_ENABLE
179 # shared targets x86_64 and i686
185 # 4MB FD size variant
188 -D FD_SIZE_IN_KB=4096
194 export GCC5_IA32_PREFIX="x86_64-linux-gnu-"
195 export GCC5_X64_PREFIX="x86_64-linux-gnu-"
196 export GCC5_AARCH64_PREFIX="aarch64-linux-gnu-"
197 export GCC5_ARM_PREFIX="arm-none-eabi-"
198 echo "Building base tools (AARCH64)"
199 ARCH=AARCH64 make -C BaseTools
200 echo "Building base tools (ARM)"
201 ARCH=ARM make -C BaseTools
202 echo "Building base tools"
206 for _arch in ${_arch_list[@]}; do
208 echo "Building shell ($_arch)."
209 BaseTools/BinWrappers/PosixLike/build -p ShellPkg/ShellPkg.dsc -a "$_arch" "${_common_args[@]}"
213 echo "Building ovmf ($_arch) with secure boot support"
214 OvmfPkg/build.sh -p OvmfPkg/OvmfPkgIa32.dsc \
216 "${_common_args[@]}" \
219 -D EXCLUDE_SHELL_FROM_FD \
220 -D LOAD_X64_ON_IA32_ENABLE \
221 -D SECURE_BOOT_ENABLE \
223 mv -v Build/Ovmf{Ia32,IA32-secure}
224 echo "Building ovmf ($_arch) with secure boot support (4MB FD)"
225 OvmfPkg/build.sh -p OvmfPkg/OvmfPkgIa32.dsc \
227 "${_common_args[@]}" \
230 -D EXCLUDE_SHELL_FROM_FD \
231 -D LOAD_X64_ON_IA32_ENABLE \
232 -D SECURE_BOOT_ENABLE \
234 mv -v Build/Ovmf{Ia32,IA32-secure-4mb}
235 echo "Building ovmf ($_arch) with CSM support"
236 OvmfPkg/build.sh -p OvmfPkg/OvmfPkgIa32.dsc \
238 "${_common_args[@]}" \
242 -D LOAD_X64_ON_IA32_ENABLE
243 mv -v Build/Ovmf{Ia32,IA32-csm}
244 echo "Building ovmf ($_arch) with CSM support (4MB FD)"
245 OvmfPkg/build.sh -p OvmfPkg/OvmfPkgIa32.dsc \
247 "${_common_args[@]}" \
251 -D LOAD_X64_ON_IA32_ENABLE
252 mv -v Build/Ovmf{Ia32,IA32-csm-4mb}
253 echo "Building ovmf ($_arch) default"
254 OvmfPkg/build.sh -p OvmfPkg/OvmfPkgIa32.dsc \
256 "${_common_args[@]}" \
259 -D LOAD_X64_ON_IA32_ENABLE
260 mv -v Build/Ovmf{Ia32,IA32}
261 echo "Building ovmf ($_arch) default (4MB FD)"
262 OvmfPkg/build.sh -p OvmfPkg/OvmfPkgIa32.dsc \
264 "${_common_args[@]}" \
267 -D LOAD_X64_ON_IA32_ENABLE
268 mv -v Build/Ovmf{Ia32,IA32-4mb}
271 echo "Building ovmf ($_arch) with microvm support (4MB FD)"
272 OvmfPkg/build.sh -p OvmfPkg/Microvm/Microvm$_arch.dsc \
274 "${_common_args[@]}" \
277 mv -v Build/MicrovmX64{,-4mb}
278 echo "Building ovmf ($_arch) with microvm support"
279 OvmfPkg/build.sh -p OvmfPkg/Microvm/Microvm$_arch.dsc \
281 "${_common_args[@]}" \
284 echo "Building ovmf ($_arch) with secure boot support"
285 OvmfPkg/build.sh -p OvmfPkg/OvmfPkgIa32X64.dsc \
286 -a IA32 -a "$_arch" \
287 "${_common_args[@]}" \
290 -D SECURE_BOOT_ENABLE \
292 -D EXCLUDE_SHELL_FROM_FD
293 mv -v Build/Ovmf3264{,-secure}
294 echo "Building ovmf ($_arch) with secure boot support (4MB FD)"
295 OvmfPkg/build.sh -p OvmfPkg/OvmfPkgIa32X64.dsc \
296 -a IA32 -a "$_arch" \
297 "${_common_args[@]}" \
300 -D SECURE_BOOT_ENABLE \
302 -D EXCLUDE_SHELL_FROM_FD
303 mv -v Build/Ovmf3264{,-secure-4mb}
304 echo "Building ovmf ($_arch) with CSM support"
305 OvmfPkg/build.sh -p OvmfPkg/OvmfPkg$_arch.dsc \
307 "${_common_args[@]}" \
311 mv -v Build/OvmfX64{,-csm}
312 echo "Building ovmf ($_arch) with CSM support (4MB FD)"
313 OvmfPkg/build.sh -p OvmfPkg/OvmfPkg$_arch.dsc \
315 "${_common_args[@]}" \
319 mv -v Build/OvmfX64{,-csm-4mb}
320 echo "Building ovmf (${_arch}) without secure boot (4MB FD)"
321 OvmfPkg/build.sh -p OvmfPkg/OvmfPkg$_arch.dsc \
323 "${_common_args[@]}" \
326 mv -v Build/OvmfX64{,-4mb}
327 echo "Building ovmf (${_arch}) without secure boot"
328 OvmfPkg/build.sh -p OvmfPkg/OvmfPkg$_arch.dsc \
330 "${_common_args[@]}" \
335 echo "Building ArmVirtPkg ($_arch) with secure boot"
336 local _build_options=(
337 -p ArmVirtPkg/ArmVirtQemu.dsc
341 -D NETWORK_HTTP_BOOT_ENABLE
342 -D NETWORK_TLS_ENABLE
343 -D SECURE_BOOT_ENABLE
345 BaseTools/BinWrappers/PosixLike/build "${_build_options[@]}"
346 dd if=/dev/zero of=Build/ArmVirtQemu-$_arch/${_build_type}_${_build_plugin}/FV/QEMU_CODE.fd bs=1M count=64
347 dd if=Build/ArmVirtQemu-$_arch/${_build_type}_${_build_plugin}/FV/QEMU_EFI.fd of=Build/ArmVirtQemu-$_arch/${_build_type}_${_build_plugin}/FV/QEMU_CODE.fd conv=notrunc
348 dd if=/dev/zero of=Build/ArmVirtQemu-$_arch/${_build_type}_${_build_plugin}/FV/QEMU_VARS.fd bs=1M count=64
351 echo "Building ovmf (${_arch}) with secure boot"
352 local _build_options=(
353 -p ArmVirtPkg/ArmVirtQemu.dsc
357 -D NETWORK_HTTP_BOOT_ENABLE
358 -D NETWORK_TLS_ENABLE
359 -D SECURE_BOOT_ENABLE
363 BaseTools/BinWrappers/PosixLike/build "${_build_options[@]}"
364 dd if=/dev/zero of=Build/ArmVirtQemu-$_arch/${_build_type}_$_build_plugin/FV/QEMU_CODE.fd bs=1M count=64
365 dd if=Build/ArmVirtQemu-$_arch/${_build_type}_$_build_plugin/FV/QEMU_EFI.fd of=Build/ArmVirtQemu-$_arch/${_build_type}_$_build_plugin/FV/QEMU_CODE.fd conv=notrunc
366 dd if=/dev/zero of=Build/ArmVirtQemu-$_arch/${_build_type}_$_build_plugin/FV/QEMU_VARS.fd bs=1M count=64
372 package_edk2-aarch64() {
375 pkgdesc="Firmware for Virtual Machines (aarch64)"
376 url="https://github.com/tianocore/tianocore.github.io/wiki/ArmVirtPkg"
377 conflicts=('edk2-armvirt<202211')
378 provides=(edk2-armvirt)
379 replaces=('edk2-armvirt<202211')
382 install -vDm 644 Build/ArmVirtQemu-$_arch/${_build_type}_${_build_plugin}/FV/*.fd -t "$pkgdir/usr/share/$pkgbase/${_arch,,}/"
383 # add libvirt compatibility (which hardcodes the following paths)
384 install -vdm 755 "$pkgdir/usr/share/AAVMF"
385 ln -svf /usr/share/$pkgbase/${_arch,,}/QEMU_CODE.fd "$pkgdir/usr/share/AAVMF/AAVMF_CODE.fd"
386 ln -svf /usr/share/$pkgbase/${_arch,,}/QEMU_VARS.fd "$pkgdir/usr/share/AAVMF/AAVMF_VARS.fd"
387 # install qemu descriptors in accordance with qemu:
388 # https://git.qemu.org/?p=qemu.git;a=tree;f=pc-bios/descriptors
389 install -vDm 644 ../*$pkgname.json -t "$pkgdir/usr/share/qemu/firmware/"
391 install -vDm 644 License.txt -t "$pkgdir/usr/share/licenses/$pkgname/"
393 # add symlink for previous aarch64 location
394 ln -svf /usr/share/$pkgbase "$pkgdir/usr/share/$pkgbase-armvirt"
400 pkgdesc="Firmware for Virtual Machines (armv7)"
401 url="https://github.com/tianocore/tianocore.github.io/wiki/ArmVirtPkg"
404 install -vDm 644 Build/ArmVirtQemu-$_arch/${_build_type}_$_build_plugin/FV/*.fd -t "$pkgdir/usr/share/$pkgbase/${_arch,,}/"
405 # add libvirt compatibility (which hardcodes the following paths)
406 install -vdm 755 "$pkgdir/usr/share/AAVMF"
407 ln -svf /usr/share/$pkgbase/${_arch,,}/QEMU_CODE.fd "$pkgdir/usr/share/AAVMF/AAVMF32_CODE.fd"
408 ln -svf /usr/share/$pkgbase/${_arch,,}/QEMU_VARS.fd "$pkgdir/usr/share/AAVMF/AAVMF32_VARS.fd"
410 # install qemu descriptors in accordance with qemu:
411 # https://git.qemu.org/?p=qemu.git;a=tree;f=pc-bios/descriptors
412 install -vDm 644 ../*$pkgname.json -t "$pkgdir/usr/share/qemu/firmware/"
414 install -vDm 644 License.txt -t "$pkgdir/usr/share/licenses/$pkgname/"
417 package_edk2-shell() {
419 # minimal UEFI shell, as defined in ShellPkg/Application/Shell/ShellPkg.inf
420 local _min='7C04A583-9E3E-4f1c-AD65-E05268D0B4D1'
421 # full UEFI shell, as defined in ShellPkg/ShellPkg.dsc
422 local _full='EA4BB293-2D7F-4456-A681-1F22F42CD0BC'
424 pkgdesc="EDK2 UEFI Shell"
425 provides=(uefi-shell)
428 for _arch in ${_arch_list[@]}; do
429 install -vDm 644 Build/Shell/${_build_type}_${_build_plugin}/$_arch/Shell_$_min.efi "$pkgdir/usr/share/$pkgname/${_arch,,}/Shell.efi"
430 install -vDm 644 Build/Shell/${_build_type}_${_build_plugin}/$_arch/Shell_$_full.efi "$pkgdir/usr/share/$pkgname/${_arch,,}/Shell_Full.efi"
433 install -vDm 644 License.txt -t "$pkgdir/usr/share/licenses/$pkgname/"
435 install -vDm 644 {ReadMe.rst,Maintainers.txt} -t "$pkgdir/usr/share/doc/$pkgname/"
438 package_edk2-ovmf() {
441 pkgdesc="Firmware for Virtual Machines (x86_64, i686)"
442 url="https://github.com/tianocore/tianocore.github.io/wiki/OVMF"
447 install=$pkgname.install
450 # installing the various firmwares
451 for _arch in IA32 X64; do
452 # installing OVMF.fd for xen: https://bugs.archlinux.org/task/58635
453 install -vDm 644 Build/Ovmf$_arch/${_build_type}_${_build_plugin}/FV/OVMF.fd -t "$pkgdir/usr/share/$pkgbase/${_arch,,}/"
454 install -vDm 644 Build/Ovmf$_arch/${_build_type}_${_build_plugin}/FV/OVMF_CODE.fd -t "$pkgdir/usr/share/$pkgbase/${_arch,,}/"
455 install -vDm 644 Build/Ovmf$_arch/${_build_type}_${_build_plugin}/FV/OVMF_VARS.fd -t "$pkgdir/usr/share/$pkgbase/${_arch,,}/"
456 install -vDm 644 Build/Ovmf$_arch-4mb/${_build_type}_${_build_plugin}/FV/OVMF.fd "$pkgdir/usr/share/$pkgbase/${_arch,,}/OVMF.4m.fd"
457 install -vDm 644 Build/Ovmf$_arch-4mb/${_build_type}_${_build_plugin}/FV/OVMF_CODE.fd "$pkgdir/usr/share/$pkgbase/${_arch,,}/OVMF_CODE.4m.fd"
458 install -vDm 644 Build/Ovmf$_arch-4mb/${_build_type}_${_build_plugin}/FV/OVMF_VARS.fd "$pkgdir/usr/share/$pkgbase/${_arch,,}/OVMF_VARS.4m.fd"
459 install -vDm 644 Build/Ovmf$_arch-csm/${_build_type}_${_build_plugin}/FV/OVMF_CODE.fd "$pkgdir/usr/share/$pkgbase/${_arch,,}/OVMF_CODE.csm.fd"
460 install -vDm 644 Build/Ovmf$_arch-csm-4mb/${_build_type}_${_build_plugin}/FV/OVMF_CODE.fd "$pkgdir/usr/share/$pkgbase/${_arch,,}/OVMF_CODE.csm.4m.fd"
461 if [[ "${_arch}" == 'X64' ]]; then
462 install -vDm 644 Build/Ovmf3264-secure/${_build_type}_${_build_plugin}/FV/OVMF_CODE.fd "$pkgdir/usr/share/$pkgbase/${_arch,,}/OVMF_CODE.secboot.fd"
463 install -vDm 644 Build/Ovmf3264-secure-4mb/${_build_type}_${_build_plugin}/FV/OVMF_CODE.fd "$pkgdir/usr/share/$pkgbase/${_arch,,}/OVMF_CODE.secboot.4m.fd"
464 install -vDm 644 Build/MicrovmX64/${_build_type}_${_build_plugin}/FV/MICROVM.fd -t "$pkgdir/usr/share/$pkgbase/${_arch,,}/"
465 install -vDm 644 Build/MicrovmX64-4mb/${_build_type}_${_build_plugin}/FV/MICROVM.fd "$pkgdir/usr/share/$pkgbase/${_arch,,}/MICROVM.4m.fd"
467 install -vDm 644 Build/Ovmf$_arch-secure/${_build_type}_${_build_plugin}/FV/OVMF_CODE.fd "$pkgdir/usr/share/$pkgbase/${_arch,,}/OVMF_CODE.secboot.fd"
468 install -vDm 644 Build/Ovmf$_arch-secure-4mb/${_build_type}_${_build_plugin}/FV/OVMF_CODE.fd "$pkgdir/usr/share/$pkgbase/${_arch,,}/OVMF_CODE.secboot.4m.fd"
471 # installing qemu descriptors in accordance with qemu:
472 # https://git.qemu.org/?p=qemu.git;a=tree;f=pc-bios/descriptors
473 # https://bugs.archlinux.org/task/64206
474 install -vDm 644 ../*$pkgname*.json -t "$pkgdir/usr/share/qemu/firmware/"
475 # add symlink for previous ovmf locations
476 # https://bugs.archlinux.org/task/66528
477 ln -svf /usr/share/$pkgbase "$pkgdir/usr/share/ovmf"
478 ln -svf /usr/share/$pkgbase "$pkgdir/usr/share/$pkgbase-ovmf"
479 # adding a symlink for applications with questionable heuristics (such as lxd)
480 ln -svf /usr/share/$pkgbase "$pkgdir/usr/share/OVMF"
482 install -vDm 644 License.txt -t "$pkgdir/usr/share/licenses/$pkgname/"
483 install -vDm 644 OvmfPkg/License.txt "$pkgdir/usr/share/licenses/$pkgname/OvmfPkg.License.txt"
485 install -vDm 644 {OvmfPkg/README,ReadMe.rst,Maintainers.txt} -t "$pkgdir/usr/share/doc/$pkgname/"