patch to move coreboot table code into libpayload. Allows payloads
using libpayload to access coreboot tables.

Signed-Off-By: Sean Nelson <[EMAIL PROTECTED]>

---

patch for coreinfo, coming next message.
Index: include/libpayload.h
===================================================================
--- include/libpayload.h	(revision 3501)
+++ include/libpayload.h	(working copy)
@@ -37,6 +37,7 @@
 #include <stdarg.h>
 #include <lar.h>
 #include <pci.h>
+#include <coreboot_tables.h>
 
 #define MIN(a,b) ((a) < (b) ? (a) : (b))
 #define MAX(a,b) ((a) > (b) ? (a) : (b))
@@ -84,6 +85,19 @@
 	int tm_isdst;
 };
 
+/* drivers/cbtables.c */
+int coreboot_tables_init(void);
+struct {
+	int mem_count;
+	int mem_actual;
+	struct cb_memory_range range[MAX_MEMORY_COUNT];
+	char vendor[32];
+	char part[32];
+	char strings[10][64];
+	struct cb_serial serial;
+	struct cb_console console;
+} cb_info;
+
 /* drivers/nvram.c */
 u8 nvram_read(u8 addr);
 void nvram_write(u8 val, u8 addr);
Index: include/coreboot_tables.h
===================================================================
--- include/coreboot_tables.h	(revision 3501)
+++ include/coreboot_tables.h	(working copy)
@@ -32,6 +32,8 @@
 
 #include <arch/types.h>
 
+#define MAX_MEMORY_COUNT 5
+
 struct cbuint64 {
 	u32 lo;
 	u32 hi;
Index: drivers/cbtables.c
===================================================================
--- drivers/cbtables.c	(revision 0)
+++ drivers/cbtables.c	(revision 0)
@@ -0,0 +1,151 @@
+/*
+ * This file is part of the coreinfo project.
+ *
+ * Copyright (C) 2008 Sean Nelson <[EMAIL PROTECTED]>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; version 2 of the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
+ */
+
+#include <libpayload.h>
+
+static void parse_memory(unsigned char *ptr)
+{
+	struct cb_memory *mem = (struct cb_memory *)ptr;
+	int max = (MEM_RANGE_COUNT(mem) > MAX_MEMORY_COUNT)
+	    ? MAX_MEMORY_COUNT : MEM_RANGE_COUNT(mem);
+	int i;
+
+	for (i = 0; i < max; i++) {
+		struct cb_memory_range *range =
+		    (struct cb_memory_range *)MEM_RANGE_PTR(mem, i);
+
+		memcpy(&cb_info.range[i], range, sizeof(*range));
+	}
+
+	cb_info.mem_count = max;
+	cb_info.mem_actual = MEM_RANGE_COUNT(mem);
+}
+
+static void parse_mainboard(unsigned char *ptr)
+{
+	struct cb_mainboard *mb = (struct cb_mainboard *)ptr;
+
+	strncpy(cb_info.vendor, (const char *)MB_VENDOR_STRING(mb), 31);
+	strncpy(cb_info.part, (const char *)MB_PART_STRING(mb), 31);
+}
+
+static void parse_strings(unsigned char *ptr)
+{
+	struct cb_string *string = (struct cb_string *)ptr;
+	int index = string->tag - CB_TAG_VERSION;
+
+	strncpy(cb_info.strings[index], (const char *)string->string, 63);
+	cb_info.strings[index][63] = 0;
+}
+
+static void parse_serial(unsigned char *ptr)
+{
+	memcpy(&cb_info.serial, (struct cb_serial *)ptr,
+	       sizeof(struct cb_serial));
+}
+
+static void parse_console(unsigned char *ptr)
+{
+	memcpy(&cb_info.console, (struct cb_console *)ptr,
+	       sizeof(struct cb_console));
+}
+
+static int parse_header(void *addr, int len)
+{
+	struct cb_header *header;
+	unsigned char *ptr = (unsigned char *)addr;
+	int i;
+
+	for (i = 0; i < len; i += 16, ptr += 16) {
+		header = (struct cb_header *)ptr;
+
+		if (!strncmp((const char *)header->signature, "LBIO", 4))
+			break;
+	}
+
+	/* We walked the entire space and didn't find anything. */
+	if (i >= len)
+		return -1;
+
+	if (!header->table_bytes)
+		return 0;
+
+	/* FIXME: Check the checksum. */
+
+	if (ipchksum((uint16_t *) header, sizeof(*header)))
+		return -1;
+
+	if (ipchksum((uint16_t *) (ptr + sizeof(*header)), header->table_bytes)
+	    != header->table_checksum)
+		return -1;
+
+	/* Now, walk the tables. */
+	ptr += header->header_bytes;
+
+	for (i = 0; i < header->table_entries; i++) {
+		struct cb_record *rec = (struct cb_record *)ptr;
+
+		switch (rec->tag) {
+		case CB_TAG_MEMORY:
+			parse_memory(ptr);
+			break;
+		case CB_TAG_MAINBOARD:
+			parse_mainboard(ptr);
+			break;
+		case CB_TAG_VERSION:
+		case CB_TAG_EXTRA_VERSION:
+		case CB_TAG_BUILD:
+		case CB_TAG_COMPILE_TIME:
+		case CB_TAG_COMPILE_BY:
+		case CB_TAG_COMPILE_HOST:
+		case CB_TAG_COMPILE_DOMAIN:
+		case CB_TAG_COMPILER:
+		case CB_TAG_LINKER:
+		case CB_TAG_ASSEMBLER:
+			parse_strings(ptr);
+			break;
+		case CB_TAG_SERIAL:
+			parse_serial(ptr);
+			break;
+		case CB_TAG_CONSOLE:
+			parse_console(ptr);
+			break;
+		default:
+			break;
+		}
+
+		ptr += rec->size;
+	}
+
+	return 1;
+}
+
+int coreboot_tables_init(void)
+{
+	int tables_good = 0;
+	
+	int ret = parse_header((void *)0x00000, 0x1000);
+
+	if (ret != 1)
+		ret = parse_header((void *)0xf0000, 0x1000);
+
+	/* Return error if we couldn't find it at either address. */
+	tables_good = (ret == 1) ? 0 : -1;
+	return tables_good;
+}
Index: drivers/Makefile.inc
===================================================================
--- drivers/Makefile.inc	(revision 3501)
+++ drivers/Makefile.inc	(working copy)
@@ -29,6 +29,8 @@
 ## SUCH DAMAGE.
 ##
 
+TARGETS-y += drivers/cbtables.o
+
 TARGETS-$(CONFIG_PCI) += drivers/pci.o
 
 TARGETS-$(CONFIG_SPEAKER) += drivers/speaker.o
--
coreboot mailing list
[email protected]
http://www.coreboot.org/mailman/listinfo/coreboot

Reply via email to