Remove processor dependency on XThread for breakpoints

This commit is contained in:
Dr. Chat 2015-11-28 13:12:01 -06:00 committed by Ben Vanik
parent 666f5543a8
commit 42c657c40a
3 changed files with 13 additions and 5 deletions

View File

@ -10,6 +10,7 @@
#ifndef XENIA_BASE_THREADING_H_
#define XENIA_BASE_THREADING_H_
#include <algorithm>
#include <atomic>
#include <chrono>
#include <climits>
@ -344,6 +345,7 @@ class Thread : public WaitHandle {
// within that thread.
static std::unique_ptr<Thread> Create(CreationParameters params,
std::function<void()> start_routine);
static std::unique_ptr<Thread> GetCurrentThread();
// Ends the calling thread.
// No destructors are called, and this function does not return.

View File

@ -442,7 +442,7 @@ std::unique_ptr<Thread> Thread::Create(CreationParameters params,
HANDLE handle =
CreateThread(NULL, params.stack_size, ThreadStartRoutine, start_data,
params.create_suspended ? CREATE_SUSPENDED : 0, NULL);
if (!handle) {
if (handle == INVALID_HANDLE_VALUE) {
// TODO(benvanik): pass back?
auto last_error = GetLastError();
XELOGE("Unable to CreateThread: %d", last_error);
@ -453,6 +453,15 @@ std::unique_ptr<Thread> Thread::Create(CreationParameters params,
return std::make_unique<Win32Thread>(handle);
}
std::unique_ptr<Thread> Thread::GetCurrentThread() {
HANDLE handle = ::GetCurrentThread();
if (handle == INVALID_HANDLE_VALUE) {
return nullptr;
}
return std::make_unique<Win32Thread>(handle);
}
void Thread::Exit(int exit_code) { ExitThread(exit_code); }
} // namespace threading

View File

@ -27,7 +27,6 @@
#include "xenia/cpu/thread_state.h"
#include "xenia/cpu/xex_module.h"
#include "xenia/debug/debugger.h"
#include "xenia/kernel/xthread.h"
// TODO(benvanik): based on compiler support
#include "xenia/cpu/backend/x64/x64_backend.h"
@ -454,9 +453,7 @@ bool Processor::BreakpointHit(uint32_t address, uint64_t host_pc) {
if (bp) {
bp->Hit(host_pc);
// TODO: Remove dependency on XThread for suspending ourselves
kernel::XThread::GetCurrentThread()->Suspend();
xe::threading::Thread::GetCurrentThread()->Suspend();
return true;
}