diff options
author | Łukasz Stelmach <l.stelmach@samsung.com> | 2023-01-31 16:43:29 +0100 |
---|---|---|
committer | Łukasz Stelmach <l.stelmach@samsung.com> | 2023-02-09 11:49:45 +0100 |
commit | f301188771bb0c42f59dee2c2e7f76b424b1b5f2 (patch) | |
tree | c0cafa7db249db5c1ccaa70f67f45c72a143e55a | |
parent | c246117510a10c1b05f82be0ce5309c7d13eafeb (diff) | |
download | linux-starfive-f301188771bb0c42f59dee2c2e7f76b424b1b5f2.tar.gz linux-starfive-f301188771bb0c42f59dee2c2e7f76b424b1b5f2.tar.bz2 linux-starfive-f301188771bb0c42f59dee2c2e7f76b424b1b5f2.zip |
packaging: Add spec file for VisionFive2sandbox/lstelmach/tizen-visionfive2
Change-Id: Ie3e558df63b48ce466bcbbfaa97833e6486b79c1
Signed-off-by: Łukasz Stelmach <l.stelmach@samsung.com>
-rw-r--r-- | .gbs.conf | 4 | ||||
-rw-r--r-- | packaging/linux-visionfive.spec | 295 |
2 files changed, 299 insertions, 0 deletions
diff --git a/.gbs.conf b/.gbs.conf new file mode 100644 index 000000000000..f744dbaac48e --- /dev/null +++ b/.gbs.conf @@ -0,0 +1,4 @@ +[general] +upstream_branch = upstream +upstream_tag = v${upstreamversion} +squash_patches_until = HEAD~10 diff --git a/packaging/linux-visionfive.spec b/packaging/linux-visionfive.spec new file mode 100644 index 000000000000..bc9a0f736b3d --- /dev/null +++ b/packaging/linux-visionfive.spec @@ -0,0 +1,295 @@ +# Ignore double dash in version for rpmbuild +%define _wrong_version_format_terminate_build 0 + +%define tizen_kernel_config_dir %{_datadir}/tizen-kernel-configs +%define config_name starfive_visionfive2_defconfig +%define buildarch riscv +%define target_board visionfive2 +%define variant %{buildarch}-%{target_board} + +# 0 until linux-rt available for 6.1 +%define build_rt 0 + +Name: visionfive-linux-kernel +Summary: The Linux Kernel for VisionFive2 +Version: 5.15 +Release: 0 +License: GPL-2.0 +ExclusiveArch: riscv64 +Group: System/Kernel +Vendor: The Linux Community +URL: https://www.kernel.org +Source0: linux-kernel-%{version}.tar.xz +BuildRoot: %{_tmppath}/%{name}-%{PACKAGE_VERSION}-root + +%define fullVersion %{version}-%{variant} + +BuildRequires: bc +BuildRequires: module-init-tools +BuildRequires: bison +BuildRequires: flex +BuildRequires: libopenssl1.1-devel +BuildRequires: libunwind-devel +BuildRequires: libdw-devel +BuildRequires: libelf-devel +BuildRequires: elfutils +BuildRequires: xz-devel +BuildRequires: binutils-devel +BuildRequires: python3 +BuildRequires: rsync +BuildRequires: tizen-kernel-configs + +%description +The Linux Kernel, the operating system core itself + +# kernel +%package -n %{variant}-linux-kernel +License: GPL-2.0 +Summary: Tizen kernel for %{target_board} +Group: System/Kernel +Provides: %{variant}-kernel-uname-r = %{fullVersion} +Provides: linux-kernel = %{version}-%{release} + +%description -n %{variant}-linux-kernel +This package contains the Linux kernel for Tizen (arch %{buildarch}, target board %{target_board}) + +%if %{build_rt} +%package -n %{variant}-rt-linux-kernel +License: GPL-2.0 +Summary: Tizen kernel for %{target_board} +Group: System/Kernel +Provides: %{variant}-kernel-uname-r = %{fullVersion}-rt +Provides: linux-kernel = %{version}-%{release}-rt + +%description -n %{variant}-rt-linux-kernel +This package contains the Linux kernel for Tizen (arch %{buildarch}, target board %{target_board}) +%endif + +# modules + +%package -n %{variant}-linux-kernel-modules +Summary: Kernel modules for %{target_board} +Group: System/Kernel +Provides: %{variant}-kernel-modules = %{fullVersion} +Provides: %{variant}-kernel-modules-uname-r = %{fullVersion} + +%description -n %{variant}-linux-kernel-modules +Kernel-modules includes the loadable kernel modules(.ko files) for %{target_board} + +%if %{build_rt} +%package -n %{variant}-rt-linux-kernel-modules +Summary: Kernel modules for %{target_board} +Group: System/Kernel +Provides: %{variant}-kernel-modules = %{fullVersion}-rt +Provides: %{variant}-kernel-modules-uname-r = %{fullVersion}-rt + +%description -n %{variant}-rt-linux-kernel-modules +Kernel-modules includes the loadable kernel modules(.ko files) for %{target_board} +with the PREEMPT_RT patch +%endif + +# devel + +%package -n %{variant}-linux-kernel-devel +License: GPL-2.0 +Summary: Linux support kernel map and etc for other packages +Group: System/Kernel +Provides: %{variant}-kernel-devel = %{fullVersion} +Provides: %{variant}-kernel-devel-uname-r = %{fullVersion} + +%description -n %{variant}-linux-kernel-devel +This package provides kernel map and etc information. + +%if %{build_rt} +%package -n %{variant}-rt-linux-kernel-devel +License: GPL-2.0 +Summary: Linux support kernel map and etc for other packages +Group: System/Kernel +Provides: %{variant}-kernel-devel = %{fullVersion}-rt +Provides: %{variant}-kernel-devel-uname-r = %{fullVersion}-rt + +%description -n %{variant}-rt-linux-kernel-devel +This package provides kernel map and etc information. +%endif + +#headers +%package -n %{variant}-linux-kernel-headers +License: GPL-2.0 +Summary: Linux support headers for userspace development +Group: System/Kernel +Provides: kernel-headers-tizen-dev + +%description -n %{variant}-linux-kernel-headers +This package provides userspaces headers from the Linux kernel. These +headers are used by the installed headers for GNU glibc and other system + libraries. + +%package -n linux-kernel-perf +Summary: The perf performance counter tool +Group: System/Kernel +Provides: perf = %{version} + +%description -n linux-kernel-perf +This package provides the "perf" tool that can be used to monitor performance +counter events as well as various kernel internal events. + +%prep +%setup -q + +%build +%{?asan:/usr/bin/gcc-unforce-options} +%{?ubsan:/usr/bin/gcc-unforce-options} + +# Here be %{variant} %{variant}-rt +for target in %{variant}; do + echo "-${target}" > localversion-tizen + + # extract uapi headers + make O=build/${target} headers_install %{?_smp_mflags} + + # Set config file + case $target in + %{variant}) + ./scripts/kconfig/merge_config.sh -O build/${target} \ + %{tizen_kernel_config_dir}/references/%{buildarch}/%{config_name} \ + %{tizen_kernel_config_dir}/tizen/tizen_defconfig + + # Build perf + make O=build/${target} -s -C tools/lib/traceevent %{?_smp_mflags} + make O=build/${target} -s -C tools/perf EXTRA_CFLAGS="-fPIE -rdynamic" %{?_smp_mflags} + ;; + %{variant}-rt) + cat _localversion-rt > localversion-rt + ./scripts/kconfig/merge_config.sh -O build/${target} \ + %{tizen_kernel_config_dir}/references/%{buildarch}/%{config_name} \ + %{tizen_kernel_config_dir}/tizen/tizen_defconfig \ + %{tizen_kernel_config_dir}/tizen/tizen_rt.config + ;; + esac + + # Build Image/Image.gz + make O=build/${target} %{?_smp_mflags} + + # Build dtbs + make O=build/${target} dtbs %{?_smp_mflags} + + # Build modules + make O=build/${target} modules %{?_smp_mflags} +done + +%install +QA_SKIP_BUILD_ROOT="DO_NOT_WANT"; export QA_SKIP_BUILD_ROOT + +# Destination directories +mkdir -p %{buildroot}/boot +mkdir -p %{buildroot}/lib/modules + +# Install boot binary files +# Here be SPL & OpenSBI + +# Install kernel DTB +install -m 644 build/%{variant}/arch/%{buildarch}/boot/dts/starfive/jh71*.dtb %{buildroot}/boot/ +mkdir -p %{buildroot}/boot/overlays + +# Install kernel headers +make O=build/%{variant} headers_install %{?_smp_mflags} INSTALL_HDR_PATH=%{buildroot}/usr + +# Here be %{variant} %{variant}-rt +for target in %{variant}; do + # Install kernel binary + case $target in + %{variant}) + install -m 644 build/${target}/arch/%{buildarch}/boot/Image %{buildroot}/boot/Image + + # Install perf + make O=build/${target} -s -C tools/perf EXTRA_CFLAGS="-fPIE -rdynamic" DESTDIR=%{buildroot}/usr install + rm -rf %{buildroot}/usr/etc + rm -rf %{buildroot}/usr/lib/debug + rm -rf %{buildroot}/usr/lib/perf + rm -rf %{buildroot}/usr/share + + ;; + %{variant}-rt) + install -m 644 build/${target}/arch/%{buildarch}/boot/Image %{buildroot}/boot/Image_rt + ;; + esac + + # Install modules + make O=build/${target} INSTALL_MOD_STRIP=1 INSTALL_MOD_PATH=%{buildroot} modules_install + + # Copy files for devel package + mkdir -p %{buildroot}/boot/kernel/devel/kernel-devel-${target} + rsync -r \ + --include "/scripts/**.c" \ + --exclude "/debug*.list" \ + --exclude "/documentation.list" \ + --exclude "/*.manifest" \ + --exclude "/packaging/" \ + --exclude "/.gbs.conf" \ + --exclude "/.git**" \ + --exclude ".gitignore" \ + --exclude "*\.c" \ + --exclude ".tmp_vmlinux*" \ + --exclude ".*dtb*tmp" \ + --exclude ".*dtb" \ + --exclude "*.*tmp" \ + --exclude "vmlinux" \ + --exclude "Image" \ + --exclude "zImage" \ + --exclude "Image.gz" \ + --exclude "*.cmd" \ + --exclude "*.ko" \ + --exclude "*.o" \ + --exclude "*.S" \ + --exclude "*.HEX" \ + --exclude "/build/" \ + ./ build/${target}/ %{buildroot}/boot/kernel/devel/kernel-devel-${target} +done + +%clean +rm -rf %{buildroot} + +%if %{build_rt} +%post -n %{variant}-rt-linux-kernel +mv /boot/Image_rt /boot/Image + +%preun -n %{variant}-rt-linux-kernel +mv /boot/Image /boot/Image_rt +%endif + +%files -n %{variant}-linux-kernel-modules +/lib/modules/*%{variant}/ + +%if %{build_rt} +%files -n %{variant}-rt-linux-kernel-modules +/lib/modules/*%{variant}-rt/ +%endif + +%files -n %{variant}-linux-kernel-devel +/boot/kernel/devel/*%{variant}/ + +%if %{build_rt} +%files -n %{variant}-rt-linux-kernel-devel +/boot/kernel/devel/*%{variant}-rt/ +%endif + +%files -n %{variant}-linux-kernel +%license COPYING +/boot/Image +/boot/jh71*.dtb + +%if %{build_rt} +%files -n %{variant}-rt-linux-kernel +%license COPYING +/boot/Image_rt +/boot/jh71*.dtb +%endif + +%files -n %{variant}-linux-kernel-headers +/usr/include/* + +%files -n linux-kernel-perf +%license COPYING +/usr/bin/* +/usr/libexec/* +/usr/lib/traceevent/* |