timestamps: Mostly remove struct timestamp_cache
Change-Id: Ifcd75630e562af302312f93bdf180aa90f18d21d Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/35290 Reviewed-by: Julius Werner <jwerner@chromium.org> Reviewed-by: Werner Zeh <werner.zeh@siemens.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
72e634fa73
commit
3c559e791f
1 changed files with 13 additions and 16 deletions
|
@ -58,25 +58,25 @@ static struct timestamp_cache timestamp_cache;
|
||||||
as CBMEM comes available. */
|
as CBMEM comes available. */
|
||||||
static struct timestamp_table *glob_ts_table CAR_GLOBAL;
|
static struct timestamp_table *glob_ts_table CAR_GLOBAL;
|
||||||
|
|
||||||
static void timestamp_cache_init(struct timestamp_cache *ts_cache,
|
static void timestamp_cache_init(struct timestamp_table *ts_cache,
|
||||||
uint64_t base)
|
uint64_t base)
|
||||||
{
|
{
|
||||||
ts_cache->table.num_entries = 0;
|
ts_cache->num_entries = 0;
|
||||||
ts_cache->table.max_entries = MAX_BSS_TIMESTAMP_CACHE;
|
ts_cache->max_entries = MAX_BSS_TIMESTAMP_CACHE;
|
||||||
ts_cache->table.base_time = base;
|
ts_cache->base_time = base;
|
||||||
|
|
||||||
if (USE_TIMESTAMP_REGION)
|
if (USE_TIMESTAMP_REGION)
|
||||||
ts_cache->table.max_entries = (REGION_SIZE(timestamp) -
|
ts_cache->max_entries = (REGION_SIZE(timestamp) -
|
||||||
offsetof(struct timestamp_cache, entries))
|
offsetof(struct timestamp_table, entries))
|
||||||
/ sizeof(struct timestamp_entry);
|
/ sizeof(struct timestamp_entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct timestamp_cache *timestamp_cache_get(void)
|
static struct timestamp_table *timestamp_cache_get(void)
|
||||||
{
|
{
|
||||||
struct timestamp_cache *ts_cache = NULL;
|
struct timestamp_table *ts_cache = NULL;
|
||||||
|
|
||||||
if (TIMESTAMP_CACHE_IN_BSS) {
|
if (TIMESTAMP_CACHE_IN_BSS) {
|
||||||
ts_cache = ×tamp_cache;
|
ts_cache = ×tamp_cache.table;
|
||||||
} else if (USE_TIMESTAMP_REGION) {
|
} else if (USE_TIMESTAMP_REGION) {
|
||||||
if (REGION_SIZE(timestamp) < sizeof(*ts_cache))
|
if (REGION_SIZE(timestamp) < sizeof(*ts_cache))
|
||||||
BUG();
|
BUG();
|
||||||
|
@ -122,17 +122,14 @@ static int timestamp_should_run(void)
|
||||||
static struct timestamp_table *timestamp_table_get(void)
|
static struct timestamp_table *timestamp_table_get(void)
|
||||||
{
|
{
|
||||||
struct timestamp_table *ts_table;
|
struct timestamp_table *ts_table;
|
||||||
struct timestamp_cache *ts_cache;
|
|
||||||
|
|
||||||
ts_table = car_get_ptr(glob_ts_table);
|
ts_table = car_get_ptr(glob_ts_table);
|
||||||
if (ts_table)
|
if (ts_table)
|
||||||
return ts_table;
|
return ts_table;
|
||||||
|
|
||||||
ts_cache = timestamp_cache_get();
|
ts_table = timestamp_cache_get();
|
||||||
if (ts_cache)
|
|
||||||
ts_table = &ts_cache->table;
|
|
||||||
|
|
||||||
car_set_ptr(glob_ts_table, ts_table);
|
car_set_ptr(glob_ts_table, ts_table);
|
||||||
|
|
||||||
return ts_table;
|
return ts_table;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -196,7 +193,7 @@ void timestamp_add_now(enum timestamp_id id)
|
||||||
|
|
||||||
void timestamp_init(uint64_t base)
|
void timestamp_init(uint64_t base)
|
||||||
{
|
{
|
||||||
struct timestamp_cache *ts_cache;
|
struct timestamp_table *ts_cache;
|
||||||
|
|
||||||
assert(ENV_ROMSTAGE_OR_BEFORE);
|
assert(ENV_ROMSTAGE_OR_BEFORE);
|
||||||
|
|
||||||
|
@ -211,7 +208,7 @@ void timestamp_init(uint64_t base)
|
||||||
}
|
}
|
||||||
|
|
||||||
timestamp_cache_init(ts_cache, base);
|
timestamp_cache_init(ts_cache, base);
|
||||||
timestamp_table_set(&ts_cache->table);
|
timestamp_table_set(ts_cache);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void timestamp_sync_cache_to_cbmem(struct timestamp_table *ts_cbmem_table)
|
static void timestamp_sync_cache_to_cbmem(struct timestamp_table *ts_cbmem_table)
|
||||||
|
|
Loading…
Reference in a new issue