2022-04-23 08:59:50 +00:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2018 yuzu Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2018-12-29 01:55:19 +00:00
|
|
|
|
|
|
|
#include "common/logging/log.h"
|
2018-12-31 01:46:27 +00:00
|
|
|
#include "core/arm/arm_interface.h"
|
2023-11-28 19:30:39 +00:00
|
|
|
#include "core/arm/debug.h"
|
2019-05-18 01:43:26 +00:00
|
|
|
#include "core/core.h"
|
2022-04-09 03:53:42 +00:00
|
|
|
#include "core/hle/kernel/k_process.h"
|
2018-12-29 01:55:19 +00:00
|
|
|
|
|
|
|
namespace Core {
|
2019-05-18 01:43:26 +00:00
|
|
|
|
2023-12-12 01:21:23 +00:00
|
|
|
void ArmInterface::LogBacktrace(Kernel::KProcess* process) const {
|
2023-11-28 19:30:39 +00:00
|
|
|
Kernel::Svc::ThreadContext ctx;
|
|
|
|
this->GetContext(ctx);
|
2023-06-13 01:34:25 +00:00
|
|
|
|
2023-11-28 19:30:39 +00:00
|
|
|
LOG_ERROR(Core_ARM, "Backtrace, sp={:016X}, pc={:016X}", ctx.sp, ctx.pc);
|
2019-05-18 01:43:26 +00:00
|
|
|
LOG_ERROR(Core_ARM, "{:20}{:20}{:20}{:20}{}", "Module Name", "Address", "Original Address",
|
|
|
|
"Offset", "Symbol");
|
2019-05-26 15:40:41 +00:00
|
|
|
LOG_ERROR(Core_ARM, "");
|
2023-11-28 19:30:39 +00:00
|
|
|
const auto backtrace = GetBacktraceFromContext(process, ctx);
|
2019-05-18 01:43:26 +00:00
|
|
|
for (const auto& entry : backtrace) {
|
|
|
|
LOG_ERROR(Core_ARM, "{:20}{:016X} {:016X} {:016X} {}", entry.module, entry.address,
|
|
|
|
entry.original_address, entry.offset, entry.name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-11-28 19:30:39 +00:00
|
|
|
const Kernel::DebugWatchpoint* ArmInterface::MatchingWatchpoint(
|
2023-03-18 01:26:04 +00:00
|
|
|
u64 addr, u64 size, Kernel::DebugWatchpointType access_type) const {
|
2023-11-28 19:30:39 +00:00
|
|
|
if (!m_watchpoints) {
|
2022-06-06 16:56:01 +00:00
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
2023-03-18 01:26:04 +00:00
|
|
|
const u64 start_address{addr};
|
|
|
|
const u64 end_address{addr + size};
|
2022-06-06 16:56:01 +00:00
|
|
|
|
|
|
|
for (size_t i = 0; i < Core::Hardware::NUM_WATCHPOINTS; i++) {
|
2023-11-28 19:30:39 +00:00
|
|
|
const auto& watch{(*m_watchpoints)[i]};
|
2022-06-06 16:56:01 +00:00
|
|
|
|
2023-03-18 01:26:04 +00:00
|
|
|
if (end_address <= GetInteger(watch.start_address)) {
|
2022-06-06 16:56:01 +00:00
|
|
|
continue;
|
|
|
|
}
|
2023-03-18 01:26:04 +00:00
|
|
|
if (start_address >= GetInteger(watch.end_address)) {
|
2022-06-06 16:56:01 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if ((access_type & watch.type) == Kernel::DebugWatchpointType::None) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
return &watch;
|
|
|
|
}
|
|
|
|
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
2018-12-31 01:41:30 +00:00
|
|
|
} // namespace Core
|