mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 05:12:26 -07:00 
			
		
		
		
	Add UHADD instruction
This commit is contained in:
		| @@ -247,7 +247,7 @@ namespace ChocolArm64.Instruction | ||||
|             AOpCodeSimdReg Op = (AOpCodeSimdReg)Context.CurrOp; | ||||
|  | ||||
|             int SizeF = Op.Size & 1; | ||||
|              | ||||
|  | ||||
|             EmitVectorExtractF(Context, Op.Rn, 0, SizeF); | ||||
|             EmitVectorExtractF(Context, Op.Rm, 0, SizeF); | ||||
|  | ||||
| @@ -316,7 +316,7 @@ namespace ChocolArm64.Instruction | ||||
|         public static void Frinti_V(AILEmitterCtx Context) | ||||
|         { | ||||
|             AOpCodeSimd Op = (AOpCodeSimd)Context.CurrOp; | ||||
|              | ||||
|  | ||||
|             EmitVectorUnaryOpF(Context, () => | ||||
|             { | ||||
|                 Context.EmitLdarg(ATranslatedSub.StateArgIdx); | ||||
| @@ -324,11 +324,11 @@ namespace ChocolArm64.Instruction | ||||
|                 Context.EmitCallPropGet(typeof(AThreadState), nameof(AThreadState.Fpcr)); | ||||
|  | ||||
|                 if (Op.Size == 2) | ||||
|                 {    | ||||
|                 { | ||||
|                     ASoftFallback.EmitCall(Context, nameof(ASoftFallback.RoundF)); | ||||
|                 } | ||||
|                 else if (Op.Size == 3) | ||||
|                 {    | ||||
|                 { | ||||
|                     ASoftFallback.EmitCall(Context, nameof(ASoftFallback.Round)); | ||||
|                 } | ||||
|                 else | ||||
| @@ -425,11 +425,11 @@ namespace ChocolArm64.Instruction | ||||
|                 Context.EmitCallPropGet(typeof(AThreadState), nameof(AThreadState.Fpcr)); | ||||
|  | ||||
|                 if (Op.Size == 0) | ||||
|                 {    | ||||
|                 { | ||||
|                     ASoftFallback.EmitCall(Context, nameof(ASoftFallback.RoundF)); | ||||
|                 } | ||||
|                 else if (Op.Size == 1) | ||||
|                 {    | ||||
|                 { | ||||
|                     ASoftFallback.EmitCall(Context, nameof(ASoftFallback.Round)); | ||||
|                 } | ||||
|                 else | ||||
| @@ -569,6 +569,18 @@ namespace ChocolArm64.Instruction | ||||
|             EmitVectorWidenRmBinaryOpZx(Context, () => Context.Emit(OpCodes.Add)); | ||||
|         } | ||||
|  | ||||
|         public static void Uhadd_V(AILEmitterCtx Context) | ||||
|         { | ||||
|             EmitVectorBinaryOpZx(Context, () => | ||||
|             { | ||||
|                 Context.Emit(OpCodes.Add); | ||||
|  | ||||
|                 Context.EmitLdc_I4(1); | ||||
|  | ||||
|                 Context.Emit(OpCodes.Shr_Un); | ||||
|             }); | ||||
|         } | ||||
|  | ||||
|         public static void Umull_V(AILEmitterCtx Context) | ||||
|         { | ||||
|             EmitVectorWidenRnRmBinaryOpZx(Context, () => Context.Emit(OpCodes.Mul)); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user