Implement Arm32 Sha256 and MRS Rd, CPSR instructions (#3544)
* Implement Arm32 Sha256 and MRS Rd, CPSR instructions * Add tests using Arm64 outputs
This commit is contained in:
		
							parent
							
								
									1080f64df9
								
							
						
					
					
						commit
						2bb9b33da1
					
				
					 6 changed files with 420 additions and 179 deletions
				
			
		
							
								
								
									
										64
									
								
								ARMeilleure/Instructions/InstEmitSimdHash32.cs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								ARMeilleure/Instructions/InstEmitSimdHash32.cs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,64 @@ | |||
| using ARMeilleure.Decoders; | ||||
| using ARMeilleure.IntermediateRepresentation; | ||||
| using ARMeilleure.Translation; | ||||
| 
 | ||||
| using static ARMeilleure.Instructions.InstEmitHelper; | ||||
| 
 | ||||
| namespace ARMeilleure.Instructions | ||||
| { | ||||
|     static partial class InstEmit32 | ||||
|     { | ||||
| #region "Sha256" | ||||
|         public static void Sha256h_V(ArmEmitterContext context) | ||||
|         { | ||||
|             OpCode32SimdReg op = (OpCode32SimdReg)context.CurrOp; | ||||
| 
 | ||||
|             Operand d = GetVecA32(op.Qd); | ||||
|             Operand n = GetVecA32(op.Qn); | ||||
|             Operand m = GetVecA32(op.Qm); | ||||
| 
 | ||||
|             Operand res = context.Call(typeof(SoftFallback).GetMethod(nameof(SoftFallback.HashLower)), d, n, m); | ||||
| 
 | ||||
|             context.Copy(GetVecA32(op.Qd), res); | ||||
|         } | ||||
| 
 | ||||
|         public static void Sha256h2_V(ArmEmitterContext context) | ||||
|         { | ||||
|             OpCode32SimdReg op = (OpCode32SimdReg)context.CurrOp; | ||||
| 
 | ||||
|             Operand d = GetVecA32(op.Qd); | ||||
|             Operand n = GetVecA32(op.Qn); | ||||
|             Operand m = GetVecA32(op.Qm); | ||||
| 
 | ||||
|             Operand res = context.Call(typeof(SoftFallback).GetMethod(nameof(SoftFallback.HashUpper)), d, n, m); | ||||
| 
 | ||||
|             context.Copy(GetVecA32(op.Qd), res); | ||||
|         } | ||||
| 
 | ||||
|         public static void Sha256su0_V(ArmEmitterContext context) | ||||
|         { | ||||
|             OpCode32Simd op = (OpCode32Simd)context.CurrOp; | ||||
| 
 | ||||
|             Operand d = GetVecA32(op.Qd); | ||||
|             Operand m = GetVecA32(op.Qm); | ||||
| 
 | ||||
|             Operand res = context.Call(typeof(SoftFallback).GetMethod(nameof(SoftFallback.Sha256SchedulePart1)), d, m); | ||||
| 
 | ||||
|             context.Copy(GetVecA32(op.Qd), res); | ||||
|         } | ||||
| 
 | ||||
|         public static void Sha256su1_V(ArmEmitterContext context) | ||||
|         { | ||||
|             OpCode32SimdReg op = (OpCode32SimdReg)context.CurrOp; | ||||
| 
 | ||||
|             Operand d = GetVecA32(op.Qd); | ||||
|             Operand n = GetVecA32(op.Qn); | ||||
|             Operand m = GetVecA32(op.Qm); | ||||
| 
 | ||||
|             Operand res = context.Call(typeof(SoftFallback).GetMethod(nameof(SoftFallback.Sha256SchedulePart2)), d, n, m); | ||||
| 
 | ||||
|             context.Copy(GetVecA32(op.Qd), res); | ||||
|         } | ||||
| #endregion | ||||
|     } | ||||
| } | ||||
|  | @ -169,6 +169,31 @@ namespace ARMeilleure.Instructions | |||
|             SetIntA32(context, op.CRn, context.ConvertI64ToI32(context.ShiftRightUI(result, Const(32)))); | ||||
|         } | ||||
| 
 | ||||
|         public static void Mrs(ArmEmitterContext context) | ||||
|         { | ||||
|             OpCode32Mrs op = (OpCode32Mrs)context.CurrOp; | ||||
| 
 | ||||
|             if (op.R) | ||||
|             { | ||||
|                 throw new NotImplementedException("SPSR"); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 Operand vSh = context.ShiftLeft(GetFlag(PState.VFlag), Const((int)PState.VFlag)); | ||||
|                 Operand cSh = context.ShiftLeft(GetFlag(PState.CFlag), Const((int)PState.CFlag)); | ||||
|                 Operand zSh = context.ShiftLeft(GetFlag(PState.ZFlag), Const((int)PState.ZFlag)); | ||||
|                 Operand nSh = context.ShiftLeft(GetFlag(PState.NFlag), Const((int)PState.NFlag)); | ||||
|                 Operand qSh = context.ShiftLeft(GetFlag(PState.QFlag), Const((int)PState.QFlag)); | ||||
| 
 | ||||
|                 Operand spsr = context.BitwiseOr(context.BitwiseOr(nSh, zSh), context.BitwiseOr(cSh, vSh)); | ||||
|                 spsr = context.BitwiseOr(spsr, qSh); | ||||
| 
 | ||||
|                 // TODO: Remaining flags. | ||||
| 
 | ||||
|                 SetIntA32(context, op.Rd, spsr); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         public static void Msr(ArmEmitterContext context) | ||||
|         { | ||||
|             OpCode32MsrReg op = (OpCode32MsrReg)context.CurrOp; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 gdkchan
						gdkchan