mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-10 08:09:26 +01:00
Merge pull request #4771 from lioncash/dspemitter
DSPCore: Move emitter cycle code into DSPEmitter itself
This commit is contained in:
commit
04c3db8bfa
@ -245,21 +245,7 @@ int DSPCore_RunCycles(int cycles)
|
||||
{
|
||||
if (g_dsp_jit)
|
||||
{
|
||||
if (g_dsp.external_interrupt_waiting)
|
||||
{
|
||||
DSPCore_CheckExternalInterrupt();
|
||||
DSPCore_CheckExceptions();
|
||||
DSPCore_SetExternalInterrupt(false);
|
||||
}
|
||||
|
||||
g_cycles_left = cycles;
|
||||
auto exec_addr = (JIT::x86::DSPEmitter::DSPCompiledCode)g_dsp_jit->m_enter_dispatcher;
|
||||
exec_addr();
|
||||
|
||||
if (g_dsp.reset_dspjit_codespace)
|
||||
g_dsp_jit->ClearIRAMandDSPJITCodespaceReset();
|
||||
|
||||
return g_cycles_left;
|
||||
return g_dsp_jit->RunCycles(static_cast<u16>(cycles));
|
||||
}
|
||||
|
||||
while (cycles > 0)
|
||||
|
@ -48,6 +48,25 @@ DSPEmitter::~DSPEmitter()
|
||||
FreeCodeSpace();
|
||||
}
|
||||
|
||||
u16 DSPEmitter::RunCycles(u16 cycles)
|
||||
{
|
||||
if (g_dsp.external_interrupt_waiting)
|
||||
{
|
||||
DSPCore_CheckExternalInterrupt();
|
||||
DSPCore_CheckExceptions();
|
||||
DSPCore_SetExternalInterrupt(false);
|
||||
}
|
||||
|
||||
g_cycles_left = cycles;
|
||||
auto exec_addr = (DSPCompiledCode)m_enter_dispatcher;
|
||||
exec_addr();
|
||||
|
||||
if (g_dsp.reset_dspjit_codespace)
|
||||
ClearIRAMandDSPJITCodespaceReset();
|
||||
|
||||
return g_cycles_left;
|
||||
}
|
||||
|
||||
void DSPEmitter::ClearIRAM()
|
||||
{
|
||||
for (int i = 0x0000; i < 0x1000; i++)
|
||||
|
@ -32,6 +32,8 @@ public:
|
||||
DSPEmitter();
|
||||
~DSPEmitter();
|
||||
|
||||
u16 RunCycles(u16 cycles);
|
||||
|
||||
void EmitInstruction(UDSPInstruction inst);
|
||||
void ClearIRAM();
|
||||
void ClearIRAMandDSPJITCodespaceReset();
|
||||
@ -245,12 +247,6 @@ public:
|
||||
void madd(const UDSPInstruction opc);
|
||||
void msub(const UDSPInstruction opc);
|
||||
|
||||
// CALL this to start the dispatcher
|
||||
const u8* m_enter_dispatcher;
|
||||
const u8* m_reenter_dispatcher;
|
||||
const u8* m_stub_entry_point;
|
||||
const u8* m_return_dispatcher;
|
||||
|
||||
std::list<u16> m_unresolved_jumps[MAX_BLOCKS];
|
||||
|
||||
private:
|
||||
@ -297,6 +293,12 @@ private:
|
||||
// The index of the last stored ext value (compile time).
|
||||
int m_store_index = -1;
|
||||
int m_store_index2 = -1;
|
||||
|
||||
// CALL this to start the dispatcher
|
||||
const u8* m_enter_dispatcher;
|
||||
const u8* m_reenter_dispatcher;
|
||||
const u8* m_stub_entry_point;
|
||||
const u8* m_return_dispatcher;
|
||||
};
|
||||
|
||||
} // namespace x86
|
||||
|
Loading…
x
Reference in New Issue
Block a user