summaryrefslogtreecommitdiff
path: root/src/arch/x86
diff options
context:
space:
mode:
authorVadim Bendebury <vbendeb@chromium.org>2011-10-03 14:58:57 -0700
committerStefan Reinauer <stefan.reinauer@coreboot.org>2012-03-29 20:19:27 +0200
commit22c0468d3927a370b9723e9e78714c2731d33a81 (patch)
treee2eacd3c2bd07653ef303ed0219557bf0d222e44 /src/arch/x86
parent2e43867a20107014cba1f32137adfee8af35a05d (diff)
downloadcoreboot-22c0468d3927a370b9723e9e78714c2731d33a81.tar.xz
Refactor publishing CBMEM addresses through coreboot table.
We need to provide u-boot access to several different CBMEM sections. To do that, a common coreboot table structure is used, just different tags match different coreboot table sections. Also, the code is added to export CBMEM console and MRC cache addresses through the same mechanism. Change-Id: I63adb67093b8b50ee61b0deb0b56ebb2c4856895 Signed-off-by: Vadim Bendebury <vbendeb@chromium.org> Reviewed-on: http://review.coreboot.org/724 Tested-by: build bot (Jenkins) Reviewed-by: Ronald G. Minnich <rminnich@gmail.com>
Diffstat (limited to 'src/arch/x86')
-rw-r--r--src/arch/x86/boot/coreboot_table.c44
1 files changed, 30 insertions, 14 deletions
diff --git a/src/arch/x86/boot/coreboot_table.c b/src/arch/x86/boot/coreboot_table.c
index 53ff3d36d4..a9ff6f0f1b 100644
--- a/src/arch/x86/boot/coreboot_table.c
+++ b/src/arch/x86/boot/coreboot_table.c
@@ -179,22 +179,39 @@ static void lb_framebuffer(struct lb_header *header)
#endif
}
-#if CONFIG_COLLECT_TIMESTAMPS
-static void lb_tsamp(struct lb_header *header)
+static void add_cbmem_pointers(struct lb_header *header)
{
- struct lb_tstamp *tstamp;
- void *tstamp_table = cbmem_find(CBMEM_ID_TIMESTAMP);
+ /*
+ * These CBMEM sections' addresses are included in the coreboot table
+ * with the appropriate tags.
+ */
+ const struct section_id {
+ int cbmem_id;
+ int table_tag;
+ } section_ids[] = {
+ {CBMEM_ID_TIMESTAMP, LB_TAG_TIMESTAMPS},
+ {CBMEM_ID_CONSOLE, LB_TAG_CBMEM_CONSOLE}
+ };
+ int i;
- if (!tstamp_table)
- return;
+ for (i = 0; i < ARRAY_SIZE(section_ids); i++) {
+ const struct section_id *sid = section_ids + i;
+ struct lb_cbmem_ref *cbmem_ref;
+ void *cbmem_addr = cbmem_find(sid->cbmem_id);
- tstamp = (struct lb_tstamp *)lb_new_record(header);
- tstamp->tag = LB_TAG_TIMESTAMPS;
- tstamp->size = sizeof(*tstamp);
- tstamp->tstamp_tab = tstamp_table;
+ if (!cbmem_addr)
+ continue; /* This section is not present */
+ cbmem_ref = (struct lb_cbmem_ref *)lb_new_record(header);
+ if (!cbmem_ref) {
+ printk(BIOS_ERR, "No more room in coreboot table!\n");
+ break;
+ }
+ cbmem_ref->tag = sid->table_tag;
+ cbmem_ref->size = sizeof(*cbmem_ref);
+ cbmem_ref->cbmem_addr = cbmem_addr;
+ }
}
-#endif
static struct lb_mainboard *lb_mainboard(struct lb_header *header)
{
@@ -637,9 +654,8 @@ unsigned long write_coreboot_table(
/* Record our framebuffer */
lb_framebuffer(head);
-#if CONFIG_COLLECT_TIMESTAMPS
- lb_tsamp(head);
-#endif
+ add_cbmem_pointers(head);
+
/* Remember where my valid memory ranges are */
return lb_table_fini(head, 1);