From bd2b610eba36ac785692ba76f44ff9c14781eef6 Mon Sep 17 00:00:00 2001 From: Amaury de la Vieuville Date: Thu, 13 Jun 2013 16:41:55 +0000 Subject: [PATCH] ARM: fix B decoding llvm-svn: 183914 --- llvm/lib/Target/ARM/Disassembler/ARMDisassembler.cpp | 2 +- llvm/test/MC/Disassembler/ARM/thumb2.txt | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/llvm/lib/Target/ARM/Disassembler/ARMDisassembler.cpp b/llvm/lib/Target/ARM/Disassembler/ARMDisassembler.cpp index a6eab33af372..4086f36ccb03 100644 --- a/llvm/lib/Target/ARM/Disassembler/ARMDisassembler.cpp +++ b/llvm/lib/Target/ARM/Disassembler/ARMDisassembler.cpp @@ -2104,7 +2104,7 @@ DecodeT2BInstruction(MCInst &Inst, unsigned Insn, unsigned imm10 = fieldFromInstruction(Insn, 16, 10); unsigned imm11 = fieldFromInstruction(Insn, 0, 11); unsigned tmp = (S << 23) | (I1 << 22) | (I2 << 21) | (imm10 << 11) | imm11; - int imm32 = SignExtend32<24>(tmp << 1); + int imm32 = SignExtend32<25>(tmp << 1); if (!tryAddingSymbolicOperand(Address, Address + imm32 + 4, true, 4, Inst, Decoder)) Inst.addOperand(MCOperand::CreateImm(imm32)); diff --git a/llvm/test/MC/Disassembler/ARM/thumb2.txt b/llvm/test/MC/Disassembler/ARM/thumb2.txt index fc237ab0f7b2..a681e2a6f9fa 100644 --- a/llvm/test/MC/Disassembler/ARM/thumb2.txt +++ b/llvm/test/MC/Disassembler/ARM/thumb2.txt @@ -170,8 +170,10 @@ 0x13 0xf5 0xce 0xa9 # CHECK: b.w #208962 +# CHECK: b.w #-16777216 0x33 0xf0 0x21 0xb8 # rdar://12585795 +0x00 0xf4 0x00 0x90 #------------------------------------------------------------------------------ # BFC