sb/intel/bd82x6x: Add time-stamp around ME DRAM update
Add a timestamp before and after waiting for the ME to acknowledge the DRAM being ready. This allows easier debugging during use of me_cleaner and/or alternate ME images. Change-Id: Ie228e12a75d373b4f406b3595e1fb1aab41aa5df Signed-off-by: Nathaniel Roach <nroach44@gmail.com> Reviewed-on: https://review.coreboot.org/21465 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Martin Roth <martinroth@google.com> Reviewed-by: Aaron Durbin <adurbin@chromium.org> Reviewed-by: Paul Menzel <paulepanter@users.sourceforge.net>
This commit is contained in:
parent
3670cc1bad
commit
52f0871b23
2 changed files with 11 additions and 0 deletions
|
@ -77,6 +77,10 @@ enum timestamp_id {
|
||||||
TS_END_COPYVPD_RO = 551,
|
TS_END_COPYVPD_RO = 551,
|
||||||
TS_END_COPYVPD_RW = 552,
|
TS_END_COPYVPD_RW = 552,
|
||||||
|
|
||||||
|
/* 940-950 reserved for vendorcode extensions (940-950: Intel ME) */
|
||||||
|
TS_ME_INFORM_DRAM_WAIT = 940,
|
||||||
|
TS_ME_INFORM_DRAM_DONE = 941,
|
||||||
|
|
||||||
/* 950+ reserved for vendorcode extensions (950-999: intel/fsp) */
|
/* 950+ reserved for vendorcode extensions (950-999: intel/fsp) */
|
||||||
TS_FSP_MEMORY_INIT_START = 950,
|
TS_FSP_MEMORY_INIT_START = 950,
|
||||||
TS_FSP_MEMORY_INIT_END = 951,
|
TS_FSP_MEMORY_INIT_END = 951,
|
||||||
|
@ -177,6 +181,10 @@ static const struct timestamp_id_to_name {
|
||||||
{ TS_KERNEL_DECOMPRESSION, "starting kernel decompression/relocation" },
|
{ TS_KERNEL_DECOMPRESSION, "starting kernel decompression/relocation" },
|
||||||
{ TS_START_KERNEL, "jumping to kernel" },
|
{ TS_START_KERNEL, "jumping to kernel" },
|
||||||
|
|
||||||
|
/* Intel ME related timestamps */
|
||||||
|
{ TS_ME_INFORM_DRAM_WAIT, "waiting for ME acknowledgement of raminit"},
|
||||||
|
{ TS_ME_INFORM_DRAM_DONE, "finished waiting for ME response"},
|
||||||
|
|
||||||
/* FSP related timestamps */
|
/* FSP related timestamps */
|
||||||
{ TS_FSP_MEMORY_INIT_START, "calling FspMemoryInit" },
|
{ TS_FSP_MEMORY_INIT_START, "calling FspMemoryInit" },
|
||||||
{ TS_FSP_MEMORY_INIT_END, "returning from FspMemoryInit" },
|
{ TS_FSP_MEMORY_INIT_END, "returning from FspMemoryInit" },
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
#include <halt.h>
|
#include <halt.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <timestamp.h>
|
||||||
#include "me.h"
|
#include "me.h"
|
||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
|
|
||||||
|
@ -190,6 +191,7 @@ int intel_early_me_init_done(u8 status)
|
||||||
meDID = did.uma_base | (1 << 28);// | (1 << 23);
|
meDID = did.uma_base | (1 << 28);// | (1 << 23);
|
||||||
pci_write_config32(PCI_DEV(0, 0x16, 0), PCI_ME_H_GS, meDID);
|
pci_write_config32(PCI_DEV(0, 0x16, 0), PCI_ME_H_GS, meDID);
|
||||||
|
|
||||||
|
timestamp_add_now(TS_ME_INFORM_DRAM_WAIT);
|
||||||
udelay(1100);
|
udelay(1100);
|
||||||
|
|
||||||
/* Must wait for ME acknowledgement */
|
/* Must wait for ME acknowledgement */
|
||||||
|
@ -200,6 +202,7 @@ int intel_early_me_init_done(u8 status)
|
||||||
hfs = (pci_read_config32(PCI_DEV(0, 0x16, 0), PCI_ME_HFS) & 0xfe000000) >> 24;
|
hfs = (pci_read_config32(PCI_DEV(0, 0x16, 0), PCI_ME_HFS) & 0xfe000000) >> 24;
|
||||||
millisec++;
|
millisec++;
|
||||||
}
|
}
|
||||||
|
timestamp_add_now(TS_ME_INFORM_DRAM_DONE);
|
||||||
|
|
||||||
me_fws2 = pci_read_config32(PCI_DEV(0, 0x16, 0), 0x48);
|
me_fws2 = pci_read_config32(PCI_DEV(0, 0x16, 0), 0x48);
|
||||||
printk(BIOS_NOTICE, "ME: FWS2: 0x%x\n", me_fws2);
|
printk(BIOS_NOTICE, "ME: FWS2: 0x%x\n", me_fws2);
|
||||||
|
|
Loading…
Reference in a new issue