Add Frint Instructions and Tests (#62)
* add 'ADC 32bit and Overflow' test * Add WZR/WSP tests * fix ADC and ADDS * add ADCS test * add SBCS test * indent my code and delete comment * '/' <- i hate you x) * remove spacebar char * remove false tab * add frintx_S test * update frintx_S test * add ASRV test * fix new line * fix PR * fix indent * Add add_V tests * work on Frintx_V * Add Frintx_V Instruction * add some instruction and test * Syntax + indent * Delete Console Write * Delete Console Write 2 * CR del * Skip NaNs tests * Skip NaNs tests 2 * Fix errors 1 * Fix errors 2
This commit is contained in:
		
							parent
							
								
									3c82c8de8c
								
							
						
					
					
						commit
						ca6cf1cc90
					
				
					 4 changed files with 680 additions and 19 deletions
				
			
		|  | @ -248,6 +248,56 @@ namespace ChocolArm64.Instruction | |||
|             EmitScalarSetF(Context, Op.Rd, SizeF); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frinti_S(AILEmitterCtx Context) | ||||
|         { | ||||
|             AOpCodeSimd Op = (AOpCodeSimd)Context.CurrOp; | ||||
| 
 | ||||
|             EmitScalarUnaryOpF(Context, () => | ||||
|             { | ||||
|                 Context.EmitLdarg(ATranslatedSub.StateArgIdx); | ||||
| 
 | ||||
|                 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 | ||||
|                 { | ||||
|                     throw new InvalidOperationException(); | ||||
|                 } | ||||
|             }); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frinti_V(AILEmitterCtx Context) | ||||
|         { | ||||
|             AOpCodeSimd Op = (AOpCodeSimd)Context.CurrOp; | ||||
|              | ||||
|             EmitVectorUnaryOpF(Context, () => | ||||
|             { | ||||
|                 Context.EmitLdarg(ATranslatedSub.StateArgIdx); | ||||
| 
 | ||||
|                 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 | ||||
|                 { | ||||
|                     throw new InvalidOperationException(); | ||||
|                 } | ||||
|             }); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frinta_S(AILEmitterCtx Context) | ||||
|         { | ||||
|             AOpCodeSimd Op = (AOpCodeSimd)Context.CurrOp; | ||||
|  | @ -259,6 +309,14 @@ namespace ChocolArm64.Instruction | |||
|             EmitScalarSetF(Context, Op.Rd, Op.Size); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frinta_V(AILEmitterCtx Context) | ||||
|         { | ||||
|             EmitVectorUnaryOpF(Context, () => | ||||
|             { | ||||
|                 EmitRoundMathCall(Context, MidpointRounding.AwayFromZero); | ||||
|             }); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frintm_S(AILEmitterCtx Context) | ||||
|         { | ||||
|             EmitScalarUnaryOpF(Context, () => | ||||
|  | @ -275,6 +333,25 @@ namespace ChocolArm64.Instruction | |||
|             }); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frintn_S(AILEmitterCtx Context) | ||||
|         { | ||||
|             AOpCodeSimd Op = (AOpCodeSimd)Context.CurrOp; | ||||
| 
 | ||||
|             EmitVectorExtractF(Context, Op.Rn, 0, Op.Size); | ||||
| 
 | ||||
|             EmitRoundMathCall(Context, MidpointRounding.ToEven); | ||||
| 
 | ||||
|             EmitScalarSetF(Context, Op.Rd, Op.Size); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frintn_V(AILEmitterCtx Context) | ||||
|         { | ||||
|             EmitVectorUnaryOpF(Context, () => | ||||
|             { | ||||
|                 EmitRoundMathCall(Context, MidpointRounding.ToEven); | ||||
|             }); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frintp_S(AILEmitterCtx Context) | ||||
|         { | ||||
|             EmitScalarUnaryOpF(Context, () => | ||||
|  | @ -283,6 +360,14 @@ namespace ChocolArm64.Instruction | |||
|             }); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frintp_V(AILEmitterCtx Context) | ||||
|         { | ||||
|             EmitVectorUnaryOpF(Context, () => | ||||
|             { | ||||
|                 EmitUnaryMathCall(Context, nameof(Math.Ceiling)); | ||||
|             }); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frintx_S(AILEmitterCtx Context) | ||||
|         { | ||||
|             AOpCodeSimd Op = (AOpCodeSimd)Context.CurrOp; | ||||
|  | @ -308,6 +393,31 @@ namespace ChocolArm64.Instruction | |||
|             }); | ||||
|         } | ||||
| 
 | ||||
|         public static void Frintx_V(AILEmitterCtx Context) | ||||
|         { | ||||
|             AOpCodeSimd Op = (AOpCodeSimd)Context.CurrOp; | ||||
| 
 | ||||
|             EmitVectorUnaryOpF(Context, () => | ||||
|             { | ||||
|                 Context.EmitLdarg(ATranslatedSub.StateArgIdx); | ||||
| 
 | ||||
|                 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 | ||||
|                 { | ||||
|                     throw new InvalidOperationException(); | ||||
|                 } | ||||
|             }); | ||||
|         } | ||||
| 
 | ||||
|         public static void Fsqrt_S(AILEmitterCtx Context) | ||||
|         { | ||||
|             EmitScalarUnaryOpF(Context, () => | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 MS-DOS1999
						MS-DOS1999