> From: Stephen Hemminger [mailto:step...@networkplumber.org]
> Sent: Monday, 18 March 2024 23.03
> 
> When debugging driver or startup issues, it is useful to have
> a timestamp on each message printed. The messages in syslog
> already have a timestamp, but often syslog is not available
> during testing. The timestamp format is chosen to look
> like the default Linux dmesg timestamp.
> 
> The first few lines are not timestamped because the flag is stored
> in internal configuration which is stored in shared memory
> which is not setup up until a little later in startup process.
> 
> This logging skips the unnecessary step of going through stdio,
> which makes it more robust against being called in interrupt
> handlers etc.
> 
> Example:
> $ dpdk-testpmd --log-timestamp -- -i
> EAL: Detected CPU lcores: 16
> EAL: Detected NUMA nodes: 1
> EAL: Detected static linkage of DPDK
> EAL: Multi-process socket /var/run/dpdk/rte/mp_socket
> EAL: Selected IOVA mode 'VA'
> [       0.112264] testpmd: No probed ethernet devices
> Interactive-mode selected
> [       0.184573] testpmd: create a new mbuf pool <mb_pool_0>: n=163456,
> size=2176, socket=0
> [       0.184612] testpmd: preferred mempool ops selected: ring_mp_mc
> 
> Signed-off-by: Stephen Hemminger <step...@networkplumber.org>
> ---

[...]

>  static ssize_t
>  console_log_write(__rte_unused void *c, const char *buf, size_t size)
>  {
> +     struct timespec ts;
>       ssize_t ret;
> 
> -     /* write on stderr */
> -     ret = fwrite(buf, 1, size, stderr);
> +     if (timestamp_enabled) {
> +             clock_gettime(CLOCK_MONOTONIC, &ts);
> +             ts.tv_sec -= log_started.tv_sec;
> +             ts.tv_nsec -= log_started.tv_nsec;

Please log the absolute CLOCK_MONOTONIC instead of subtracting log_started, so 
timestamps can be easily compared with timestamps from other processes.

> +             if (ts.tv_nsec < 0) {
> +                     --ts.tv_sec;
> +                     ts.tv_nsec += 1000000000ul;
> +             }
> +
> +             ret = fprintf(stderr, "[%8lu.%06lu] %.*s",
> +                           ts.tv_sec, ts.tv_nsec / 1000u,
> +                           (int) size, buf);

With the above change,
For the series,
Acked-by: Morten Brørup <m...@smartsharesystems.com>

Reply via email to