On Fri, 19-Dec-2025 at 20:37:41 +0000, Jamie Landeg-Jones wrote:
> void <[email protected]> wrote:
>
> >...
> > and so dmsg has things like
> >
> > [1353919] swp_pager_getswapspace(32): failed
> >
> > the [1353919] I guess being the timestamp.
> >
> > ...
> >
> Yes! You can get the value from sysctl kern.boottime.
>
> Here is a small program I wrote a while back, just call it
> as a dmesg substitute.
> ...
> Cheers, Jamie
>
> #!/bin/sh -efu
> set -efu
>
> boottime="$(/sbin/sysctl -n kern.boottime | /usr/local/bin/gawk '{printf
> "%d", gensub ("^.* sec = ([1-9][0-9]*), .*$", "\\1", 1)}')"
>
> [ -z "$(printf '%s' "$boottime" | /usr/bin/egrep '^0$|^[1-9][0-9]*$')" ] && {
> printf 'Invalid boottime retrieved.\n' >& 2; exit 1; }
>
> /sbin/dmesg "$@" | /usr/local/bin/gawk -v boottime="$boottime" '
>
> {
> uptime = gensub ("^\\[([1-9][0-9]*)\\] .*$", "\\1", 1)
> if (uptime == $0) realtime = "??? ?? ??:??;??"
> else realtime = strftime ("%b %d %T", uptime + boottime)
>
> print realtime " " $0
> }'
FWIW, this is a patch for dmesg(1) I use. You can enable timestamp
conversion using -t and optionally specify a different output format
using -f "fmt".
If interested for inclusion in base, I could try to re-format it
and come up with a manpage diff...
--- sbin/dmesg/dmesg.c 2023-12-27 17:49:57.000000000 +0100
+++ sbin/dmesg/dmesg.c 2026-01-22 09:20:28.987020000 +0100
@@ -60,6 +60,7 @@
#include <unistd.h>
#include <vis.h>
#include <sys/syslog.h>
+#include <time.h>
static struct nlist nl[] = {
#define X_MSGBUF 0
@@ -76,18 +77,23 @@
main(int argc, char *argv[])
{
struct msgbuf *bufp, cur;
+ struct timeval boottime;
+ char timebuf[64];
char *bp, *ep, *memf, *nextp, *nlistf, *p, *q, *visbp;
+ const char *timefmt = "%d %b %T";
kvm_t *kd;
+ time_t time;
size_t buflen, bufpos;
long pri;
- int ch, clear;
+ int ch, clear, timeconv;
bool all;
all = false;
clear = false;
+ timeconv = false;
(void) setlocale(LC_CTYPE, "");
memf = nlistf = NULL;
- while ((ch = getopt(argc, argv, "acM:N:")) != -1)
+ while ((ch = getopt(argc, argv, "actf:M:N:")) != -1)
switch(ch) {
case 'a':
all = true;
@@ -95,6 +101,12 @@
case 'c':
clear = true;
break;
+ case 't':
+ timeconv = true;
+ break;
+ case 'f':
+ timefmt = optarg;
+ break;
case 'M':
memf = optarg;
break;
@@ -109,6 +121,13 @@
if (argc != 0)
usage();
+ if( timeconv ) {
+ int mib[6] = { CTL_KERN, KERN_BOOTTIME };
+ size_t l = sizeof boottime;
+ if (sysctl(mib, 2, &boottime, &l, 0, 0) < 0)
+ err(1, "sysctl kern.boottime");
+ }
+
if (memf == NULL) {
/*
* Running kernel. Use sysctl. This gives an unwrapped buffer
@@ -200,7 +219,22 @@
}
(void)strvisx(visbp, p, nextp - p, 0);
- (void)printf("%s", visbp);
+ bufpos = strspn( visbp+1, "0123456789" ) + 1;
+ if( timeconv != true
+ || bufpos < 2
+ || visbp[0] != '['
+ || visbp[bufpos] != ']'
+ || visbp[bufpos+1] != ' ' ) {
+ (void)printf("%s", visbp);
+ continue;
+ }
+
+ visbp[bufpos] = '\0';
+ time = boottime.tv_sec + strtoull( visbp+1, NULL, 10 );
+ if( strftime( timebuf, sizeof timebuf, timefmt, localtime(
&time ) ) != 0 )
+ (void)printf( "[%s]%s", timebuf, visbp + bufpos + 1 );
+ else
+ (void)printf("%s", visbp);
}
exit(0);
}
@@ -208,6 +242,6 @@
void
usage(void)
{
- fprintf(stderr, "usage: dmesg [-ac] [-M core [-N system]]\n");
+ fprintf(stderr, "usage: dmesg [-ac] [-t [-f output_fmt]] [-M core [-N
system]]\n");
exit(1);
}
-Andre