mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 05:12:26 -07:00 
			
		
		
		
	Add MUL (vector by element), fix FCVTN, make svcs use MakeError too
This commit is contained in:
		| @@ -341,6 +341,11 @@ namespace ChocolArm64.Instruction | ||||
|             EmitVectorBinaryOpZx(Context, () => Context.Emit(OpCodes.Mul)); | ||||
|         } | ||||
|  | ||||
|         public static void Mul_Ve(AILEmitterCtx Context) | ||||
|         { | ||||
|             EmitVectorBinaryOpByElemZx(Context, () => Context.Emit(OpCodes.Mul)); | ||||
|         } | ||||
|  | ||||
|         public static void Neg_V(AILEmitterCtx Context) | ||||
|         { | ||||
|             EmitVectorUnaryOpSx(Context, () => Context.Emit(OpCodes.Neg)); | ||||
|   | ||||
| @@ -99,6 +99,11 @@ namespace ChocolArm64.Instruction | ||||
|                     EmitVectorInsertF(Context, Op.Rd, Part + Index, 0); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             if (Op.RegisterSize == ARegisterSize.SIMD64) | ||||
|             { | ||||
|                 EmitVectorZeroUpper(Context, Op.Rd); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public static void Fcvtps_Gp(AILEmitterCtx Context) | ||||
|   | ||||
| @@ -200,20 +200,6 @@ namespace ChocolArm64.Instruction | ||||
|             EmitVectorOpF(Context, Emit, OperFlags.RdRnRm); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorBinaryOpByElemF(AILEmitterCtx Context, Action Emit) | ||||
|         { | ||||
|             AOpCodeSimdRegElem Op = (AOpCodeSimdRegElem)Context.CurrOp; | ||||
|  | ||||
|             EmitVectorOpByElemF(Context, Emit, Op.Index, Ternary: false); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorTernaryOpByElemF(AILEmitterCtx Context, Action Emit) | ||||
|         { | ||||
|             AOpCodeSimdRegElem Op = (AOpCodeSimdRegElem)Context.CurrOp; | ||||
|  | ||||
|             EmitVectorOpByElemF(Context, Emit, Op.Index, Ternary: true); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorOpF(AILEmitterCtx Context, Action Emit, OperFlags Opers) | ||||
|         { | ||||
|             AOpCodeSimdReg Op = (AOpCodeSimdReg)Context.CurrOp; | ||||
| @@ -250,6 +236,20 @@ namespace ChocolArm64.Instruction | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorBinaryOpByElemF(AILEmitterCtx Context, Action Emit) | ||||
|         { | ||||
|             AOpCodeSimdRegElemF Op = (AOpCodeSimdRegElemF)Context.CurrOp; | ||||
|  | ||||
|             EmitVectorOpByElemF(Context, Emit, Op.Index, Ternary: false); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorTernaryOpByElemF(AILEmitterCtx Context, Action Emit) | ||||
|         { | ||||
|             AOpCodeSimdRegElemF Op = (AOpCodeSimdRegElemF)Context.CurrOp; | ||||
|  | ||||
|             EmitVectorOpByElemF(Context, Emit, Op.Index, Ternary: true); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorOpByElemF(AILEmitterCtx Context, Action Emit, int Elem, bool Ternary) | ||||
|         { | ||||
|             AOpCodeSimdReg Op = (AOpCodeSimdReg)Context.CurrOp; | ||||
| @@ -341,6 +341,54 @@ namespace ChocolArm64.Instruction | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorBinaryOpByElemSx(AILEmitterCtx Context, Action Emit) | ||||
|         { | ||||
|             AOpCodeSimdRegElem Op = (AOpCodeSimdRegElem)Context.CurrOp; | ||||
|  | ||||
|             EmitVectorOpByElem(Context, Emit, Op.Index, false, true); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorBinaryOpByElemZx(AILEmitterCtx Context, Action Emit) | ||||
|         { | ||||
|             AOpCodeSimdRegElem Op = (AOpCodeSimdRegElem)Context.CurrOp; | ||||
|  | ||||
|             EmitVectorOpByElem(Context, Emit, Op.Index, false, false); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorTernaryOpByElemZx(AILEmitterCtx Context, Action Emit) | ||||
|         { | ||||
|             AOpCodeSimdRegElem Op = (AOpCodeSimdRegElem)Context.CurrOp; | ||||
|  | ||||
|             EmitVectorOpByElem(Context, Emit, Op.Index, true, false); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorOpByElem(AILEmitterCtx Context, Action Emit, int Elem, bool Ternary, bool Signed) | ||||
|         { | ||||
|             AOpCodeSimdReg Op = (AOpCodeSimdReg)Context.CurrOp; | ||||
|  | ||||
|             int Bytes = Context.CurrOp.GetBitsCount() >> 3; | ||||
|  | ||||
|             for (int Index = 0; Index < (Bytes >> Op.Size); Index++) | ||||
|             { | ||||
|                 if (Ternary) | ||||
|                 { | ||||
|                     EmitVectorExtract(Context, Op.Rd, Index, Op.Size, Signed); | ||||
|                 } | ||||
|  | ||||
|                 EmitVectorExtract(Context, Op.Rn, Index, Op.Size, Signed); | ||||
|                 EmitVectorExtract(Context, Op.Rm, Index, Op.Size, Signed); | ||||
|  | ||||
|                 Emit(); | ||||
|  | ||||
|                 EmitVectorInsert(Context, Op.Rd, Index, Op.Size); | ||||
|             } | ||||
|  | ||||
|             if (Op.RegisterSize == ARegisterSize.SIMD64) | ||||
|             { | ||||
|                 EmitVectorZeroUpper(Context, Op.Rd); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorImmUnaryOp(AILEmitterCtx Context, Action Emit) | ||||
|         { | ||||
|             EmitVectorImmOp(Context, Emit, false); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user