[PATCH] D17540: [MIPS][LLVM-MC] Fix Disassemble of Negative Offset

Nitesh Jain via llvm-commits llvm-commits at lists.llvm.org
Tue Mar 15 23:17:23 PDT 2016


nitesh.jain added inline comments.

================
Comment at: test/MC/Disassembler/Mips/mips32r6/valid-mips32r6.txt:36
@@ -35,2 +35,3 @@
 0x04 0x11 0x14 0x9b # CHECK: bal 21104
 # FIXME: The encode/decode functions are not inverses of each other.
+0x18 0x02 0x01 0x4d # CHECK: blezalc $2, 1336
----------------
dsanders wrote:
> Are these FIXME's still true? If you assemble the mnemonics from the disassembler do you get the same opcodes?
> I suspect this change may have fixed the ones next to the tests you've updated.
The encoding and decoding are not inverse of each other. Since while decoding the offset is left shifted by 2 and then 4 is added but in case of encoding it will just right shift by 2. Thus for example

encoding 0x18 0x42 0x01 0x4d -->disassemble -->bgezalc $2, 1336
bgezalc $2, 1336-->assemble-->0x18 0x42 0x01 0x4e
0x18 0x42 0x01 0x4e-->disassemble-->bgezalc $2, 1340.

So these FIXME's will always be true


Repository:
  rL LLVM

http://reviews.llvm.org/D17540





More information about the llvm-commits mailing list