diff --git a/linux-ramdump-parser-v2/watchdog_v2.py b/linux-ramdump-parser-v2/watchdog_v2.py index 691fddfa44579f8265552b7d5ce89e9e9c99541a..99139ebcebb4fafdab64f175d9fc43dbe1a02f34 100644 --- a/linux-ramdump-parser-v2/watchdog_v2.py +++ b/linux-ramdump-parser-v2/watchdog_v2.py @@ -278,9 +278,11 @@ class TZRegDump_v2(): if ram_dump.arm64: lr = self.core_regs.regs['x30'] bt = self.core_regs.regs['sp_el1'] + fp = self.core_regs.regs['x29'] else: lr = self.core_regs.regs['r14_svc'] bt = self.core_regs.regs['r13_svc'] + fp = self.core_regs.regs['r11'] a = ram_dump.unwind_lookup(pc) if a is not None: @@ -299,7 +301,7 @@ class TZRegDump_v2(): print_out_str( 'Core {3} LR: {0}+{1:x} <{2:x}>'.format(symname, offset, lr, self.core)) print_out_str('') - ram_dump.unwind.unwind_backtrace(bt, 0, pc, lr, '') + ram_dump.unwind.unwind_backtrace(bt, fp, pc, lr, '') print_out_str('') def init_regs(self, start_addr, end_addr, core, ram_dump):