!118 [sync] PR-116: library: address remaining cpu distortions, api
From: @openeuler-sync-bot Reviewed-by: @wangbin224 Signed-off-by: @wangbin224
This commit is contained in:
commit
586082f0fe
@ -0,0 +1,79 @@
|
|||||||
|
From 6418b8c1fbcfdcda4cad8efacccceb7bcdbb1de9 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jim Warner <james.warner@comcast.net>
|
||||||
|
Date: Wed, 20 Mar 2024 00:00:00 -0500
|
||||||
|
Subject: [PATCH] library: address remaining cpu distortions, <stat> api
|
||||||
|
|
||||||
|
When the potential cpu distortion was addressed in the
|
||||||
|
commit referenced below, the revision did not quite go
|
||||||
|
far enough. This was revealed in the merge plus issue
|
||||||
|
posts also shown. Thus a need for this final solution.
|
||||||
|
|
||||||
|
[ and now that all the stat_jifs fields are verified ]
|
||||||
|
[ that TICsetH macro need not check for distortions. ]
|
||||||
|
|
||||||
|
Reference(s):
|
||||||
|
https://gitlab.com/procps-ng/procps/-/merge_requests/223
|
||||||
|
https://gitlab.com/procps-ng/procps/-/issues/321
|
||||||
|
|
||||||
|
. Mar, 2017 - cpu distorions relocated/improved
|
||||||
|
commit 253ac7f709412a8699767bd70faeaf98e19614f0
|
||||||
|
|
||||||
|
Discovered-by: Chao Liu SuperSix173 <liuchao173@huawei.com>
|
||||||
|
Signed-off-by: Jim Warner <james.warner@comcast.net>
|
||||||
|
---
|
||||||
|
library/stat.c | 24 +++++++++++++++---------
|
||||||
|
1 file changed, 15 insertions(+), 9 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/library/stat.c b/library/stat.c
|
||||||
|
index c37e9b54..b04fe0a5 100644
|
||||||
|
--- a/library/stat.c
|
||||||
|
+++ b/library/stat.c
|
||||||
|
@@ -182,9 +182,10 @@ struct stat_info {
|
||||||
|
#define SYS_set(e,t,x) setDECL(e) { \
|
||||||
|
(void)T; R->result. t = S->new. x; }
|
||||||
|
// delta assignment
|
||||||
|
+// ( thanks to 'stat_derive_unique', this macro no longer needs to )
|
||||||
|
+// ( protect against a negative value when a cpu is brought online )
|
||||||
|
#define TICsetH(e,t,x) setDECL(e) { \
|
||||||
|
- (void)S; R->result. t = ( T->new. x - T->old. x ); \
|
||||||
|
- if (R->result. t < 0) R->result. t = 0; }
|
||||||
|
+ (void)S; R->result. t = ( T->new. x - T->old. x ); }
|
||||||
|
#define SYSsetH(e,t,x) setDECL(e) { \
|
||||||
|
(void)T; R->result. t = ( S->new. x - S->old. x ); }
|
||||||
|
|
||||||
|
@@ -555,6 +556,9 @@ wrap_up:
|
||||||
|
static inline void stat_derive_unique (
|
||||||
|
struct hist_tic *this)
|
||||||
|
{
|
||||||
|
+ unsigned long long *new, *old;
|
||||||
|
+ int i;
|
||||||
|
+
|
||||||
|
/* note: we calculate these derived values in a manner consistent with
|
||||||
|
the calculations for cgroup accounting, as nearly as possible
|
||||||
|
( see linux sources: ./kernel/cgroup/rstat.c, root_cgroup_cputime ) */
|
||||||
|
@@ -576,13 +580,15 @@ static inline void stat_derive_unique (
|
||||||
|
this->new.xbsy
|
||||||
|
= this->new.xtot - this->new.xidl;
|
||||||
|
|
||||||
|
- // don't distort deltas when cpus are taken offline or brought online
|
||||||
|
- if (this->new.xusr < this->old.xusr
|
||||||
|
- || (this->new.xsys < this->old.xsys)
|
||||||
|
- || (this->new.xidl < this->old.xidl)
|
||||||
|
- || (this->new.xbsy < this->old.xbsy)
|
||||||
|
- || (this->new.xtot < this->old.xtot))
|
||||||
|
- memcpy(&this->old, &this->new, sizeof(struct stat_jifs));
|
||||||
|
+ // don't distort results when cpus are brought back online
|
||||||
|
+ new = (unsigned long long *)&this->new;
|
||||||
|
+ old = (unsigned long long *)&this->old;
|
||||||
|
+ for (i = 0; i < sizeof(struct stat_jifs) / sizeof(unsigned long long); i++) {
|
||||||
|
+ if (*(new++) < *(old++)) {
|
||||||
|
+ memcpy(&this->old, &this->new, sizeof(struct stat_jifs));
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
} // end: stat_derive_unique
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
2.33.0
|
||||||
|
|
||||||
@ -1,6 +1,6 @@
|
|||||||
Name: procps-ng
|
Name: procps-ng
|
||||||
Version: 4.0.4
|
Version: 4.0.4
|
||||||
Release: 1
|
Release: 2
|
||||||
Summary: Utilities that provide system information.
|
Summary: Utilities that provide system information.
|
||||||
License: GPL+ and GPLv2 and GPLv2+ and GPLv3+ and LGPLv2+
|
License: GPL+ and GPLv2 and GPLv2+ and GPLv3+ and LGPLv2+
|
||||||
URL: https://sourceforge.net/projects/procps-ng/
|
URL: https://sourceforge.net/projects/procps-ng/
|
||||||
@ -11,6 +11,7 @@ Source2: README.top
|
|||||||
|
|
||||||
Patch1: openeuler-add-M-and-N-options-for-top.patch
|
Patch1: openeuler-add-M-and-N-options-for-top.patch
|
||||||
Patch2: openeuler-top-exit-with-error-when-pid-overflow.patch
|
Patch2: openeuler-top-exit-with-error-when-pid-overflow.patch
|
||||||
|
Patch3: backport-library-address-remaining-cpu-distortions-stat-api.patch
|
||||||
|
|
||||||
BuildRequires: ncurses-devel libtool autoconf automake gcc gettext-devel systemd-devel
|
BuildRequires: ncurses-devel libtool autoconf automake gcc gettext-devel systemd-devel
|
||||||
|
|
||||||
@ -93,6 +94,9 @@ ln -s %{_bindir}/pidof %{buildroot}%{_sbindir}/pidof
|
|||||||
%{_mandir}/man*
|
%{_mandir}/man*
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Tue Apr 02 2024 Liu Chao <liuchao173@huawei.com> - 4.0.4-2
|
||||||
|
- library: address remaining cpu distortions, <stat> api
|
||||||
|
|
||||||
* Wed Nov 01 2023 liweigang <weigangli99@gmail.com> - 4.0.4-1
|
* Wed Nov 01 2023 liweigang <weigangli99@gmail.com> - 4.0.4-1
|
||||||
- update to version v4.0.4
|
- update to version v4.0.4
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user