mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-12 08:00:09 +00:00
tools: bpftool: improve accuracy of load time
BPF program load time is reported from the kernel relative to boot time. If conversion to wall clock does not take nanosecond parts into account, the load time reported by bpftool may differ by one second from run to run. This means JSON object reported by bpftool for a program will randomly change. Fixes: 71bb428fe2c1 ("tools: bpf: add bpftool") Signed-off-by: Jakub Kicinski <jakub.kicinski@netronome.com> Reviewed-by: Quentin Monnet <quentin.monnet@netronome.com> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
This commit is contained in:
parent
3bce593ac0
commit
07480cbc05
@ -90,7 +90,9 @@ static void print_boot_time(__u64 nsecs, char *buf, unsigned int size)
|
|||||||
}
|
}
|
||||||
|
|
||||||
wallclock_secs = (real_time_ts.tv_sec - boot_time_ts.tv_sec) +
|
wallclock_secs = (real_time_ts.tv_sec - boot_time_ts.tv_sec) +
|
||||||
nsecs / 1000000000;
|
(real_time_ts.tv_nsec - boot_time_ts.tv_nsec + nsecs) /
|
||||||
|
1000000000;
|
||||||
|
|
||||||
|
|
||||||
if (!localtime_r(&wallclock_secs, &load_tm)) {
|
if (!localtime_r(&wallclock_secs, &load_tm)) {
|
||||||
snprintf(buf, size, "%llu", nsecs / 1000000000);
|
snprintf(buf, size, "%llu", nsecs / 1000000000);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user