mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-24 19:10:31 -07:00 
			
		
		
		
	Add Saddlv_V Inst. Improve Cnt_V, Dup_Gp & Ins_Gp Tests. Tuneup Cls_V & Clz_V Tests. (#720)
* Update PackageReferences. * Improve Cnt_V Test. Tuneup Cls_V & Clz_V Tests. Nit. * Nit. * Improve Dup_Gp & Ins_Gp Tests. * Update for Saddlv_V Inst. * Update for Saddlv_V Inst. * Update for Saddlv_V Inst.
This commit is contained in:
		| @@ -2206,6 +2206,11 @@ namespace ChocolArm64.Instructions | ||||
|             EmitAddLongPairwise(context, signed: true, accumulate: false); | ||||
|         } | ||||
|  | ||||
|         public static void Saddlv_V(ILEmitterCtx context) | ||||
|         { | ||||
|             EmitVectorLongAcrossVectorOpSx(context, () => context.Emit(OpCodes.Add)); | ||||
|         } | ||||
|  | ||||
|         public static void Saddw_V(ILEmitterCtx context) | ||||
|         { | ||||
|             if (Optimizations.UseSse41) | ||||
| @@ -3041,21 +3046,7 @@ namespace ChocolArm64.Instructions | ||||
|  | ||||
|         public static void Uaddlv_V(ILEmitterCtx context) | ||||
|         { | ||||
|             OpCodeSimd64 op = (OpCodeSimd64)context.CurrOp; | ||||
|  | ||||
|             int bytes = op.GetBitsCount() >> 3; | ||||
|             int elems = bytes >> op.Size; | ||||
|  | ||||
|             EmitVectorExtractZx(context, op.Rn, 0, op.Size); | ||||
|  | ||||
|             for (int index = 1; index < elems; index++) | ||||
|             { | ||||
|                 EmitVectorExtractZx(context, op.Rn, index, op.Size); | ||||
|  | ||||
|                 context.Emit(OpCodes.Add); | ||||
|             } | ||||
|  | ||||
|             EmitScalarSet(context, op.Rd, op.Size + 1); | ||||
|             EmitVectorLongAcrossVectorOpZx(context, () => context.Emit(OpCodes.Add)); | ||||
|         } | ||||
|  | ||||
|         public static void Uaddw_V(ILEmitterCtx context) | ||||
|   | ||||
| @@ -823,15 +823,29 @@ namespace ChocolArm64.Instructions | ||||
|  | ||||
|         public static void EmitVectorAcrossVectorOpSx(ILEmitterCtx context, Action emit) | ||||
|         { | ||||
|             EmitVectorAcrossVectorOp(context, emit, true); | ||||
|             EmitVectorAcrossVectorOp(context, emit, signed: true, isLong: false); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorAcrossVectorOpZx(ILEmitterCtx context, Action emit) | ||||
|         { | ||||
|             EmitVectorAcrossVectorOp(context, emit, false); | ||||
|             EmitVectorAcrossVectorOp(context, emit, signed: false, isLong: false); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorAcrossVectorOp(ILEmitterCtx context, Action emit, bool signed) | ||||
|         public static void EmitVectorLongAcrossVectorOpSx(ILEmitterCtx context, Action emit) | ||||
|         { | ||||
|             EmitVectorAcrossVectorOp(context, emit, signed: true, isLong: true); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorLongAcrossVectorOpZx(ILEmitterCtx context, Action emit) | ||||
|         { | ||||
|             EmitVectorAcrossVectorOp(context, emit, signed: false, isLong: true); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorAcrossVectorOp( | ||||
|             ILEmitterCtx context, | ||||
|             Action emit, | ||||
|             bool signed, | ||||
|             bool isLong) | ||||
|         { | ||||
|             OpCodeSimd64 op = (OpCodeSimd64)context.CurrOp; | ||||
|  | ||||
| @@ -847,7 +861,7 @@ namespace ChocolArm64.Instructions | ||||
|                 emit(); | ||||
|             } | ||||
|  | ||||
|             EmitScalarSet(context, op.Rd, op.Size); | ||||
|             EmitScalarSet(context, op.Rd, isLong ? op.Size + 1 : op.Size); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorPairwiseOpF(ILEmitterCtx context, Action emit) | ||||
|   | ||||
| @@ -439,6 +439,8 @@ namespace ChocolArm64 | ||||
|             SetA64("0x001110<<100000011010xxxxxxxxxx", InstEmit.Sadalp_V,        typeof(OpCodeSimd64)); | ||||
|             SetA64("0x001110<<1xxxxx000000xxxxxxxxxx", InstEmit.Saddl_V,         typeof(OpCodeSimdReg64)); | ||||
|             SetA64("0x001110<<100000001010xxxxxxxxxx", InstEmit.Saddlp_V,        typeof(OpCodeSimd64)); | ||||
|             SetA64("000011100x110000001110xxxxxxxxxx", InstEmit.Saddlv_V,        typeof(OpCodeSimd64)); | ||||
|             SetA64("01001110<<110000001110xxxxxxxxxx", InstEmit.Saddlv_V,        typeof(OpCodeSimd64)); | ||||
|             SetA64("0x001110<<1xxxxx000100xxxxxxxxxx", InstEmit.Saddw_V,         typeof(OpCodeSimdReg64)); | ||||
|             SetA64("x00111100x100010000000xxxxxxxxxx", InstEmit.Scvtf_Gp,        typeof(OpCodeSimdCvt64)); | ||||
|             SetA64(">00111100x000010>xxxxxxxxxxxxxxx", InstEmit.Scvtf_Gp_Fixed,  typeof(OpCodeSimdCvt64)); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user