Add SMLSL, SQRSHRN and SRSHR (Vector) cpu instructions, nits (#225)
* Add SMLSL, SQRSHRN and SRSHR (Vector) cpu instructions * Address PR feedback * Address PR feedback * Remove another useless temp var * nit: Alignment * Replace Context.CurrOp.GetBitsCount() with Op.GetBitsCount() * Fix encodings and move flag bit test out of the loop
This commit is contained in:
		
							parent
							
								
									2f37583ab3
								
							
						
					
					
						commit
						514218ab98
					
				
					 9 changed files with 265 additions and 153 deletions
				
			
		|  | @ -363,7 +363,7 @@ namespace ChocolArm64.Instruction | |||
|         { | ||||
|             AOpCodeSimd Op = (AOpCodeSimd)Context.CurrOp; | ||||
| 
 | ||||
|             int Bytes = Context.CurrOp.GetBitsCount() >> 3; | ||||
|             int Bytes = Op.GetBitsCount() >> 3; | ||||
|             int Elems = (!Scalar ? Bytes >> Op.Size : 1); | ||||
| 
 | ||||
|             ulong SzMask = ulong.MaxValue >> (64 - (8 << Op.Size)); | ||||
|  | @ -407,7 +407,7 @@ namespace ChocolArm64.Instruction | |||
|         { | ||||
|             AOpCodeSimdReg Op = (AOpCodeSimdReg)Context.CurrOp; | ||||
| 
 | ||||
|             int Bytes = Context.CurrOp.GetBitsCount() >> 3; | ||||
|             int Bytes = Op.GetBitsCount() >> 3; | ||||
|             int Elems = (!Scalar ? Bytes >> Op.Size : 1); | ||||
| 
 | ||||
|             ulong SzMask = ulong.MaxValue >> (64 - (8 << Op.Size)); | ||||
|  | @ -454,7 +454,7 @@ namespace ChocolArm64.Instruction | |||
| 
 | ||||
|             int SizeF = Op.Size & 1; | ||||
| 
 | ||||
|             int Bytes = Context.CurrOp.GetBitsCount() >> 3; | ||||
|             int Bytes = Op.GetBitsCount() >> 3; | ||||
| 
 | ||||
|             for (int Index = 0; Index < Bytes >> SizeF + 2; Index++) | ||||
|             { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 gdkchan
						gdkchan