arm64 :show_regs: show the address before relocation
authorPeng Fan <peng.fan@nxp.com>
Tue, 28 Nov 2017 02:08:08 +0000 (10:08 +0800)
committerTom Rini <trini@konsulko.com>
Mon, 4 Dec 2017 15:23:52 +0000 (10:23 -0500)
After relocation, when error happends, it is hard to track
ELR and LR with asm file objdumped from elf file.

So subtract the gd->reloc_off the reflect the compliation address.

Signed-off-by: Peng Fan <peng.fan@nxp.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
arch/arm/lib/interrupts_64.c

index 7c9cfce69fafe7f1ef4055e2af69a1d67ca3c7ca..cbcfeec2b030056094f9c2d76da2dc9734c28cf8 100644 (file)
@@ -9,6 +9,7 @@
 #include <linux/compiler.h>
 #include <efi_loader.h>
 
+DECLARE_GLOBAL_DATA_PTR;
 
 int interrupt_init(void)
 {
@@ -29,8 +30,13 @@ void show_regs(struct pt_regs *regs)
 {
        int i;
 
-       printf("ELR:     %lx\n", regs->elr);
-       printf("LR:      %lx\n", regs->regs[30]);
+       if (gd->flags & GD_FLG_RELOC) {
+               printf("ELR:     %lx\n", regs->elr - gd->reloc_off);
+               printf("LR:      %lx\n", regs->regs[30] - gd->reloc_off);
+       } else {
+               printf("ELR:     %lx\n", regs->elr);
+               printf("LR:      %lx\n", regs->regs[30]);
+       }
        for (i = 0; i < 29; i += 2)
                printf("x%-2d: %016lx x%-2d: %016lx\n",
                       i, regs->regs[i], i+1, regs->regs[i+1]);