[LLVMbugs] [Bug 7832] New: ARM Disassembler: BLX is variously disassembled as B or BL

bugzilla-daemon at llvm.org bugzilla-daemon at llvm.org
Thu Aug 5 15:29:00 PDT 2010


http://llvm.org/bugs/show_bug.cgi?id=7832

           Summary: ARM Disassembler: BLX is variously disassembled as B
                    or BL
           Product: new-bugs
           Version: trunk
          Platform: PC
        OS/Version: Linux
            Status: NEW
          Severity: normal
          Priority: P
         Component: new bugs
        AssignedTo: unassignedbugs at nondot.org
        ReportedBy: sliedes at cc.hut.fi
                CC: llvmbugs at cs.uiuc.edu


(trunk r110360)

I think the ARM disassembler does not produce the BLX instruction ever.
Instead, it is variously (and wrongly) disassembled as B or BL.

B is defined as

  cond 1010 imm24

BL as

  cond 1011 imm24

and BLX as

  1111 101H imm24

There's no contradiction in this, because 1111 is not a valid condition code.

However, llvm-mc disassembles blx instructions as b or bl:

$ echo '0x3a 0x9f 0xb5 0xfa' |Release+Asserts/bin/llvm-mc --disassemble
--triple=arm
        b       #-19497744

(This is BLX 0xfed69dc8)

$ echo '0x00 0x00 0x68 0xfb' |Release+Asserts/bin/llvm-mc --disassemble
--triple=arm
        bl      #27262984

(This is BLX 0x1a02492)

-- 
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