mirror of
https://github.com/RPCS3/rpcs3.git
synced 2025-07-03 13:31:27 +12:00
Migration to named_thread<>
Add atomic_t<>::try_dec instead of fetch_dec_sat Add atomic_t<>::try_inc GDBDebugServer is broken (needs rewrite) Removed old_thread class (former named_thread) Removed storing/rethrowing exceptions from thread Emu.Stop doesn't inject an exception anymore task_stack helper class removed thread_base simplified (no shared_from_this) thread_ctrl::spawn simplified (creates detached thread) Implemented overrideable thread detaching logic Disabled cellAdec, cellDmux, cellFsAio SPUThread renamed to spu_thread RawSPUThread removed, spu_thread used instead Disabled deriving from ppu_thread Partial support for thread renaming lv2_timer... simplified, screw it idm/fxm: butchered support for on_stop/on_init vm: improved allocation structure (added size)
This commit is contained in:
parent
8ca6c9fff0
commit
1b37e775be
82 changed files with 1820 additions and 2023 deletions
|
@ -8,8 +8,6 @@
|
|||
#include "Emu/Cell/PPUOpcodes.h"
|
||||
#include "sys_interrupt.h"
|
||||
|
||||
|
||||
|
||||
LOG_CHANNEL(sys_interrupt);
|
||||
|
||||
void lv2_int_serv::exec()
|
||||
|
@ -22,7 +20,7 @@ void lv2_int_serv::exec()
|
|||
{ ppu_cmd::sleep, 0 }
|
||||
});
|
||||
|
||||
thread->notify();
|
||||
thread_ctrl::notify(*thread);
|
||||
}
|
||||
|
||||
void lv2_int_serv::join()
|
||||
|
@ -35,8 +33,8 @@ void lv2_int_serv::join()
|
|||
{ ppu_cmd::opcode, ppu_instructions::SC(0) },
|
||||
});
|
||||
|
||||
thread->notify();
|
||||
thread->join();
|
||||
thread_ctrl::notify(*thread);
|
||||
(*thread)();
|
||||
}
|
||||
|
||||
error_code sys_interrupt_tag_destroy(u32 intrtag)
|
||||
|
@ -86,7 +84,7 @@ error_code _sys_interrupt_thread_establish(vm::ptr<u32> ih, u32 intrtag, u32 int
|
|||
}
|
||||
|
||||
// Get interrupt thread
|
||||
const auto it = idm::get_unlocked<ppu_thread>(intrthread);
|
||||
const auto it = idm::get_unlocked<named_thread<ppu_thread>>(intrthread);
|
||||
|
||||
if (!it)
|
||||
{
|
||||
|
@ -110,7 +108,8 @@ error_code _sys_interrupt_thread_establish(vm::ptr<u32> ih, u32 intrtag, u32 int
|
|||
|
||||
result = std::make_shared<lv2_int_serv>(it, arg1, arg2);
|
||||
tag->handler = result;
|
||||
it->run();
|
||||
it->state -= cpu_flag::stop;
|
||||
thread_ctrl::notify(*it);
|
||||
return result;
|
||||
});
|
||||
|
||||
|
@ -131,7 +130,7 @@ error_code _sys_interrupt_thread_disestablish(ppu_thread& ppu, u32 ih, vm::ptr<u
|
|||
|
||||
if (!handler)
|
||||
{
|
||||
if (const auto thread = idm::withdraw<ppu_thread>(ih))
|
||||
if (const auto thread = idm::withdraw<named_thread<ppu_thread>>(ih))
|
||||
{
|
||||
*r13 = thread->gpr[13];
|
||||
return CELL_OK;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue