| 12345678910111213141516171819202122232425262728293031323334353637 |
- using ARMeilleure.Decoders;
- using ARMeilleure.Translation;
- using static ARMeilleure.Instructions.InstEmitFlowHelper;
- using static ARMeilleure.IntermediateRepresentation.OperandHelper;
- namespace ARMeilleure.Instructions
- {
- static partial class InstEmit32
- {
- public static void Svc(ArmEmitterContext context)
- {
- EmitExceptionCall(context, NativeInterface.SupervisorCall);
- }
- public static void Trap(ArmEmitterContext context)
- {
- EmitExceptionCall(context, NativeInterface.Break);
- }
- private static void EmitExceptionCall(ArmEmitterContext context, _Void_U64_S32 func)
- {
- OpCode32Exception op = (OpCode32Exception)context.CurrOp;
- context.StoreToContext();
- context.Call(func, Const(op.Address), Const(op.Id));
- context.LoadFromContext();
- if (context.CurrBlock.Next == null)
- {
- EmitTailContinue(context, Const(op.Address + 4));
- }
- }
- }
- }
|