mirror of
https://github.com/Ryujinx/Ryujinx.git
synced 2024-12-27 11:01:21 -08:00
36e8e074c9
* Fix and simplify TranslatorCache * Fix some assignment alignments, remove some unused usings * Changes to ILEmitter, separate it from ILEmitterCtx * Rename ILEmitter to ILMethodBuilder * Rename LdrLit and *_Fix opcodes * Revert TranslatorCache impl to the more performant one, fix a few issues with it * Allow EmitOpCode to be called even after everything has been emitted * Make Emit and AdvanceOpCode private, simplify it a bit now that it starts emiting from the entry point * Remove unneeded temp use * Add missing exit call on TestExclusive * Use better hash * Implement the == and != operators
42 lines
1.2 KiB
C#
42 lines
1.2 KiB
C#
using ChocolArm64.State;
|
|
using System.Reflection.Emit;
|
|
|
|
namespace ChocolArm64.Translation
|
|
{
|
|
struct ILOpCodeStoreState : IILEmit
|
|
{
|
|
private ILBlock _block;
|
|
|
|
public ILOpCodeStoreState(ILBlock block)
|
|
{
|
|
_block = block;
|
|
}
|
|
|
|
public void Emit(ILMethodBuilder context)
|
|
{
|
|
long intOutputs = context.LocalAlloc.GetIntOutputs(_block);
|
|
long vecOutputs = context.LocalAlloc.GetVecOutputs(_block);
|
|
|
|
StoreLocals(context, intOutputs, RegisterType.Int);
|
|
StoreLocals(context, vecOutputs, RegisterType.Vector);
|
|
}
|
|
|
|
private void StoreLocals(ILMethodBuilder context, long outputs, RegisterType baseType)
|
|
{
|
|
for (int bit = 0; bit < 64; bit++)
|
|
{
|
|
long mask = 1L << bit;
|
|
|
|
if ((outputs & mask) != 0)
|
|
{
|
|
Register reg = ILMethodBuilder.GetRegFromBit(bit, baseType);
|
|
|
|
context.Generator.EmitLdarg(TranslatedSub.StateArgIdx);
|
|
context.Generator.EmitLdloc(context.GetLocalIndex(reg));
|
|
|
|
context.Generator.Emit(OpCodes.Stfld, reg.GetField());
|
|
}
|
|
}
|
|
}
|
|
}
|
|
} |