timestamps: Use stash before CBMEM is usable
Change-Id: I9e927abdb1d7d9c233de5620a9a65b419e803ebf Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: http://review.coreboot.org/3909 Tested-by: build bot (Jenkins) Reviewed-by: Paul Menzel <paulepanter@users.sourceforge.net> Reviewed-by: Aaron Durbin <adurbin@google.com>
This commit is contained in:
parent
e28bd4ade6
commit
b766b1c76a
|
@ -59,14 +59,12 @@ enum timestamp_id {
|
||||||
void timestamp_init(tsc_t base);
|
void timestamp_init(tsc_t base);
|
||||||
void timestamp_add(enum timestamp_id id, tsc_t ts_time);
|
void timestamp_add(enum timestamp_id id, tsc_t ts_time);
|
||||||
void timestamp_add_now(enum timestamp_id id);
|
void timestamp_add_now(enum timestamp_id id);
|
||||||
void timestamp_stash(enum timestamp_id id);
|
|
||||||
void timestamp_sync(void);
|
void timestamp_sync(void);
|
||||||
tsc_t get_initial_timestamp(void);
|
tsc_t get_initial_timestamp(void);
|
||||||
#else
|
#else
|
||||||
#define timestamp_init(base)
|
#define timestamp_init(base)
|
||||||
#define timestamp_add(id, time)
|
#define timestamp_add(id, time)
|
||||||
#define timestamp_add_now(id)
|
#define timestamp_add_now(id)
|
||||||
#define timestamp_stash(id)
|
|
||||||
#define timestamp_sync()
|
#define timestamp_sync()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -126,7 +126,7 @@ static boot_state_t bs_pre_device(void *arg)
|
||||||
|
|
||||||
static boot_state_t bs_dev_init_chips(void *arg)
|
static boot_state_t bs_dev_init_chips(void *arg)
|
||||||
{
|
{
|
||||||
timestamp_stash(TS_DEVICE_ENUMERATE);
|
timestamp_add_now(TS_DEVICE_ENUMERATE);
|
||||||
|
|
||||||
/* Initialize chips early, they might disable unused devices. */
|
/* Initialize chips early, they might disable unused devices. */
|
||||||
dev_initialize_chips();
|
dev_initialize_chips();
|
||||||
|
@ -145,7 +145,7 @@ static boot_state_t bs_dev_enumerate(void *arg)
|
||||||
|
|
||||||
static boot_state_t bs_dev_resources(void *arg)
|
static boot_state_t bs_dev_resources(void *arg)
|
||||||
{
|
{
|
||||||
timestamp_stash(TS_DEVICE_CONFIGURE);
|
timestamp_add_now(TS_DEVICE_CONFIGURE);
|
||||||
/* Now compute and assign the bus resources. */
|
/* Now compute and assign the bus resources. */
|
||||||
dev_configure();
|
dev_configure();
|
||||||
post_code(POST_DEVICE_CONFIGURATION_COMPLETE);
|
post_code(POST_DEVICE_CONFIGURATION_COMPLETE);
|
||||||
|
@ -155,7 +155,7 @@ static boot_state_t bs_dev_resources(void *arg)
|
||||||
|
|
||||||
static boot_state_t bs_dev_enable(void *arg)
|
static boot_state_t bs_dev_enable(void *arg)
|
||||||
{
|
{
|
||||||
timestamp_stash(TS_DEVICE_ENABLE);
|
timestamp_add_now(TS_DEVICE_ENABLE);
|
||||||
/* Now actually enable devices on the bus */
|
/* Now actually enable devices on the bus */
|
||||||
dev_enable();
|
dev_enable();
|
||||||
post_code(POST_DEVICES_ENABLED);
|
post_code(POST_DEVICES_ENABLED);
|
||||||
|
@ -165,7 +165,7 @@ static boot_state_t bs_dev_enable(void *arg)
|
||||||
|
|
||||||
static boot_state_t bs_dev_init(void *arg)
|
static boot_state_t bs_dev_init(void *arg)
|
||||||
{
|
{
|
||||||
timestamp_stash(TS_DEVICE_INITIALIZE);
|
timestamp_add_now(TS_DEVICE_INITIALIZE);
|
||||||
/* And of course initialize devices on the bus */
|
/* And of course initialize devices on the bus */
|
||||||
dev_initialize();
|
dev_initialize();
|
||||||
post_code(POST_DEVICES_INITIALIZED);
|
post_code(POST_DEVICES_INITIALIZED);
|
||||||
|
@ -175,7 +175,7 @@ static boot_state_t bs_dev_init(void *arg)
|
||||||
|
|
||||||
static boot_state_t bs_post_device(void *arg)
|
static boot_state_t bs_post_device(void *arg)
|
||||||
{
|
{
|
||||||
timestamp_stash(TS_DEVICE_DONE);
|
timestamp_add_now(TS_DEVICE_DONE);
|
||||||
|
|
||||||
timestamp_sync();
|
timestamp_sync();
|
||||||
|
|
||||||
|
@ -446,7 +446,10 @@ static void boot_state_schedule_static_entries(void)
|
||||||
|
|
||||||
void main(void)
|
void main(void)
|
||||||
{
|
{
|
||||||
timestamp_stash(TS_START_RAMSTAGE);
|
/* Record current time, try to locate timestamps in CBMEM. */
|
||||||
|
timestamp_init(rdtsc());
|
||||||
|
|
||||||
|
timestamp_add_now(TS_START_RAMSTAGE);
|
||||||
post_code(POST_ENTRY_RAMSTAGE);
|
post_code(POST_ENTRY_RAMSTAGE);
|
||||||
|
|
||||||
/* console_init() MUST PRECEDE ALL printk()! */
|
/* console_init() MUST PRECEDE ALL printk()! */
|
||||||
|
|
|
@ -17,27 +17,26 @@
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA, 02110-1301 USA
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA, 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <cbmem.h>
|
#include <cbmem.h>
|
||||||
#include <timestamp.h>
|
#include <timestamp.h>
|
||||||
#ifndef __PRE_RAM__
|
|
||||||
/* For CAR_GLOBAL... This should move out of x86 specific code */
|
|
||||||
#include <cpu/x86/car.h>
|
#include <cpu/x86/car.h>
|
||||||
#endif
|
|
||||||
|
|
||||||
#define MAX_TIMESTAMPS 30
|
#define MAX_TIMESTAMPS 30
|
||||||
|
|
||||||
#ifndef __PRE_RAM__
|
static struct timestamp_table* ts_table CAR_GLOBAL = NULL;
|
||||||
static struct timestamp_table* ts_table;
|
static tsc_t ts_basetime CAR_GLOBAL = { .lo = 0, .hi =0 };
|
||||||
#endif
|
|
||||||
|
static void timestamp_stash(enum timestamp_id id, tsc_t ts_time);
|
||||||
|
|
||||||
static uint64_t tsc_to_uint64(tsc_t tstamp)
|
static uint64_t tsc_to_uint64(tsc_t tstamp)
|
||||||
{
|
{
|
||||||
return (((uint64_t)tstamp.hi) << 32) + tstamp.lo;
|
return (((uint64_t)tstamp.hi) << 32) + tstamp.lo;
|
||||||
}
|
}
|
||||||
|
|
||||||
void timestamp_init(tsc_t base)
|
static void timestamp_real_init(tsc_t base)
|
||||||
{
|
{
|
||||||
struct timestamp_table* tst;
|
struct timestamp_table* tst;
|
||||||
|
|
||||||
|
@ -53,18 +52,19 @@ void timestamp_init(tsc_t base)
|
||||||
tst->base_time = tsc_to_uint64(base);
|
tst->base_time = tsc_to_uint64(base);
|
||||||
tst->max_entries = MAX_TIMESTAMPS;
|
tst->max_entries = MAX_TIMESTAMPS;
|
||||||
tst->num_entries = 0;
|
tst->num_entries = 0;
|
||||||
|
|
||||||
|
ts_table = tst;
|
||||||
}
|
}
|
||||||
|
|
||||||
void timestamp_add(enum timestamp_id id, tsc_t ts_time)
|
void timestamp_add(enum timestamp_id id, tsc_t ts_time)
|
||||||
{
|
{
|
||||||
struct timestamp_entry *tse;
|
struct timestamp_entry *tse;
|
||||||
#ifdef __PRE_RAM__
|
|
||||||
struct timestamp_table *ts_table = cbmem_find(CBMEM_ID_TIMESTAMP);
|
if (!ts_table) {
|
||||||
#else
|
timestamp_stash(id, ts_time);
|
||||||
if (!ts_table)
|
return;
|
||||||
ts_table = cbmem_find(CBMEM_ID_TIMESTAMP);
|
}
|
||||||
#endif
|
if (ts_table->num_entries == ts_table->max_entries)
|
||||||
if (!ts_table || (ts_table->num_entries == ts_table->max_entries))
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
tse = &ts_table->entries[ts_table->num_entries++];
|
tse = &ts_table->entries[ts_table->num_entries++];
|
||||||
|
@ -77,8 +77,6 @@ void timestamp_add_now(enum timestamp_id id)
|
||||||
timestamp_add(id, rdtsc());
|
timestamp_add(id, rdtsc());
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef __PRE_RAM__
|
|
||||||
|
|
||||||
#define MAX_TIMESTAMP_CACHE 8
|
#define MAX_TIMESTAMP_CACHE 8
|
||||||
struct timestamp_cache {
|
struct timestamp_cache {
|
||||||
enum timestamp_id id;
|
enum timestamp_id id;
|
||||||
|
@ -95,18 +93,18 @@ static int timestamp_entries CAR_GLOBAL = 0;
|
||||||
* ram stage main()
|
* ram stage main()
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void timestamp_stash(enum timestamp_id id)
|
static void timestamp_stash(enum timestamp_id id, tsc_t ts_time)
|
||||||
{
|
{
|
||||||
if (timestamp_entries >= MAX_TIMESTAMP_CACHE) {
|
if (timestamp_entries >= MAX_TIMESTAMP_CACHE) {
|
||||||
printk(BIOS_ERR, "ERROR: failed to add timestamp to cache\n");
|
printk(BIOS_ERR, "ERROR: failed to add timestamp to cache\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
timestamp_cache[timestamp_entries].id = id;
|
timestamp_cache[timestamp_entries].id = id;
|
||||||
timestamp_cache[timestamp_entries].time = rdtsc();
|
timestamp_cache[timestamp_entries].time = ts_time;
|
||||||
timestamp_entries++;
|
timestamp_entries++;
|
||||||
}
|
}
|
||||||
|
|
||||||
void timestamp_sync(void)
|
static void timestamp_do_sync(void)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < timestamp_entries; i++)
|
for (i = 0; i < timestamp_entries; i++)
|
||||||
|
@ -114,4 +112,30 @@ void timestamp_sync(void)
|
||||||
timestamp_entries = 0;
|
timestamp_entries = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void timestamp_init(tsc_t base)
|
||||||
|
{
|
||||||
|
#ifndef __PRE_RAM__
|
||||||
|
struct timestamp_table* tst;
|
||||||
|
|
||||||
|
/* Locate and use an already existing table. */
|
||||||
|
tst = cbmem_find(CBMEM_ID_TIMESTAMP);
|
||||||
|
if (tst) {
|
||||||
|
ts_table = tst;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
timestamp_real_init(base);
|
||||||
|
if (ts_table)
|
||||||
|
timestamp_do_sync();
|
||||||
|
else
|
||||||
|
ts_basetime = base;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef __PRE_RAM__
|
||||||
|
void timestamp_sync(void)
|
||||||
|
{
|
||||||
|
if (!ts_table)
|
||||||
|
timestamp_init(ts_basetime);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue