2018-02-05 00:08:20 +01:00
|
|
|
using ChocolArm64.Decoder;
|
|
|
|
using ChocolArm64.State;
|
|
|
|
using ChocolArm64.Translation;
|
|
|
|
using System;
|
|
|
|
|
|
|
|
namespace ChocolArm64.Instruction
|
|
|
|
{
|
|
|
|
static partial class AInstEmit
|
|
|
|
{
|
2018-02-10 14:24:16 +01:00
|
|
|
public static void Brk(AILEmitterCtx Context)
|
|
|
|
{
|
|
|
|
EmitExceptionCall(Context, nameof(ARegisters.OnBreak));
|
|
|
|
}
|
|
|
|
|
2018-02-05 00:08:20 +01:00
|
|
|
public static void Svc(AILEmitterCtx Context)
|
2018-02-10 14:24:16 +01:00
|
|
|
{
|
|
|
|
EmitExceptionCall(Context, nameof(ARegisters.OnSvcCall));
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void EmitExceptionCall(AILEmitterCtx Context, string MthdName)
|
2018-02-05 00:08:20 +01:00
|
|
|
{
|
|
|
|
AOpCodeException Op = (AOpCodeException)Context.CurrOp;
|
|
|
|
|
|
|
|
Context.EmitStoreState();
|
|
|
|
|
|
|
|
Context.EmitLdarg(ATranslatedSub.RegistersArgIdx);
|
|
|
|
|
|
|
|
Context.EmitLdc_I4(Op.Id);
|
|
|
|
|
2018-02-10 14:24:16 +01:00
|
|
|
Context.EmitCall(typeof(ARegisters), MthdName);
|
2018-02-05 00:08:20 +01:00
|
|
|
|
|
|
|
if (Context.CurrBlock.Next != null)
|
|
|
|
{
|
|
|
|
Context.EmitLoadState(Context.CurrBlock.Next);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void Und(AILEmitterCtx Context)
|
|
|
|
{
|
2018-02-10 18:20:46 +01:00
|
|
|
AOpCode Op = Context.CurrOp;
|
|
|
|
|
|
|
|
Context.EmitStoreState();
|
|
|
|
|
|
|
|
Context.EmitLdarg(ATranslatedSub.RegistersArgIdx);
|
|
|
|
|
|
|
|
Context.EmitLdc_I8(Op.Position);
|
|
|
|
Context.EmitLdc_I4(Op.RawOpCode);
|
|
|
|
|
|
|
|
Context.EmitCall(typeof(ARegisters), nameof(ARegisters.OnUndefined));
|
|
|
|
|
|
|
|
if (Context.CurrBlock.Next != null)
|
|
|
|
{
|
|
|
|
Context.EmitLoadState(Context.CurrBlock.Next);
|
|
|
|
}
|
2018-02-05 00:08:20 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|