mirror of
https://github.com/acidanthera/audk.git
synced 2025-07-21 20:54:29 +02:00
ArmPkg/DefaultExceptionHandlerLib: walk call stack unconditionally
Currently, we only attempt to walk the call stack and print a backtrace if the program counter refers to a location covered by a PE/COFF image. However, regardless of the value of PC, the frame pointer may still have a meaningful value, and so we can still produce the remainder of the backtrace. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Reviewed-by: Leif Lindholm <leif.lindholm@linaro.org>
This commit is contained in:
parent
b8fc72bd7d
commit
173bf5c847
@ -181,6 +181,9 @@ DefaultExceptionHandler (
|
|||||||
DEBUG ((EFI_D_ERROR, "PC 0x%012lx (0x%012lx+0x%08x) [ 0] %a\n",
|
DEBUG ((EFI_D_ERROR, "PC 0x%012lx (0x%012lx+0x%08x) [ 0] %a\n",
|
||||||
SystemContext.SystemContextAArch64->ELR, ImageBase,
|
SystemContext.SystemContextAArch64->ELR, ImageBase,
|
||||||
SystemContext.SystemContextAArch64->ELR - ImageBase, BaseName (Pdb)));
|
SystemContext.SystemContextAArch64->ELR - ImageBase, BaseName (Pdb)));
|
||||||
|
} else {
|
||||||
|
DEBUG ((EFI_D_ERROR, "PC 0x%012lx\n", SystemContext.SystemContextAArch64->ELR));
|
||||||
|
}
|
||||||
|
|
||||||
if ((UINT64 *)SystemContext.SystemContextAArch64->FP != 0) {
|
if ((UINT64 *)SystemContext.SystemContextAArch64->FP != 0) {
|
||||||
Idx = 0;
|
Idx = 0;
|
||||||
@ -200,10 +203,14 @@ DefaultExceptionHandler (
|
|||||||
}
|
}
|
||||||
DEBUG ((EFI_D_ERROR, "PC 0x%012lx (0x%012lx+0x%08x) [% 2d] %a\n",
|
DEBUG ((EFI_D_ERROR, "PC 0x%012lx (0x%012lx+0x%08x) [% 2d] %a\n",
|
||||||
Fp[1], ImageBase, Fp[1] - ImageBase, Idx, BaseName (Pdb)));
|
Fp[1], ImageBase, Fp[1] - ImageBase, Idx, BaseName (Pdb)));
|
||||||
|
} else {
|
||||||
|
DEBUG ((EFI_D_ERROR, "PC 0x%012lx\n", Fp[1]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
PrevPdb = Pdb = GetImageName (SystemContext.SystemContextAArch64->ELR, &ImageBase, &PeCoffSizeOfHeader);
|
PrevPdb = Pdb = GetImageName (SystemContext.SystemContextAArch64->ELR, &ImageBase, &PeCoffSizeOfHeader);
|
||||||
|
if (Pdb != NULL) {
|
||||||
DEBUG ((EFI_D_ERROR, "\n[ 0] %a\n", Pdb));
|
DEBUG ((EFI_D_ERROR, "\n[ 0] %a\n", Pdb));
|
||||||
|
}
|
||||||
|
|
||||||
Idx = 0;
|
Idx = 0;
|
||||||
for (Fp = RootFp; Fp[0] != 0; Fp = (UINT64 *)Fp[0]) {
|
for (Fp = RootFp; Fp[0] != 0; Fp = (UINT64 *)Fp[0]) {
|
||||||
@ -214,7 +221,6 @@ DefaultExceptionHandler (
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
DEBUG_CODE_END ();
|
DEBUG_CODE_END ();
|
||||||
|
|
||||||
DEBUG ((EFI_D_ERROR, "\n X0 0x%016lx X1 0x%016lx X2 0x%016lx X3 0x%016lx\n", SystemContext.SystemContextAArch64->X0, SystemContext.SystemContextAArch64->X1, SystemContext.SystemContextAArch64->X2, SystemContext.SystemContextAArch64->X3));
|
DEBUG ((EFI_D_ERROR, "\n X0 0x%016lx X1 0x%016lx X2 0x%016lx X3 0x%016lx\n", SystemContext.SystemContextAArch64->X0, SystemContext.SystemContextAArch64->X1, SystemContext.SystemContextAArch64->X2, SystemContext.SystemContextAArch64->X3));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user