Compare commits
No commits in common. "71c9556e46aa3cb5aa46b883a4c7a9fac7eb71e6" and "06e433c15f3af8257e357f2fbf20942f2a2984fa" have entirely different histories.
71c9556e46
...
06e433c15f
69
README.md
69
README.md
@ -1,73 +1,30 @@
|
|||||||
# stalld
|
# stalld
|
||||||
|
|
||||||
#### 介绍
|
#### 介绍
|
||||||
The stalld program (which stands for 'stall daemon') is a
|
The stalld program is a mechanism to prevent the starvation of operating system threads in a Linux system.
|
||||||
mechanism to prevent the starvation of operating system threads in a
|
|
||||||
Linux system. The premise is to start up on a housekeeping cpu (one
|
|
||||||
that is not used for real-application purposes) and to periodically
|
|
||||||
monitor the state of each thread in the system, looking for a thread
|
|
||||||
that has been on a run queue (i.e. ready to run) for a specifed length
|
|
||||||
of time without being run. This condition is usually hit when the
|
|
||||||
thread is on the same cpu as a high-priority cpu-intensive task and
|
|
||||||
therefore is being given no opportunity to run.
|
|
||||||
When a thread is judged to be starving, stalld changes
|
|
||||||
that thread to use the SCHED_DEADLINE policy and gives the thread a
|
|
||||||
small slice of time for that cpu (specified on the command line). The
|
|
||||||
thread then runs and when that timeslice is used, the thread is then
|
|
||||||
returned to its original scheduling policy and stalld then
|
|
||||||
continues to monitor thread states.
|
|
||||||
There is now an experimental option to boost using SCHED_FIFO. This
|
|
||||||
logic is used if the running kernel does not support the
|
|
||||||
SCHED_DEADLINE policy and may be forced by using the -F/--force_fifo
|
|
||||||
option.
|
|
||||||
|
|
||||||
|
|
||||||
|
#### 软件架构
|
||||||
|
软件架构说明
|
||||||
|
|
||||||
|
|
||||||
#### 安装教程
|
#### 安装教程
|
||||||
|
|
||||||
Install stalld rpm package:
|
1. xxxx
|
||||||
|
2. xxxx
|
||||||
yum install stalld
|
3. xxxx
|
||||||
|
|
||||||
#### 使用说明
|
#### 使用说明
|
||||||
Logging options
|
|
||||||
|
|
||||||
-l/--log_only: only log information (do not boost) [false]
|
1. xxxx
|
||||||
-v/--verbose: print info to the std output [false]
|
2. xxxx
|
||||||
-k/--log_kmsg: print log to the kernel buffer [false]
|
3. xxxx
|
||||||
-s/--log_syslog: print log to syslog [true]
|
|
||||||
|
|
||||||
|
|
||||||
Startup options
|
|
||||||
|
|
||||||
-c/--cpu: list of cpus to monitor for stalled threads [all cpus]
|
|
||||||
-f/--foreground: run in foreground [false but true when -v]
|
|
||||||
-P/--pidfile: write daemon pid to specified file [no pidfile]
|
|
||||||
|
|
||||||
|
|
||||||
Boosting options
|
|
||||||
|
|
||||||
-p/--boost_period: SCHED_DEADLINE period [ns] that the starving task will receive [1000000000]
|
|
||||||
-r/--boost_runtime: SCHED_DEADLINE runtime [ns] that the starving task will receive [20000]
|
|
||||||
-d/--boost_duration: how long [s] the starving task will run with SCHED_DEADLINE [3]
|
|
||||||
-F/--force_fifo: force using SCHED_FIFO for boosting
|
|
||||||
|
|
||||||
|
|
||||||
Monitoring options
|
|
||||||
|
|
||||||
-t/--starving_threshold: how long [s] the starving task will wait before being boosted [60]
|
|
||||||
-A/--aggressive_mode: dispatch one thread per run queue, even when there is no starving
|
|
||||||
threads on all CPU (uses more CPU/power). [false]
|
|
||||||
|
|
||||||
#### 参与贡献
|
#### 参与贡献
|
||||||
|
|
||||||
master分支使用最新的上游版本,如果检测到上游有最新版本发布,先形成issue后再提交对应PR更新,流程如下。
|
1. Fork 本仓库
|
||||||
1. 提交issue
|
2. 新建 Feat_xxx 分支
|
||||||
2. Fork 本仓库
|
3. 提交代码
|
||||||
3. 新建 Feat_xxx 分支
|
4. 新建 Pull Request
|
||||||
4. 提交代码
|
|
||||||
5. 新建 Pull Request
|
|
||||||
|
|
||||||
|
|
||||||
#### 特技
|
#### 特技
|
||||||
|
|||||||
@ -1,30 +0,0 @@
|
|||||||
diff --git a/Makefile b/Makefile
|
|
||||||
index f866a74..76aefe2 100644
|
|
||||||
--- a/Makefile
|
|
||||||
+++ b/Makefile
|
|
||||||
@@ -34,6 +34,12 @@ USE_BPF := 0
|
|
||||||
FCF_PROTECTION := $(CF_PROTECTION_OPTS)
|
|
||||||
TMOPTS := -mtune=powerpc
|
|
||||||
endif
|
|
||||||
+ifeq ($(ARCH),riscv64)
|
|
||||||
+USE_BPF :=0
|
|
||||||
+FCF_PROTECTION := $(CF_PROTECTION_OPTS)
|
|
||||||
+TMOPTS := -march=rv64gc -mabi=lp64d
|
|
||||||
+endif
|
|
||||||
+
|
|
||||||
|
|
||||||
$(info USE_BPF=$(USE_BPF))
|
|
||||||
$(info FCF_PROTECTION=$(FCF_PROTECTION))
|
|
||||||
diff --git a/src/stalld.h b/src/stalld.h
|
|
||||||
index a5b9dbc..7362d4e 100644
|
|
||||||
--- a/src/stalld.h
|
|
||||||
+++ b/src/stalld.h
|
|
||||||
@@ -119,7 +119,7 @@ struct stalld_backend {
|
|
||||||
#elif __arm__
|
|
||||||
# define __NR_sched_setattr 380
|
|
||||||
# define __NR_sched_getattr 381
|
|
||||||
-#elif __aarch64__ || __loongarch64
|
|
||||||
+#elif __aarch64__ || __loongarch64 || __riscv
|
|
||||||
# define __NR_sched_setattr 274
|
|
||||||
# define __NR_sched_getattr 275
|
|
||||||
#elif __powerpc__
|
|
||||||
BIN
stalld-1.16.tar.bz2
Normal file
BIN
stalld-1.16.tar.bz2
Normal file
Binary file not shown.
Binary file not shown.
31
stalld.spec
31
stalld.spec
@ -1,12 +1,11 @@
|
|||||||
Name: stalld
|
Name: stalld
|
||||||
Version: v1.19.1
|
Version: 1.16
|
||||||
Release: 1
|
Release: 1
|
||||||
Summary: Daemon that finds starving tasks and gives them a temporary boost
|
Summary: Daemon that finds starving tasks and gives them a temporary boost
|
||||||
|
|
||||||
License: GPLv2
|
License: GPLv2
|
||||||
URL: https://gitlab.com/rt-linux-tools/%{name}
|
URL: https://gitlab.com/rt-linux-tools/%{name}
|
||||||
Source0: https://gitlab.com/rt-linux-tools/%{name}/-/archive/%{version}/%{name}-%{version}.tar.bz2
|
Source0: https://gitlab.com/rt-linux-tools/%{name}/-/archive/v%{version}/%{name}-%{version}.tar.bz2
|
||||||
Patch0: riscv_support.patch
|
|
||||||
|
|
||||||
BuildRequires: glibc-devel
|
BuildRequires: glibc-devel
|
||||||
BuildRequires: gcc
|
BuildRequires: gcc
|
||||||
@ -15,15 +14,6 @@ BuildRequires: systemd
|
|||||||
|
|
||||||
Requires: systemd
|
Requires: systemd
|
||||||
|
|
||||||
%ifnarch i686
|
|
||||||
BuildRequires: bpftool
|
|
||||||
BuildRequires: clang
|
|
||||||
BuildRequires: libbpf-devel
|
|
||||||
BuildRequires: llvm
|
|
||||||
|
|
||||||
Requires: libbpf
|
|
||||||
%endif
|
|
||||||
|
|
||||||
%description
|
%description
|
||||||
The stalld program monitors the set of system threads,
|
The stalld program monitors the set of system threads,
|
||||||
looking for threads that are ready-to-run but have not
|
looking for threads that are ready-to-run but have not
|
||||||
@ -33,23 +23,21 @@ boost using the SCHED_DEADLINE policy. The default is to
|
|||||||
allow 10 microseconds of runtime for 1 second of clock time.
|
allow 10 microseconds of runtime for 1 second of clock time.
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%autosetup -p1
|
%autosetup
|
||||||
|
|
||||||
%build
|
%build
|
||||||
%make_build CFLAGS="%{optflags} %{build_cflags} -DVERSION="\\\"%{version}\\\""" LDFLAGS="%{build_ldflags}"
|
%make_build CFLAGS="%{optflags} %{build_cflags} -DVERSION="\\\"%{version}\\\""" LDFLAGS="%{build_ldflags}"
|
||||||
|
|
||||||
%install
|
%install
|
||||||
%make_install DOCDIR=%{_docdir} MANDIR=%{_mandir} BINDIR=%{_bindir} DATADIR=%{_datadir} VERSION=%{version}
|
%make_install DOCDIR=%{_docdir} MANDIR=%{_mandir} BINDIR=%{_bindir} DATADIR=%{_datadir} VERSION=%{version}
|
||||||
%make_install -C systemd UNITDIR=%{_unitdir}
|
%make_install -C redhat UNITDIR=%{_unitdir}
|
||||||
mkdir -p %{buildroot}%{_docdir}/%{name}
|
|
||||||
mv %{buildroot}%{_docdir}/README.md %{buildroot}%{_docdir}/%{name}/
|
|
||||||
|
|
||||||
%files
|
%files
|
||||||
%{_bindir}/%{name}
|
%{_bindir}/%{name}
|
||||||
%{_bindir}/throttlectl
|
%{_bindir}/throttlectl
|
||||||
%{_unitdir}/%{name}.service
|
%{_unitdir}/%{name}.service
|
||||||
%config(noreplace) %{_sysconfdir}/sysconfig/stalld
|
%config(noreplace) %{_sysconfdir}/sysconfig/stalld
|
||||||
%doc %{_docdir}/%{name}/README.md
|
%doc %{_docdir}/README.md
|
||||||
%doc %{_mandir}/man8/stalld.8*
|
%doc %{_mandir}/man8/stalld.8*
|
||||||
%license gpl-2.0.txt
|
%license gpl-2.0.txt
|
||||||
|
|
||||||
@ -63,15 +51,6 @@ mv %{buildroot}%{_docdir}/README.md %{buildroot}%{_docdir}/%{name}/
|
|||||||
%systemd_postun_with_restart %{name}.service
|
%systemd_postun_with_restart %{name}.service
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
* Sat Mar 23 2024 luojun <luojun.oerv@isrc.iscas.ac.cn> - v1.19.1-1
|
|
||||||
- update to v1.19 and support for oe-riscv
|
|
||||||
|
|
||||||
* Thu Sep 14 2023 duyiwei <duyiwei@kylinos.cn> - 1.16-3
|
|
||||||
- move README
|
|
||||||
|
|
||||||
* Thu Jul 20 2023 lvgenggeng <lvgenggeng@uniontech.com> - 1.16-2
|
|
||||||
- add support for loongarch64
|
|
||||||
|
|
||||||
* Mon Nov 07 2022 duyiwei <duyiwei@kylinos.cn> - 1.16-1
|
* Mon Nov 07 2022 duyiwei <duyiwei@kylinos.cn> - 1.16-1
|
||||||
- upgrade version to 1.16
|
- upgrade version to 1.16
|
||||||
|
|
||||||
|
|||||||
@ -1,4 +0,0 @@
|
|||||||
version_control: gitlab
|
|
||||||
src_repo: rt-linux-tools/stalld
|
|
||||||
tag_prefix: "v"
|
|
||||||
separator: "."
|
|
||||||
Loading…
x
Reference in New Issue
Block a user