Fix #31: invalid time for kernel log messages on 32-bit machines

Signed-off-by: Joachim Wiberg <troglobit@gmail.com>
This commit is contained in:
Joachim Wiberg 2021-05-05 03:03:01 +02:00
parent d722584191
commit 4ab8bc7b40

View File

@ -1099,6 +1099,7 @@ void printsys(char *msg)
{ {
struct buf_msg buffer; struct buf_msg buffer;
char line[MAXLINE + 1]; char line[MAXLINE + 1];
uint64_t ustime = 0;
uint64_t seqno = 0; uint64_t seqno = 0;
char *lp, *p, *q; char *lp, *p, *q;
int c; int c;
@ -1137,9 +1138,9 @@ void printsys(char *msg)
/* timestamp */ /* timestamp */
while (isdigit(*p)) while (isdigit(*p))
buffer.timestamp.usec = 10 * buffer.timestamp.usec + (*p++ - '0'); ustime = 10 * ustime + (*p++ - '0');
now += buffer.timestamp.usec / 1000000; now += ustime / 1000000;
buffer.timestamp.usec = buffer.timestamp.usec % 1000000; buffer.timestamp.usec = ustime % 1000000;
localtime_r(&now, &buffer.timestamp.tm); localtime_r(&now, &buffer.timestamp.tm);
/* skip flags for now */ /* skip flags for now */