2023-08-29 17:10:35 +08:00
|
|
|
%define build_version %{version}-%{release}
|
2023-03-29 18:42:15 +08:00
|
|
|
%define kernel_devel_rpm %(echo $(rpm -q kernel-devel | head -n 1))
|
2023-08-29 17:10:35 +08:00
|
|
|
%define kernel_version %(echo $(rpm -q --qf "\%%{VERSION}" %{kernel_devel_rpm}))
|
|
|
|
|
%define kernel_name %(echo $(rpm -q --qf "\%%{VERSION}-\%%{RELEASE}.\%%{ARCH}" %{kernel_devel_rpm}))
|
|
|
|
|
|
|
|
|
|
%define pkg_kmod %{name}-kmod
|
|
|
|
|
%define pkg_build %{name}-build
|
|
|
|
|
%define pkg_build_kmod %{pkg_build}-kmod
|
|
|
|
|
%define pkg_build_ebpf %{pkg_build}-ebpf
|
|
|
|
|
|
|
|
|
|
############################################
|
|
|
|
|
############ Package syscare ###############
|
|
|
|
|
############################################
|
|
|
|
|
Name: syscare
|
2023-11-22 09:58:04 +08:00
|
|
|
Version: 1.2.0
|
2023-12-12 09:57:38 +08:00
|
|
|
Release: 8
|
2023-08-29 17:10:35 +08:00
|
|
|
Summary: System hot-fix service
|
|
|
|
|
License: MulanPSL-2.0 and GPL-2.0-only
|
|
|
|
|
URL: https://gitee.com/openeuler/syscare
|
|
|
|
|
Source0: %{name}-%{version}.tar.gz
|
|
|
|
|
BuildRequires: cmake >= 3.14 make
|
2023-09-20 14:58:01 +08:00
|
|
|
BuildRequires: rust >= 1.51 cargo >= 1.51
|
2023-08-29 17:10:35 +08:00
|
|
|
BuildRequires: gcc gcc-c++
|
|
|
|
|
Requires: coreutils systemd
|
|
|
|
|
Requires: kpatch-runtime
|
|
|
|
|
|
|
|
|
|
############### Description ################
|
2022-11-15 12:55:32 +00:00
|
|
|
%description
|
2023-08-29 17:10:35 +08:00
|
|
|
SysCare is a system-level hot-fix service that provides security patches and system error hot-fixes for the operating system.
|
2022-11-22 11:44:18 +00:00
|
|
|
The host can fix the system problem without rebooting.
|
2022-11-15 12:55:32 +00:00
|
|
|
|
2023-08-29 17:10:35 +08:00
|
|
|
############## BuildPreparare ##############
|
2022-11-15 12:55:32 +00:00
|
|
|
%prep
|
|
|
|
|
%autosetup -p1
|
|
|
|
|
|
2023-08-29 17:10:35 +08:00
|
|
|
################## Build ###################
|
2022-11-15 12:55:32 +00:00
|
|
|
%build
|
2023-06-02 17:11:44 +08:00
|
|
|
mkdir -p build
|
|
|
|
|
cd build
|
2023-03-15 11:34:43 +08:00
|
|
|
|
2023-10-11 23:09:02 +08:00
|
|
|
cmake \
|
|
|
|
|
-DCMAKE_INSTALL_PREFIX=/usr \
|
|
|
|
|
-DBUILD_VERSION=%{build_version} \
|
|
|
|
|
-DKERNEL_VERSION=%{kernel_name} \
|
|
|
|
|
..
|
|
|
|
|
|
2022-11-15 12:55:32 +00:00
|
|
|
make
|
|
|
|
|
|
2023-08-29 17:10:35 +08:00
|
|
|
################# Install ##################
|
2022-11-15 12:55:32 +00:00
|
|
|
%install
|
2023-06-02 17:11:44 +08:00
|
|
|
cd build
|
2022-11-15 12:55:32 +00:00
|
|
|
%make_install
|
2023-08-29 17:10:35 +08:00
|
|
|
|
2023-03-29 18:42:15 +08:00
|
|
|
mkdir -p %{buildroot}/lib/modules/%{kernel_name}/extra/syscare
|
2023-08-29 17:10:35 +08:00
|
|
|
mv -f %{buildroot}/usr/libexec/syscare/upatch_hijacker.ko %{buildroot}/lib/modules/%{kernel_name}/extra/syscare
|
2022-12-02 11:45:58 +00:00
|
|
|
|
2023-08-29 17:10:35 +08:00
|
|
|
############### PostInstall ################
|
2022-11-28 12:26:22 +00:00
|
|
|
%post
|
2023-04-04 10:57:35 +08:00
|
|
|
mkdir -p /usr/lib/syscare/patches
|
2023-03-15 11:34:43 +08:00
|
|
|
|
2023-08-29 17:10:35 +08:00
|
|
|
systemctl daemon-reload
|
2023-03-29 18:42:15 +08:00
|
|
|
systemctl enable syscare
|
2023-03-29 17:47:03 +08:00
|
|
|
systemctl start syscare
|
2022-12-02 11:45:58 +00:00
|
|
|
|
2023-08-29 17:10:35 +08:00
|
|
|
############### PreUninstall ###############
|
2022-12-02 11:45:58 +00:00
|
|
|
%preun
|
2023-10-11 23:09:02 +08:00
|
|
|
systemctl daemon-reload
|
2023-03-29 18:42:15 +08:00
|
|
|
systemctl stop syscare
|
|
|
|
|
systemctl disable syscare
|
2022-12-02 11:45:58 +00:00
|
|
|
|
2023-08-29 17:10:35 +08:00
|
|
|
############## PostUninstall ###############
|
2022-12-02 11:45:58 +00:00
|
|
|
%postun
|
2023-03-29 17:47:03 +08:00
|
|
|
if [ "$1" -eq 0 ] || { [ -n "$2" ] && [ "$2" -eq 0 ]; }; then
|
|
|
|
|
rm -rf /usr/lib/syscare
|
2023-08-29 17:10:35 +08:00
|
|
|
rm -f /var/log/syscare/syscared*.log*
|
|
|
|
|
if [ -z "$(ls -A /var/log/syscare)" ]; then
|
|
|
|
|
rm -rf /var/log/syscare
|
|
|
|
|
fi
|
2023-03-29 17:47:03 +08:00
|
|
|
fi
|
2022-11-28 12:26:22 +00:00
|
|
|
|
2023-08-29 17:10:35 +08:00
|
|
|
################## Files ###################
|
|
|
|
|
%files
|
|
|
|
|
%defattr(-,root,root,-)
|
|
|
|
|
%dir /usr/libexec/syscare
|
|
|
|
|
%attr(644,root,root) /usr/lib/systemd/system/syscare.service
|
|
|
|
|
%attr(755,root,root) /usr/bin/syscared
|
2023-10-11 23:09:02 +08:00
|
|
|
%attr(755,root,root) /usr/bin/syscare
|
2023-11-22 09:58:04 +08:00
|
|
|
%attr(755,root,root) /usr/libexec/syscare/upatch-manage
|
2023-03-29 18:42:15 +08:00
|
|
|
|
2023-08-29 17:10:35 +08:00
|
|
|
############################################
|
|
|
|
|
########## Package syscare-build ###########
|
|
|
|
|
############################################
|
|
|
|
|
%package build
|
|
|
|
|
Summary: Syscare build tools.
|
|
|
|
|
BuildRequires: elfutils-libelf-devel
|
|
|
|
|
Requires: (%{pkg_build_kmod} >= %{build_version} or %{pkg_build_ebpf} >= %{build_version})
|
|
|
|
|
Requires: coreutils
|
|
|
|
|
Requires: patch
|
|
|
|
|
Requires: kpatch
|
|
|
|
|
Requires: tar gzip
|
|
|
|
|
Requires: rpm rpm-build
|
|
|
|
|
|
|
|
|
|
############### Description ################
|
|
|
|
|
%description build
|
|
|
|
|
Syscare patch building toolset.
|
|
|
|
|
|
|
|
|
|
############### PostInstall ################
|
|
|
|
|
%post build
|
|
|
|
|
mkdir -p /etc/syscare
|
|
|
|
|
systemctl daemon-reload
|
2023-10-11 23:09:02 +08:00
|
|
|
systemctl enable upatch
|
|
|
|
|
systemctl start upatch
|
2023-08-29 17:10:35 +08:00
|
|
|
|
|
|
|
|
############### PreUninstall ###############
|
|
|
|
|
%preun build
|
|
|
|
|
systemctl daemon-reload
|
2023-10-11 23:09:02 +08:00
|
|
|
systemctl stop upatch
|
|
|
|
|
systemctl disable upatch
|
2023-08-29 17:10:35 +08:00
|
|
|
|
|
|
|
|
############## PostUninstall ###############
|
|
|
|
|
%postun build
|
|
|
|
|
if [ "$1" -eq 0 ] || { [ -n "$2" ] && [ "$2" -eq 0 ]; }; then
|
|
|
|
|
rm -rf /etc/syscare
|
|
|
|
|
rm -f /var/log/syscare/upatchd*.log*
|
|
|
|
|
if [ -z "$(ls -A /var/log/syscare)" ]; then
|
|
|
|
|
rm -rf /var/log/syscare
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
################## Files ###################
|
2022-11-15 12:55:32 +00:00
|
|
|
%files build
|
|
|
|
|
%defattr(-,root,root,-)
|
2023-03-15 11:34:43 +08:00
|
|
|
%dir /usr/libexec/syscare
|
2023-10-11 23:09:02 +08:00
|
|
|
%attr(644,root,root) /usr/lib/systemd/system/upatch.service
|
2023-08-29 17:10:35 +08:00
|
|
|
%attr(755,root,root) /usr/bin/upatchd
|
2023-03-15 11:34:43 +08:00
|
|
|
%attr(755,root,root) /usr/libexec/syscare/syscare-build
|
|
|
|
|
%attr(755,root,root) /usr/libexec/syscare/upatch-build
|
2023-03-29 17:47:03 +08:00
|
|
|
%attr(755,root,root) /usr/libexec/syscare/upatch-diff
|
2023-08-29 17:10:35 +08:00
|
|
|
%attr(755,root,root) /usr/libexec/syscare/as-hijacker
|
|
|
|
|
%attr(755,root,root) /usr/libexec/syscare/cc-hijacker
|
|
|
|
|
%attr(755,root,root) /usr/libexec/syscare/c++-hijacker
|
|
|
|
|
%attr(755,root,root) /usr/libexec/syscare/gcc-hijacker
|
|
|
|
|
%attr(755,root,root) /usr/libexec/syscare/g++-hijacker
|
|
|
|
|
|
|
|
|
|
############################################
|
|
|
|
|
######## Package syscare-build-kmod ########
|
|
|
|
|
############################################
|
|
|
|
|
%package build-kmod
|
|
|
|
|
Summary: Kernel module for syscare patch build tools.
|
|
|
|
|
BuildRequires: make gcc
|
2023-09-04 18:16:46 +08:00
|
|
|
BuildRequires: kernel-devel
|
2023-08-29 17:10:35 +08:00
|
|
|
Requires: kernel >= %{kernel_version}
|
|
|
|
|
|
|
|
|
|
############### Description ################
|
|
|
|
|
%description build-kmod
|
|
|
|
|
Syscare build dependency - kernel module.
|
|
|
|
|
|
|
|
|
|
############### PostInstall ################
|
|
|
|
|
%post build-kmod
|
|
|
|
|
echo "/lib/modules/%{kernel_name}/extra/syscare/upatch_hijacker.ko" | /sbin/weak-modules --add-module --no-initramfs
|
2023-11-24 04:53:41 +08:00
|
|
|
depmod > /dev/null 2>&1
|
2023-08-29 17:10:35 +08:00
|
|
|
|
|
|
|
|
############### PreUninstall ###############
|
|
|
|
|
%preun build-kmod
|
|
|
|
|
# Nothing
|
|
|
|
|
|
|
|
|
|
############## PostUninstall ###############
|
|
|
|
|
%postun build-kmod
|
|
|
|
|
echo "/lib/modules/%{kernel_name}/extra/syscare/upatch_hijacker.ko" | /sbin/weak-modules --remove-module --no-initramfs
|
2023-11-24 04:53:41 +08:00
|
|
|
depmod > /dev/null 2>&1
|
2023-08-29 17:10:35 +08:00
|
|
|
|
|
|
|
|
################## Files ###################
|
|
|
|
|
%files build-kmod
|
|
|
|
|
%dir /lib/modules/%{kernel_name}/extra/syscare
|
|
|
|
|
%attr(640,root,root) /lib/modules/%{kernel_name}/extra/syscare/upatch_hijacker.ko
|
|
|
|
|
|
|
|
|
|
############################################
|
|
|
|
|
######## Package syscare-build-ebpf ########
|
|
|
|
|
############################################
|
|
|
|
|
%package build-ebpf
|
|
|
|
|
Summary: eBPF for syscare patch build tools.
|
|
|
|
|
BuildRequires: make llvm clang bpftool
|
|
|
|
|
BuildRequires: libbpf libbpf-devel libbpf-static
|
|
|
|
|
|
|
|
|
|
############### Description ################
|
|
|
|
|
%description build-ebpf
|
|
|
|
|
Syscare build dependency - eBPF.
|
|
|
|
|
|
|
|
|
|
############### PostInstall ################
|
|
|
|
|
%post build-ebpf
|
|
|
|
|
|
|
|
|
|
############### PreUninstall ###############
|
|
|
|
|
%preun build-ebpf
|
|
|
|
|
# Nothing
|
|
|
|
|
|
|
|
|
|
############## PostUninstall ###############
|
|
|
|
|
%postun build-ebpf
|
|
|
|
|
# Nothing
|
|
|
|
|
|
|
|
|
|
################## Files ###################
|
|
|
|
|
%files build-ebpf
|
|
|
|
|
%attr(755,root,root) /usr/libexec/syscare/upatch_hijacker
|
|
|
|
|
|
|
|
|
|
############################################
|
|
|
|
|
################ Change log ################
|
|
|
|
|
############################################
|
2022-11-15 12:55:32 +00:00
|
|
|
%changelog
|
2023-12-12 09:57:38 +08:00
|
|
|
* Tue Dec 12 2023 renoseven<dev@renoseven.net> - 1.2.0-8
|
|
|
|
|
- Builder: fix 'enabling multiple kpatch may lead soft-lockup' issue
|
2023-11-28 19:32:08 +08:00
|
|
|
* Wed Nov 29 2023 renoseven<dev@renoseven.net> - 1.2.0-7
|
|
|
|
|
- Fix aarch64 compile issue
|
2023-11-28 17:40:33 +08:00
|
|
|
* Tue Nov 28 2023 renoseven<dev@renoseven.net> - 1.2.0-6
|
|
|
|
|
- Enable debuginfo for rust code
|
|
|
|
|
- Sync arguments with old version
|
2023-11-27 20:20:10 +08:00
|
|
|
* Tue Nov 28 2023 renoseven<dev@renoseven.net> - 1.2.0-5
|
|
|
|
|
- Upgrade MSRV to 1.60
|
|
|
|
|
- Optimize syscare build check logic
|
|
|
|
|
- Optimize external command calling
|
|
|
|
|
- Optimize log output
|
2023-11-24 04:53:41 +08:00
|
|
|
* Fri Nov 24 2023 renoseven<dev@renoseven.net> - 1.2.0-4
|
|
|
|
|
- Fix 'kpatch driver cannot support old version' issue
|
2023-11-24 03:17:11 +08:00
|
|
|
* Fri Nov 24 2023 renoseven<dev@renoseven.net> - 1.2.0-3
|
|
|
|
|
- Fix 'upatch only apply first patch for new process' issue
|
2023-11-22 14:22:57 +08:00
|
|
|
* Wed Nov 22 2023 renoseven<dev@renoseven.net> - 1.2.0-2
|
|
|
|
|
- Fix upatch process detection
|
2023-11-22 09:58:04 +08:00
|
|
|
* Wed Nov 22 2023 renoseven<dev@renoseven.net> - 1.2.0-1
|
|
|
|
|
- Fix various issue
|
2023-10-11 23:09:02 +08:00
|
|
|
* Wed Oct 11 2023 renoseven<dev@renoseven.net> - 1.1.0-6
|
|
|
|
|
- Support build patch for kernel moudules
|
|
|
|
|
- Fix various issue
|
2023-09-22 14:18:22 +08:00
|
|
|
* Fri Sep 22 2023 renoseven<dev@renoseven.net> - 1.1.0-5
|
|
|
|
|
- Fix various issue
|
2023-09-21 09:35:06 +08:00
|
|
|
* Thu Sep 21 2023 renoseven<dev@renoseven.net> - 1.1.0-4
|
|
|
|
|
- Fix 'syscare-build only accept one patch' issue
|
2023-09-20 14:58:01 +08:00
|
|
|
* Wed Sep 20 2023 renoseven<dev@renoseven.net> - 1.1.0-3
|
|
|
|
|
- Fix various issue
|
|
|
|
|
- Support MSRV 1.51
|
2023-08-29 17:10:35 +08:00
|
|
|
* Mon Aug 28 2023 renoseven<dev@renoseven.net> - 1.1.0-1
|
|
|
|
|
- Support build patch without kernel module
|
|
|
|
|
- Add syscare daemon
|
|
|
|
|
- Add syscare-build daemon
|
|
|
|
|
- Improve syscare cli
|
2023-06-28 16:28:06 +08:00
|
|
|
* Wed Jun 28 2023 renoseven<dev@renoseven.net> - 1.0.2-4
|
|
|
|
|
- Fix builder check failure issue
|
2023-06-25 14:36:51 +08:00
|
|
|
* Sun Jun 25 2023 renoseven<dev@renoseven.net> - 1.0.2-3
|
|
|
|
|
- Fix various issue
|
2023-06-17 19:06:50 +08:00
|
|
|
* Mon Jun 19 2023 renoseven<dev@renoseven.net> - 1.0.2-2
|
|
|
|
|
- Fix various issue
|
|
|
|
|
- Update dependencies
|
2023-06-09 11:46:19 +08:00
|
|
|
* Fri Jun 09 2023 renoseven<dev@renoseven.net> - 1.0.2-1
|
|
|
|
|
- Fix 'rpmpbuild getcwd failed' issue
|
|
|
|
|
- Fix 'upatch ko prints redundant log' issue
|
2023-06-09 08:21:53 +08:00
|
|
|
* Fri Jun 09 2023 renoseven<dev@renoseven.net> - 1.0.1-9
|
|
|
|
|
- Fix 'patch file is not checked' issue
|
|
|
|
|
- Rename patched source package
|
|
|
|
|
- Update dependencies
|
2023-06-06 21:55:03 +08:00
|
|
|
* Tue Jun 06 2023 renoseven<dev@renoseven.net> - 1.0.1-8
|
|
|
|
|
- Fix 'kernel patch sys interface collision' issue
|
|
|
|
|
- Fix 'patch GOT table jump fails' issue
|
|
|
|
|
- Fix 'patch TLS variable relocation fails' issue
|
2023-06-02 17:11:44 +08:00
|
|
|
* Fri Jun 02 2023 renoseven<dev@renoseven.net> - 1.0.1-7
|
|
|
|
|
- Various bugfix
|
|
|
|
|
- Support multiple compiler
|
2023-05-31 08:13:47 +08:00
|
|
|
* Wed May 31 2023 renoseven<dev@renoseven.net> - 1.0.1-6
|
|
|
|
|
- Various bugfix
|
|
|
|
|
- Support multiple debuginfo package
|
2023-05-15 10:29:54 +08:00
|
|
|
* Mon May 15 2023 renoseven<dev@renoseven.net> - 1.0.1-5
|
|
|
|
|
- Fix aarch64 kmod patch jump instruction error issue
|
|
|
|
|
- Add ifunc support
|
|
|
|
|
- Add 'syscare accept' command
|
|
|
|
|
- Add patch 'ACCEPT' state
|
2023-04-04 10:57:35 +08:00
|
|
|
* Tue Apr 04 2023 renoseven<dev@renoseven.net> - 1.0.1-4
|
|
|
|
|
- Enable aarch64
|
|
|
|
|
- Fix syscare-upatch service may start failed issue
|
2023-03-29 18:42:15 +08:00
|
|
|
* Thu Mar 30 2023 renoseven<dev@renoseven.net> - 1.0.1-3
|
|
|
|
|
- Fix upatch may not contain all symbols issue
|
|
|
|
|
- Add syscare-kmod package
|
2023-03-29 17:47:03 +08:00
|
|
|
* Wed Mar 29 2023 renoseven<dev@renoseven.net> - 1.0.1-2
|
|
|
|
|
- Fix rpm install & remove script issue
|
2023-03-15 11:34:43 +08:00
|
|
|
* Wed Mar 15 2023 renoseven<dev@renoseven.net> - 1.0.1-1
|
|
|
|
|
- New syscare cli
|
|
|
|
|
- Support building patch for C++ code
|
|
|
|
|
- Support patch version verification
|
|
|
|
|
- Support elf name derivation
|
|
|
|
|
- Support fast reboot
|
2022-12-21 12:03:08 +00:00
|
|
|
* Wed Dec 21 2022 snoweay<snoweay@163.com> - 1.0.0-7
|
|
|
|
|
- Fix 42 relocation caused by gcc 11.
|
2022-12-20 14:00:40 +00:00
|
|
|
* Tue Dec 20 2022 snoweay<snoweay@163.com> - 1.0.0-6
|
|
|
|
|
- Fix patch open failure by reading patches at attach instead of load.
|
|
|
|
|
- Support epoch in spec.
|
2022-12-17 10:05:25 +00:00
|
|
|
* Sat Dec 17 2022 snoweay<snoweay@163.com> - 1.0.0-5
|
|
|
|
|
- Check version-release of source pkg & debuginfo pkg.
|
2022-12-16 09:15:36 +00:00
|
|
|
* Fri Dec 16 2022 snoweay<snoweay@163.com> - 1.0.0-4
|
|
|
|
|
- Avoid duplicate elfs by not following symlinks at build.
|
2022-12-15 11:04:03 +00:00
|
|
|
* Thu Dec 15 2022 snoweay<snoweay@163.com> - 1.0.0-3
|
|
|
|
|
- Change kernel patches' scontext before apply not at rpm-post.
|
2022-12-14 13:43:07 +00:00
|
|
|
* Wed Dec 14 2022 snoweay<snoweay@163.com> - 1.0.0-2
|
|
|
|
|
- Fix some issues:
|
|
|
|
|
- manager: Allow apply to actived kernel patch
|
|
|
|
|
- build: only 'NOT-APPLIED' patch package can be removed
|
|
|
|
|
- build: fix 'kernel patch cannot be insmod during system start' issue
|
|
|
|
|
- kmod: unregister when rmmod upatch
|
2022-12-13 03:07:16 +00:00
|
|
|
* Tue Dec 13 2022 snoweay<snoweay@163.com> - 1.0.0-1
|
|
|
|
|
- Release the first version 1.0.0.
|