t=1765210592; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=ZoxkXAu58ziwzl4ybgvk/aClPhaleqGq0Srn0XnEJEQ=; b=FFN9986P7v6Vw89maoJqw80fOVqEDb6ZCLKS+OPNLtzY5jIp/b7D0q/hOOZpcyxkopy7HR AUrz0S5Q+xCUYPViiwEymU5uss6ZWZXEbPlnwTEqnsgCyjJ4aLJGBouX/pzkRKNUqHXkFD MaglwU+RUIRzm5JK4nfCbuPmrvW+xmcqCJ5oVd6Zw28Y1qSw+/pgfvex2H4/UgzFBpdJ8i 5caGRRxsrGIhTqYthNSZ9jP+NxcPTu8baUyW+/fYUGwpn1++zcumzunSO2ZFjcUo0HHttE D0qKfi50/rXyZYuBTMsaRSLuJn8RVhSgAWrDkgIJ/817p3bzeL7f7HHiQMDP2w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1765210592; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=ZoxkXAu58ziwzl4ybgvk/aClPhaleqGq0Srn0XnEJEQ=; b=SY8gatNpGWlGiYz/ofs5YngfifhZEXNkLH4pST1zP6gcICPWFr3VLFYCjMJ37PDIci0PRj Tv7LGJrm1KApp7FQ/AGT2hBhdjcuvwhXM1SejiKpyjV6GShZ/rADFyXWzSJHMZIgMcczTW YZya0wPQRl99iNoABeODYpCyn6zr2e6mtiNnqkR0SMnGNbPHYL5ST2E8p9x6EZVXNhAWDZ j8SibdbLe9YdqD/8+Q6d8cmmz5lVDHZwC+eK+uISqM4wjUcnyg/jZv+tdku8Ah6Keq2Bo2 NuqyPpVggbMsjmdFmkfXiiJKp1AYAH17OYeW9muXrPbeKpcmCBhtmMQFhlzIlQ== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1765210592; a=rsa-sha256; cv=none; b=kl9tNt5ZPcVlRf3iwO3QyZNBSrDOu4QCXnbcH+6NmMeMm2bsG7AVtDrQTmR2DUvsgE6xn8 4zpara/LFkkAn1OwwnP0O29O0VVoZJQanlGdwbZ2SngeqH4CQdxJdLsayoYW/NItySMTPG E9fUxWaw8X/skvbc7anP8yUI0Xa7FQ396J2C4HNaaeu3R7h7F0gQKbSz3+HWI8Oa4CEtaw xlFwayIZ8vJ9Y3nGPHQ3H1mhmVJ6Oe4wPAZ7Bfx4aE21WYfEqIdPHiadfVaBKlbK94wh65 Jr4VNKYIKzEJqbTAUrM9kmx9y1xGIPJZqQEXUpow+Oq6e698CFxyzZHyHskmoA== ARC-Authentication-Results: i=1; mx1.freebsd.org; none Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) by mxrelay.nyi.freebsd.org (Postfix) with ESMTP id 4dQ6YX5tlrz4Bp for ; Mon, 08 Dec 2025 16:16:32 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from git (uid 1279) (envelope-from git@FreeBSD.org) id 3a8b7 by gitrepo.freebsd.org (DragonFly Mail Agent v0.13+ on gitrepo.freebsd.org); Mon, 08 Dec 2025 16:16:32 +0000 To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org From: John Baldwin Subject: git: 3f8ed605dbd0 - main - ruxreset: Add an inline function to reset all the stats in rusage_ext List-Id: Commit messages for the main branch of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-main List-Help: List-Post: List-Subscribe: List-Unsubscribe: X-BeenThere: dev-commits-src-main@freebsd.org Sender: owner-dev-commits-src-main@FreeBSD.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: jhb X-Git-Repository: src X-Git-Refname: refs/heads/main X-Git-Reftype: branch X-Git-Commit: 3f8ed605dbd0ee211ce8fe59c0c072b916d6311c Auto-Submitted: auto-generated Date: Mon, 08 Dec 2025 16:16:32 +0000 Message-Id: <6936f9e0.3a8b7.62869968@gitrepo.freebsd.org> The branch main has been updated by jhb: URL: https://cgit.FreeBSD.org/src/commit/?id=3f8ed605dbd0ee211ce8fe59c0c072b916d6311c commit 3f8ed605dbd0ee211ce8fe59c0c072b916d6311c Author: John Baldwin AuthorDate: 2025-12-08 16:15:20 +0000 Commit: John Baldwin CommitDate: 2025-12-08 16:16:13 +0000 ruxreset: Add an inline function to reset all the stats in rusage_ext Use it in proc0_post to reset per-process CPU usage. Suggested by: olce Reviewed by: olce, kib Differential Revision: https://reviews.freebsd.org/D54049 --- sys/kern/init_main.c | 5 +---- sys/sys/proc.h | 12 ++++++++++++ 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/sys/kern/init_main.c b/sys/kern/init_main.c index 3075b2224963..6495340578da 100644 --- a/sys/kern/init_main.c +++ b/sys/kern/init_main.c @@ -660,10 +660,7 @@ proc0_post(void *dummy __unused) microuptime(&p->p_stats->p_start); PROC_STATLOCK(p); rufetch(p, &ru); /* Clears thread stats */ - p->p_rux.rux_runtime = 0; - p->p_rux.rux_uticks = 0; - p->p_rux.rux_sticks = 0; - p->p_rux.rux_iticks = 0; + ruxreset(&p->p_rux); PROC_STATUNLOCK(p); FOREACH_THREAD_IN_PROC(p, td) { td->td_runtime = 0; diff --git a/sys/sys/proc.h b/sys/sys/proc.h index 23b052e21063..b27b67999e8b 100644 --- a/sys/sys/proc.h +++ b/sys/sys/proc.h @@ -1326,6 +1326,18 @@ td_get_sched(struct thread *td) return ((struct td_sched *)&td[1]); } +static __inline void +ruxreset(struct rusage_ext *rux) +{ + rux->rux_runtime = 0; + rux->rux_uticks = 0; + rux->rux_sticks = 0; + rux->rux_iticks = 0; + rux->rux_uu = 0; + rux->rux_su = 0; + rux->rux_tu = 0; +} + #define PROC_ID_PID 0 #define PROC_ID_GROUP 1 #define PROC_ID_SESSION 2