# Binaries not used in standard manner so debuginfo is useless %global debug_package %{nil} Name: optee_os Version: 4.4.0 Release: 2%{?dist} Summary: Trusted side of the TEE # The TEE core of optee_os is provided under the BSD 2-Clause license. But # there are also other software such as libraries included in optee_os. # This "other" software will have different licenses that are compatible # with BSD 2-Clause (i.e., non-contaminating licenses unlike GPL-v2 for example). License: BSD-2-Clause AND Apache-2.0 AND (BSD-2-Clause AND BSD-3-Clause) AND (BSD-2-Clause AND MIT) AND (BSD-2-Clause AND MIT-CMU) AND BSD-3-Clause AND BSD-Source-Code AND BSL-1.0 AND (GPL-2.0 OR BSD-2-Clause) AND (GPL-2.0-or-later OR BSD-2-Clause) AND (GPL-2.0 or BSD-3-Clause) AND (GPL-2.0+ or BSD-3-Clause) AND (GPL-2.0 OR MIT) AND (GPL-2.0+ OR MIT) AND ISC AND MIT AND Unlicense AND (Unlicense AND BSD-2-Clause) AND Zlib URL: https://www.trustedfirmware.org Source: https://github.com/OP-TEE/optee_os/archive/%{version}/%{name}-%{version}.tar.gz BuildRequires: gcc BuildRequires: gcc-arm-linux-gnu BuildRequires: make BuildRequires: python3-cryptography BuildRequires: python3-pyelftools ExclusiveArch: aarch64 %description OP-TEE is a Trusted Execution Environment (TEE) designed as companion to a non-secure Linux kernel running on Arm; Cortex-A cores using the TrustZone technology. OP-TEE implements TEE Internal Core API v1.1.x which is the API exposed to Trusted Applications. Note: the contents of this package are generally just consumed by bootloaders such as u-boot. As such the binaries aren't of general interest to users. %package -n optee-os-firmware-armv8 Summary: OP-TEE Firmware for ARMv8-A BuildArch: noarch %description -n optee-os-firmware-armv8 OP-TEE firmware for various ARMv8-A SoCs. Note: the contents of this package are generally just consumed by bootloaders such as u-boot. As such the binaries aren't of general interest to users. %prep %autosetup -n %{name}-%{version} -p1 %build %undefine _auto_set_build_flags # For now only secure firmwares for TI platforms are built make HOSTCC="gcc $RPM_OPT_FLAGS" CROSS_COMPILE64="" CROSS_COMPILE=arm-linux-gnu- PLATFORM=k3-j721e CFG_ARM64_core=y O=out/k3-j721e make HOSTCC="gcc $RPM_OPT_FLAGS" CROSS_COMPILE64="" CROSS_COMPILE=arm-linux-gnu- PLATFORM=k3-j784s4 CFG_ARM64_core=y CFG_CONSOLE_UART=0x8 O=out/k3-j784s4 make HOSTCC="gcc $RPM_OPT_FLAGS" CROSS_COMPILE64="" CROSS_COMPILE=arm-linux-gnu- PLATFORM=k3-am62x CFG_ARM64_core=y CFG_WITH_SOFTWARE_PRNG=y O=out/k3-am62x make HOSTCC="gcc $RPM_OPT_FLAGS" CROSS_COMPILE64="" CROSS_COMPILE=arm-linux-gnu- PLATFORM=rockchip-rk3399 CFG_ARM64_core=y O=out/rockchip-rk3399 make HOSTCC="gcc $RPM_OPT_FLAGS" CROSS_COMPILE64="" CROSS_COMPILE=arm-linux-gnu- PLATFORM=sunxi-sun50i_a64 CFG_ARM64_core=y O=out/sunxi-sun50i_a64 %install mkdir -p %{buildroot}%{_datadir}/%{name} %ifarch aarch64 # At the moment we just support adding tee-raw.bin mkdir -p %{buildroot}%{_datadir}/%{name}/k3-j721e/ install -p -m 0644 out/k3-j721e/core/tee-raw.bin /%{buildroot}%{_datadir}/%{name}/k3-j721e/ install -p -m 0644 out/k3-j721e/core/tee-pager_v2.bin /%{buildroot}%{_datadir}/%{name}/k3-j721e/ mkdir -p %{buildroot}%{_datadir}/%{name}/k3-j784s4/ install -p -m 0644 out/k3-j784s4/core/tee-raw.bin /%{buildroot}%{_datadir}/%{name}/k3-j784s4/ install -p -m 0644 out/k3-j784s4/core/tee-pager_v2.bin /%{buildroot}%{_datadir}/%{name}/k3-j784s4/ mkdir -p %{buildroot}%{_datadir}/%{name}/k3-am62x/ install -p -m 0644 out/k3-am62x/core/tee-raw.bin /%{buildroot}%{_datadir}/%{name}/k3-am62x/ install -p -m 0644 out/k3-am62x/core/tee-pager_v2.bin /%{buildroot}%{_datadir}/%{name}/k3-am62x/ # rk3399 expects the .elf mkdir -p %{buildroot}%{_datadir}/%{name}/rockchip-rk3399 install -p -m 0644 out/rockchip-rk3399/core/tee.elf /%{buildroot}%{_datadir}/%{name}/rockchip-rk3399 install -p -m 0644 out/rockchip-rk3399/core/tee-pager_v2.bin /%{buildroot}%{_datadir}/%{name}/rockchip-rk3399 mkdir -p %{buildroot}%{_datadir}/%{name}/sunxi-sun50i_a64/ install -p -m 0644 out/sunxi-sun50i_a64/core/tee-raw.bin /%{buildroot}%{_datadir}/%{name}/sunxi-sun50i_a64/ install -p -m 0644 out/sunxi-sun50i_a64/core/tee-pager_v2.bin /%{buildroot}%{_datadir}/%{name}/sunxi-sun50i_a64/ %endif %files -n optee-os-firmware-armv8 %license LICENSE %doc README.md %{_datadir}/%{name} %changelog * Wed Oct 23 2024 Zbigniew Jedrzejewski-Szmek - 4.4.0-2 - Only build on aarch64 * Mon Oct 21 2024 Peter Robinson - 4.4.0-1 - Update to 4.4.0 * Fri Oct 11 2024 Peter Robinson - 4.3.0-4 - Ship tee-pager_v2.bin for all targets * Thu Aug 1 2024 Enric Balletbo i Serra - 4.3.0-3 - Make optee-os-firmware-armv8 noarch * Thu Jul 18 2024 Fedora Release Engineering - 4.3.0-2 - Rebuilt for https://fedoraproject.org/wiki/Fedora_41_Mass_Rebuild * Mon Jul 15 2024 Peter Robinson - 4.3.0-1 - Update to 4.3.0 * Fri Apr 12 2024 Peter Robinson - 4.2.0-1 - Update to 4.2.0 * Thu Jan 25 2024 Fedora Release Engineering - 4.1.0-2 - Rebuilt for https://fedoraproject.org/wiki/Fedora_40_Mass_Rebuild * Fri Jan 19 2024 Peter Robinson - 4.1.0-1 - Update up 4.1.0 * Wed Jan 10 2024 Enric Balletbo i Serra - 4.0.0-2 - Build k3-j721e OP-TEE * Thu Nov 02 2023 Peter Robinson - 4.0.0-1 - Update to 4.0.0 - Build rk3399 and sunxi-a64 OP-TEE * Tue Oct 10 2023 Enric Balletbo i Serra - 3.22.0-4 - Add CFG_CONSOLE_UART=0x8 a extra arguments used for building OP-TEE on TI J784S4 boards * Wed Oct 4 2023 Enric Balletbo i Serra - 3.22.0-3 - According to the uboot build documentation use tee-raw.bin instead of tee-pager_v2.bin (is the same binary) * Thu Sep 21 2023 Enric Balletbo i Serra - 3.22.0-2 - Add support for TI AM62x boards * Tue Sep 19 2023 Enric Balletbo i Serra - 3.22.0-1 - Initial package