mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 12:12:27 -07:00 
			
		
		
		
	T32: Implement ALU (shifted register) instructions (#3135)
* T32: Implement ADC, ADD, AND, BIC, CMN, CMP, EOR, MOV, MVN, ORN, ORR, RSB, SBC, SUB, TEQ, TST (shifted register) * OpCodeTable: Sort T32 list * Tests: Rename RandomTestCase to PrecomputedThumbTestCase * T32: Tests for AluRsImm instructions * fix nit * fix nit 2
This commit is contained in:
		
							
								
								
									
										20
									
								
								ARMeilleure/Decoders/OpCodeT32Alu.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								ARMeilleure/Decoders/OpCodeT32Alu.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| namespace ARMeilleure.Decoders | ||||
| { | ||||
|     class OpCodeT32Alu : OpCodeT32, IOpCode32Alu | ||||
|     { | ||||
|         public int Rd { get; } | ||||
|         public int Rn { get; } | ||||
|  | ||||
|         public bool? SetFlags { get; } | ||||
|  | ||||
|         public new static OpCode Create(InstDescriptor inst, ulong address, int opCode) => new OpCodeT32Alu(inst, address, opCode); | ||||
|  | ||||
|         public OpCodeT32Alu(InstDescriptor inst, ulong address, int opCode) : base(inst, address, opCode) | ||||
|         { | ||||
|             Rd = (opCode >> 8) & 0xf; | ||||
|             Rn = (opCode >> 16) & 0xf; | ||||
|  | ||||
|             SetFlags = ((opCode >> 20) & 1) != 0; | ||||
|         } | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user