2020-11-09 05:23:58 +01:00
|
|
|
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
2013-09-24 00:23:35 +02:00
|
|
|
|
|
|
|
#include "acpi-fpdt.h"
|
2015-11-16 22:09:36 +01:00
|
|
|
#include "boot-timestamps.h"
|
2019-08-01 16:28:29 +02:00
|
|
|
#include "efi-loader.h"
|
2015-12-03 21:13:37 +01:00
|
|
|
#include "macro.h"
|
|
|
|
#include "time-util.h"
|
2013-09-24 00:23:35 +02:00
|
|
|
|
|
|
|
int boot_timestamps(const dual_timestamp *n, dual_timestamp *firmware, dual_timestamp *loader) {
|
2014-02-19 17:47:11 +01:00
|
|
|
usec_t x = 0, y = 0, a;
|
2013-09-24 00:23:35 +02:00
|
|
|
int r;
|
|
|
|
dual_timestamp _n;
|
|
|
|
|
|
|
|
assert(firmware);
|
|
|
|
assert(loader);
|
|
|
|
|
|
|
|
if (!n) {
|
|
|
|
dual_timestamp_get(&_n);
|
|
|
|
n = &_n;
|
|
|
|
}
|
|
|
|
|
|
|
|
r = acpi_get_boot_usec(&x, &y);
|
|
|
|
if (r < 0) {
|
|
|
|
r = efi_loader_get_boot_usec(&x, &y);
|
|
|
|
if (r < 0)
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Let's convert this to timestamps where the firmware
|
|
|
|
* began/loader began working. To make this more confusing:
|
|
|
|
* since usec_t is unsigned and the kernel's monotonic clock
|
|
|
|
* begins at kernel initialization we'll actually initialize
|
|
|
|
* the monotonic timestamps here as negative of the actual
|
|
|
|
* value. */
|
|
|
|
|
|
|
|
firmware->monotonic = y;
|
|
|
|
loader->monotonic = y - x;
|
|
|
|
|
|
|
|
a = n->monotonic + firmware->monotonic;
|
|
|
|
firmware->realtime = n->realtime > a ? n->realtime - a : 0;
|
|
|
|
|
|
|
|
a = n->monotonic + loader->monotonic;
|
|
|
|
loader->realtime = n->realtime > a ? n->realtime - a : 0;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|