mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	The autogened decoder was confusing the ARM STRBT for ARM USAT, because the .td
entry for ARM STRBT is actually a super-instruction for A8.6.199 STRBT A1 & A2. Recover by looking for ARM:USAT encoding pattern before delegating to the auto- gened decoder. Added a "usat" test case to arm-tests.txt. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110894 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -26,6 +26,8 @@ | ||||
| #include "llvm/Support/ErrorHandling.h" | ||||
| #include "llvm/Support/raw_ostream.h" | ||||
|  | ||||
| //#define DEBUG(X) do { X; } while (0) | ||||
|  | ||||
| /// ARMGenDecoderTables.inc - ARMDecoderTables.inc is tblgen'ed from | ||||
| /// ARMDecoderEmitter.cpp TableGen backend.  It contains: | ||||
| /// | ||||
| @@ -87,6 +89,11 @@ static unsigned decodeARMInstruction(uint32_t &insn) { | ||||
|       return ARM::BFI; | ||||
|   } | ||||
|  | ||||
|   // Ditto for STRBT, which is a super-instruction for A8.6.199 Encoding A1 & A2. | ||||
|   // As a result, the decoder fails to deocode USAT properly. | ||||
|   if (slice(insn, 27, 21) == 0x37 && slice(insn, 5, 4) == 1) | ||||
|     return ARM::USAT; | ||||
|  | ||||
|   // Ditto for ADDSrs, which is a super-instruction for A8.6.7 & A8.6.8. | ||||
|   // As a result, the decoder fails to decode UMULL properly. | ||||
|   if (slice(insn, 27, 21) == 0x04 && slice(insn, 7, 4) == 9) { | ||||
|   | ||||
| @@ -20,6 +20,8 @@ | ||||
| #include "llvm/Support/Debug.h" | ||||
| #include "llvm/Support/raw_ostream.h" | ||||
|  | ||||
| //#define DEBUG(X) do { X; } while (0) | ||||
|  | ||||
| /// ARMGenInstrInfo.inc - ARMGenInstrInfo.inc contains the static const | ||||
| /// TargetInstrDesc ARMInsts[] definition and the TargetOperandInfo[]'s | ||||
| /// describing the operand info for each ARMInsts[i]. | ||||
|   | ||||
| @@ -97,3 +97,5 @@ | ||||
| # CHECK:	ubfx	r0, r0, #16, #1 | ||||
| 0x50 0x08 0xe0 0xe7 | ||||
|  | ||||
| # CHECK:	usat	r8, #0, r10, asr #32 | ||||
| 0x5a 0x80 0xe0 0xe6 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user