[LLVMbugs] [Bug 4682] New: Invalid assembler emitted for some thumb instructions
bugzilla-daemon at cs.uiuc.edu
bugzilla-daemon at cs.uiuc.edu
Tue Aug 4 14:13:19 PDT 2009
http://llvm.org/bugs/show_bug.cgi?id=4682
Summary: Invalid assembler emitted for some thumb instructions
Product: libraries
Version: trunk
Platform: PC
OS/Version: Linux
Status: NEW
Severity: normal
Priority: P2
Component: Backend: ARM
AssignedTo: unassignedbugs at nondot.org
ReportedBy: asl at math.spbu.ru
CC: llvmbugs at cs.uiuc.edu
Created an attachment (id=3284)
--> (http://llvm.org/bugs/attachment.cgi?id=3284)
picadd.bc
Consider the attached 2 testcases
1. Reproduce with llc picadd.bc -relocation-model=pic
Invalid "add.w r0, r0, pc" instruction is emitted. It has 3 register operands
and 'w' suffix thus it's treated as T3 instruction by assembler (no other
variant is possible due to 'w' suffix - assembler *must* use wide variant).
However It's not possible to use sp and pc registers as dest and rhs registers
for this encoding.
It's really should be T1 or T2 instruction (and thus - narrow) with dst = lhs.
2. Reproduce with llc subsp.bc
Invalid "sub.w sp, r7, #8" instruction is emitted.
--
Configure bugmail: http://llvm.org/bugs/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
You are on the CC list for the bug.
More information about the llvm-bugs
mailing list