Update Coreinfo to use TAG_FORWARD in tables.
authorMyles Watson <mylesgw@gmail.com>
Mon, 24 Aug 2009 15:25:11 +0000 (15:25 +0000)
committerMyles Watson <mylesgw@gmail.com>
Mon, 24 Aug 2009 15:25:11 +0000 (15:25 +0000)
Update the ramdump function cursor functions and make the address hex
instead of decimal

Signed-off-by: Myles Watson <mylesgw@gmail.com>
Acked-by: Ronald G. Minnich <rminnich@gmail.com>
Acked-by: Uwe Hermann <uwe@hermann-uwe.de>
Acked-by: Stefan Reinauer <stepan@coresystems.de>
git-svn-id: svn://svn.coreboot.org/coreboot/trunk@4563 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1

payloads/coreinfo/coreboot_module.c
payloads/coreinfo/ramdump_module.c

index 16a63c544df74ee975b075459ba716cdd2004ee8..c8694f460a8aeb182e09907b74ff32132bae1e9a 100644 (file)
@@ -203,6 +203,9 @@ static int parse_header(void *addr, int len)
                struct cb_record *rec = (struct cb_record *)ptr;
 
                switch (rec->tag) {
+               case CB_TAG_FORWARD:
+                       return parse_header((void *)(unsigned long)((struct cb_forward *)rec)->forward, 1);
+                       break;
                case CB_TAG_MEMORY:
                        parse_memory(ptr);
                        break;
index 04a9f0955d85442acb04eaf40eceaf0cc0d842e7..a0479eb135b1234b4b326847ae391bb64a148912 100644 (file)
@@ -34,7 +34,7 @@ static void dump_ram(WINDOW *win, uint32_t addr, int row, int col)
        int i, x = 0, y = 0, count = 0;
        volatile uint8_t *ptr = (void *)(addr);
 
-       mvwprintw(win, 0, col + 54, "RAM address: %10d", addr);
+       mvwprintw(win, 0, col + 54, "RAM address: %10x", addr);
 
        /* Dump 256 bytes of RAM. */
        for (i = 1; i < 257; i++) {
@@ -68,23 +68,21 @@ static int ramdump_module_handle(int key)
 {
        switch (key) {
        case KEY_DOWN:
-               if (cursor == cursor_max)
-                       return 0;
                cursor++;
                break;
        case KEY_UP:
-               if (cursor == 0)
-                       return 0;
                cursor--;
                break;
-       case KEY_NPAGE:
-               if (cursor == cursor_max)
-                       return 0;
-               cursor += 4096; /* Jump in 1MB steps. */
+       case KEY_RIGHT:
+               cursor += 256;
+               break;
+       case KEY_LEFT:
+               cursor -= 256;
                break;
        case KEY_PPAGE:
-               if (cursor == 0)
-                       return 0;
+               cursor += 4096; /* Jump in 1MB steps. */
+               break;
+       case KEY_NPAGE:
                cursor -= 4096; /* Jump in 1MB steps. */
                break;
        }