Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 17 Oct 2021 20:42:31 GMT
From:      Colin Percival <cperciva@FreeBSD.org>
To:        src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org
Subject:   git: 52e125c2bd30 - main - TSLOG: Report final execname, not first
Message-ID:  <202110172042.19HKgVRZ068353@gitrepo.freebsd.org>

next in thread | raw e-mail | index | archive | help
The branch main has been updated by cperciva:

URL: https://cgit.FreeBSD.org/src/commit/?id=52e125c2bd302982c179ecc920cc9a6e166033d6

commit 52e125c2bd302982c179ecc920cc9a6e166033d6
Author:     Colin Percival <cperciva@FreeBSD.org>
AuthorDate: 2021-10-17 20:36:38 +0000
Commit:     Colin Percival <cperciva@FreeBSD.org>
CommitDate: 2021-10-17 20:36:38 +0000

    TSLOG: Report final execname, not first
    
    In cases such as daemons launched via limits(1), a process may call
    exec multiple times; the last name of the last binary executed is
    usually (always?) more informative.
    
    Fixes:  46dd801acb23 Add userland boot profiling to TSLOG
    Sponsored by:   https://www.patreon.com/cperciva
---
 sys/kern/kern_tslog.c | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/sys/kern/kern_tslog.c b/sys/kern/kern_tslog.c
index 38c91911ec08..0e7ad3c9ff23 100644
--- a/sys/kern/kern_tslog.c
+++ b/sys/kern/kern_tslog.c
@@ -169,8 +169,9 @@ tslog_user(pid_t pid, pid_t ppid, const char * execname, const char * namei)
 
 	/* If we have an execname, record it. */
 	if (execname != NULL) {
-		if (procs[pid].execname == NULL)
-			procs[pid].execname = strdup(execname, M_TSLOGUSER);
+		if (procs[pid].execname != NULL)
+			free(procs[pid].execname, M_TSLOGUSER);
+		procs[pid].execname = strdup(execname, M_TSLOGUSER);
 		return;
 	}
 



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202110172042.19HKgVRZ068353>