summaryrefslogtreecommitdiffstats
path: root/src/core/arm/arm_interface.cpp
blob: b0c9a58363b381c65272b748c0534e3888c1d559 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
// Copyright 2018 yuzu emulator team
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.

#include "arm_interface.h"
#include "common/common_types.h"
#include "common/logging/log.h"
#include "core/memory.h"

namespace Core {
void ARM_Interface::LogBacktrace() const {
    VAddr fp = GetReg(29);
    VAddr lr = GetReg(30);
    const VAddr sp = GetReg(13);
    const VAddr pc = GetPC();

    LOG_ERROR(Core_ARM, "Backtrace, sp={:016X}, pc={:016X}", sp, pc);
    while (true) {
        LOG_ERROR(Core_ARM, "{:016X}", lr);
        if (!fp) {
            break;
        }
        lr = Memory::Read64(fp + 8) - 4;
        fp = Memory::Read64(fp);
    }
}
} // namespace Core