| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- using ARMeilleure.Decoders;
- using ARMeilleure.Translation;
- using System;
- using static ARMeilleure.Instructions.InstEmitFlowHelper;
- using static ARMeilleure.IntermediateRepresentation.OperandHelper;
- namespace ARMeilleure.Instructions
- {
- static partial class InstEmit
- {
- public static void Brk(ArmEmitterContext context)
- {
- EmitExceptionCall(context, NativeInterface.Break);
- }
- public static void Svc(ArmEmitterContext context)
- {
- EmitExceptionCall(context, NativeInterface.SupervisorCall);
- }
- private static void EmitExceptionCall(ArmEmitterContext context, _Void_U64_S32 func)
- {
- OpCodeException op = (OpCodeException)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));
- }
- }
- public static void Und(ArmEmitterContext context)
- {
- OpCode op = context.CurrOp;
- Delegate dlg = new _Void_U64_S32(NativeInterface.Undefined);
- context.StoreToContext();
- context.Call(dlg, Const(op.Address), Const(op.RawOpCode));
- context.LoadFromContext();
- if (context.CurrBlock.Next == null)
- {
- EmitTailContinue(context, Const(op.Address + 4));
- }
- }
- }
- }
|