| // SPDX-License-Identifier: GPL-2.0+ |
| * This file is part of the coreboot project. |
| * Copyright (C) 2011 The ChromiumOS Authors. All rights reserved. |
| #include <asm/arch/timestamp.h> |
| #include <asm/arch/sysinfo.h> |
| #include <linux/compiler.h> |
| struct timestamp_entry entries[0]; /* Variable number of entries */ |
| static struct timestamp_table *ts_table __attribute__((section(".data"))); |
| void timestamp_init(void) |
| timestamp_add_now(TS_U_BOOT_INITTED); |
| void timestamp_add(enum timestamp_id id, uint64_t ts_time) |
| struct timestamp_entry *tse; |
| if (!ts_table || (ts_table->num_entries == ts_table->max_entries)) |
| tse = &ts_table->entries[ts_table->num_entries++]; |
| tse->entry_stamp = ts_time - ts_table->base_time; |
| void timestamp_add_now(enum timestamp_id id) |
| timestamp_add(id, rdtsc()); |
| int timestamp_add_to_bootstage(void) |
| for (i = 0; i < ts_table->num_entries; i++) { |
| struct timestamp_entry *tse = &ts_table->entries[i]; |
| case TS_DEVICE_INITIALIZE: |
| name = "device-initialize"; |
| bootstage_add_record(0, name, BOOTSTAGEF_ALLOC, |