mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +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:
parent
09062b1672
commit
270159fcc2
@ -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
|
||||
|
Loading…
Reference in New Issue
Block a user