diff --git a/module-contrib/hotfix_conflict_check.sh b/module-contrib/hotfix_conflict_check similarity index 100% rename from module-contrib/hotfix_conflict_check.sh rename to module-contrib/hotfix_conflict_check diff --git a/module-contrib/plugsched.service b/module-contrib/plugsched.service index b7cfbf3f89926794a78dedd6f87f0507b59e3870..22659c1438c17612278dce941729f514dc497b6c 100644 --- a/module-contrib/plugsched.service +++ b/module-contrib/plugsched.service @@ -7,8 +7,7 @@ ConditionKernelCommandLine=!plugsched.enable=0 [Service] Type=oneshot -ExecStartPre=/usr/bin/bash -c "hotfix_conflict_check /var/plugsched/$(uname -r)/tainted_functions" -ExecStart=/usr/local/bin/scheduler-install install +ExecStart=/usr/bin/bash -c "/var/plugsched/$(uname -r)/scheduler-installer install" [Install] WantedBy=multi-user.target diff --git a/module-contrib/scheduler-install b/module-contrib/scheduler-installer similarity index 82% rename from module-contrib/scheduler-install rename to module-contrib/scheduler-installer index 64cde05e88de34cf4f5fd6aa43e9ab5a4e3d4e92..66484ec3476b5fe578ac31dfdcc7ebe092b97f22 100755 --- a/module-contrib/scheduler-install +++ b/module-contrib/scheduler-installer @@ -7,6 +7,8 @@ RETRY_INTERVAL=2 cursys=$(uname -r) modfile=/var/plugsched/$cursys/scheduler.ko +hotfix_conflict_check=/var/plugsched/$cursys/hotfix_conflict_check +tainted_functions=/var/plugsched/$cursys/tainted_functions enablefile=/sys/kernel/plugsched/plugsched/enable mod=$(modinfo $modfile | grep vermagic | awk '{print $2}') @@ -58,17 +60,18 @@ uninstall_module() { fi } -if [ $1 == "install" ]; then +if [ "$1" == "install" ]; then if [ "$cursys" == "$mod" ]; then + $hotfix_conflict_check $tainted_functions || exit 1 /usr/bin/mkdir -p /run/plugsched /usr/bin/cp $modfile /run/plugsched/scheduler.ko - /usr/local/bin/symbol_resolve /run/plugsched/scheduler.ko /proc/kallsyms + /var/plugsched/$(uname -r)/symbol_resolve /run/plugsched/scheduler.ko /proc/kallsyms install_module /run/plugsched/scheduler.ko else warn "Error: kernel version is not same as plugsched version!" exit 1 fi -elif [ $1 == "uninstall" ]; then +elif [ "$1" == "uninstall" ]; then uninstall_module /usr/bin/rm -rf /run/plugsched else diff --git a/module-contrib/scheduler.spec b/module-contrib/scheduler.spec index b36d628f3dca34c88f8b7f1eab4114a5fb6da06b..18ff77f88a2083fd34b5da37fcefc5d307bc8987 100644 --- a/module-contrib/scheduler.spec +++ b/module-contrib/scheduler.spec @@ -19,23 +19,18 @@ Packager: Yihao Wu Group: System Environment/Kernel License: GPLv2 URL: None -Source1: scheduler-install -Source2: plugsched.service -Source3: hotfix_conflict_check.sh -Source4: version -Source5: sched_boundary.yaml %description The scheduler policy rpm-package. %prep # copy files to rpmbuild/SOURCE/ -cp %{_outdir}/scheduler-install %{_sourcedir} -cp %{_outdir}/plugsched.service %{_sourcedir} -cp %{_outdir}/hotfix_conflict_check.sh %{_sourcedir} -cp %{_outdir}/version %{_sourcedir} +cp %{_outdir}/* %{_sourcedir} cp %{_tmpdir}/sched_boundary.yaml %{_sourcedir} +chmod 0644 %{_sourcedir}/{version,sched_boundary.yaml} +rm -f %{_sourcedir}/scheduler.spec + %build # Build sched_mod make plugsched_tmpdir=%{_tmpdir} plugsched_modpath=%{_modpath} -C %{_kerneldir} \ @@ -46,56 +41,52 @@ make -C %{_tmpdir}/symbol_resolve # Generate the tainted_functions file awk -F '[(,)]' '$2!=""{print $2" "$3" vmlinux"}' %{_modpath}/tainted_functions{.h,_sidecar.h} > %{_sourcedir}/tainted_functions +chmod 0444 %{_sourcedir}/tainted_functions %install #install tool, module and systemd service -mkdir -p %{buildroot}%{_bindir} mkdir -p %{buildroot}%{_prefix}/lib/systemd/system mkdir -p %{buildroot}%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch} -install -m 755 %{_tmpdir}/symbol_resolve/symbol_resolve %{buildroot}%{_bindir}/symbol_resolve +install -m 755 %{_tmpdir}/symbol_resolve/symbol_resolve %{buildroot}%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/symbol_resolve install -m 755 %{_modpath}/scheduler.ko %{buildroot}%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/scheduler.ko -install -m 444 %{_sourcedir}/tainted_functions %{buildroot}%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/tainted_functions +install -m 644 %{_sourcedir}/plugsched.service %{buildroot}%{_prefix}/lib/systemd/system -install -m 755 %{SOURCE1} %{buildroot}%{_bindir} -install -m 644 %{SOURCE2} %{buildroot}%{_prefix}/lib/systemd/system -install -m 755 %{SOURCE3} %{buildroot}%{_bindir}/hotfix_conflict_check -install -m 644 %{SOURCE4} %{buildroot}%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/version -install -m 644 %{SOURCE5} %{buildroot}%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/sched_boundary.yaml +cp %{_sourcedir}/* %{buildroot}%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch} +rm -f %{buildroot}%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/plugsched.service #install kernel module after install this rpm-package %post sync -if [ $1 == 1 ]; then - echo "Installing scheduler" - systemctl daemon-reload - systemctl enable plugsched - systemctl start plugsched -elif [ $1 == 2 ]; then - echo "Upgrading scheduler - install new version." - /sbin/rmmod scheduler || echo "scheduler module not loaded. Skip rmmod and continue upgrade." +if [ "$(uname -r)" != "%{KVER}-%{KREL}.%{_arch}" ]; then + echo "INFO: scheduler dose not match kernel, skip load module..." + exit 0 fi +echo "Start plugsched.service" +systemctl daemon-reload +systemctl enable plugsched +systemctl start plugsched + #uninstall kernel module before remove this rpm-package %preun -systemctl daemon-reload -if [ $1 == 0 ]; then - echo "Uninstalling scheduler" - /usr/local/bin/scheduler-install uninstall || exit 1 -elif [ $1 == 1 ]; then - echo "Upgrading scheduler - uninstall old version." - systemctl start scheduler +if [ "$(uname -r)" != "%{KVER}-%{KREL}.%{_arch}" ]; then + echo "INFO: scheduler dose not match kernel, skip unload module..." + exit 0 fi +echo "Stop plugsched.service" +/var/plugsched/$(uname -r)/scheduler-installer uninstall || exit 1 + +%postun +systemctl daemon-reload + %files -%{_bindir}/symbol_resolve -%{_bindir}/scheduler-install -%{_bindir}/hotfix_conflict_check %{_prefix}/lib/systemd/system/plugsched.service -%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/scheduler.ko -%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/tainted_functions -%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/version -%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/sched_boundary.yaml +%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch}/* + +%dir +%{_localstatedir}/plugsched/%{KVER}-%{KREL}.%{_arch} %changelog