diff options
| author | Bill Wendling <isanbard@gmail.com> | 2013-12-01 04:37:25 +0000 | 
|---|---|---|
| committer | Bill Wendling <isanbard@gmail.com> | 2013-12-01 04:37:25 +0000 | 
| commit | ffafab019600347714602ff8a5ed38ce7d740ee4 (patch) | |
| tree | 9a5594ed214971ec1b7883736de56dfc22fe6837 | |
| parent | f4b097829a14829bb0e538123326c7537f122a5f (diff) | |
| download | external_llvm-ffafab019600347714602ff8a5ed38ce7d740ee4.zip external_llvm-ffafab019600347714602ff8a5ed38ce7d740ee4.tar.gz external_llvm-ffafab019600347714602ff8a5ed38ce7d740ee4.tar.bz2 | |
Merging r195936:
------------------------------------------------------------------------
r195936 | kevinqin | 2013-11-28 17:29:16 -0800 (Thu, 28 Nov 2013) | 1 line
[AArch64 NEON]Fix a assertion failure when disassemble SHLL instruction.
------------------------------------------------------------------------
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_34@196028 91177308-0d34-0410-b5e6-96231b3b80d8
| -rw-r--r-- | lib/Target/AArch64/AArch64InstrNEON.td | 72 | ||||
| -rw-r--r-- | lib/Target/AArch64/Disassembler/AArch64Disassembler.cpp | 36 | ||||
| -rw-r--r-- | test/MC/Disassembler/AArch64/neon-instructions.txt | 17 | 
3 files changed, 90 insertions, 35 deletions
| diff --git a/lib/Target/AArch64/AArch64InstrNEON.td b/lib/Target/AArch64/AArch64InstrNEON.td index 461a3fe..6af07f3 100644 --- a/lib/Target/AArch64/AArch64InstrNEON.td +++ b/lib/Target/AArch64/AArch64InstrNEON.td @@ -7818,41 +7818,43 @@ defm : NeonI_2VMisc_Narrow_Patterns<"SQXTN", int_arm_neon_vqmovns>;  defm : NeonI_2VMisc_Narrow_Patterns<"UQXTN", int_arm_neon_vqmovnu>;  multiclass NeonI_2VMisc_SHIFT<string asmop, bit U, bits<5> opcode> { -  def 8b8h : NeonI_2VMisc<0b0, U, 0b00, opcode, -                          (outs VPR128:$Rd), -                          (ins VPR64:$Rn, uimm_exact8:$Imm), -                          asmop # "\t$Rd.8h, $Rn.8b, $Imm", -                          [], NoItinerary>; - -  def 4h4s : NeonI_2VMisc<0b0, U, 0b01, opcode, -                          (outs VPR128:$Rd), -                          (ins VPR64:$Rn, uimm_exact16:$Imm), -                          asmop # "\t$Rd.4s, $Rn.4h, $Imm", -                          [], NoItinerary>; - -  def 2s2d : NeonI_2VMisc<0b0, U, 0b10, opcode, -                          (outs VPR128:$Rd), -                          (ins VPR64:$Rn, uimm_exact32:$Imm), -                          asmop # "\t$Rd.2d, $Rn.2s, $Imm", -                          [], NoItinerary>; - -  def 16b8h : NeonI_2VMisc<0b1, U, 0b00, opcode, -                          (outs VPR128:$Rd), -                          (ins VPR128:$Rn, uimm_exact8:$Imm), -                          asmop # "2\t$Rd.8h, $Rn.16b, $Imm", -                          [], NoItinerary>; - -  def 8h4s : NeonI_2VMisc<0b1, U, 0b01, opcode, -                          (outs VPR128:$Rd), -                          (ins VPR128:$Rn, uimm_exact16:$Imm), -                          asmop # "2\t$Rd.4s, $Rn.8h, $Imm", -                          [], NoItinerary>; - -  def 4s2d : NeonI_2VMisc<0b1, U, 0b10, opcode, -                          (outs VPR128:$Rd), -                          (ins VPR128:$Rn, uimm_exact32:$Imm), -                          asmop # "2\t$Rd.2d, $Rn.4s, $Imm", -                          [], NoItinerary>; +  let DecoderMethod = "DecodeSHLLInstruction" in { +    def 8b8h : NeonI_2VMisc<0b0, U, 0b00, opcode, +                            (outs VPR128:$Rd), +                            (ins VPR64:$Rn, uimm_exact8:$Imm), +                            asmop # "\t$Rd.8h, $Rn.8b, $Imm", +                            [], NoItinerary>; +     +    def 4h4s : NeonI_2VMisc<0b0, U, 0b01, opcode, +                            (outs VPR128:$Rd), +                            (ins VPR64:$Rn, uimm_exact16:$Imm), +                            asmop # "\t$Rd.4s, $Rn.4h, $Imm", +                            [], NoItinerary>; +     +    def 2s2d : NeonI_2VMisc<0b0, U, 0b10, opcode, +                            (outs VPR128:$Rd), +                            (ins VPR64:$Rn, uimm_exact32:$Imm), +                            asmop # "\t$Rd.2d, $Rn.2s, $Imm", +                            [], NoItinerary>; +     +    def 16b8h : NeonI_2VMisc<0b1, U, 0b00, opcode, +                            (outs VPR128:$Rd), +                            (ins VPR128:$Rn, uimm_exact8:$Imm), +                            asmop # "2\t$Rd.8h, $Rn.16b, $Imm", +                            [], NoItinerary>; +     +    def 8h4s : NeonI_2VMisc<0b1, U, 0b01, opcode, +                            (outs VPR128:$Rd), +                            (ins VPR128:$Rn, uimm_exact16:$Imm), +                            asmop # "2\t$Rd.4s, $Rn.8h, $Imm", +                            [], NoItinerary>; +     +    def 4s2d : NeonI_2VMisc<0b1, U, 0b10, opcode, +                            (outs VPR128:$Rd), +                            (ins VPR128:$Rn, uimm_exact32:$Imm), +                            asmop # "2\t$Rd.2d, $Rn.4s, $Imm", +                            [], NoItinerary>; +  }  }  defm SHLL : NeonI_2VMisc_SHIFT<"shll", 0b1, 0b10011>; diff --git a/lib/Target/AArch64/Disassembler/AArch64Disassembler.cpp b/lib/Target/AArch64/Disassembler/AArch64Disassembler.cpp index 1f70a3d..be4d7f2 100644 --- a/lib/Target/AArch64/Disassembler/AArch64Disassembler.cpp +++ b/lib/Target/AArch64/Disassembler/AArch64Disassembler.cpp @@ -238,6 +238,10 @@ static DecodeStatus DecodeVLDSTLanePostInstruction(MCInst &Inst, unsigned Insn,                                                     uint64_t Address,                                                     const void *Decoder); +static DecodeStatus DecodeSHLLInstruction(MCInst &Inst, unsigned Insn, +                                          uint64_t Address, +                                          const void *Decoder); +  static bool Check(DecodeStatus &Out, DecodeStatus In);  #include "AArch64GenDisassemblerTables.inc" @@ -1534,3 +1538,35 @@ static DecodeStatus DecodeVLDSTLanePostInstruction(MCInst &Inst, unsigned Insn,    return MCDisassembler::Success;  } + +static DecodeStatus DecodeSHLLInstruction(MCInst &Inst, unsigned Insn, +                                          uint64_t Address, +                                          const void *Decoder) { +  unsigned Rd = fieldFromInstruction(Insn, 0, 5); +  unsigned Rn = fieldFromInstruction(Insn, 5, 5); +  unsigned size = fieldFromInstruction(Insn, 22, 2); +  unsigned Q = fieldFromInstruction(Insn, 30, 1); + +  DecodeFPR128RegisterClass(Inst, Rd, Address, Decoder); + +  if(Q) +    DecodeFPR128RegisterClass(Inst, Rn, Address, Decoder); +  else +    DecodeFPR64RegisterClass(Inst, Rn, Address, Decoder); + +  switch (size) { +  case 0: +    Inst.addOperand(MCOperand::CreateImm(8)); +    break; +  case 1: +    Inst.addOperand(MCOperand::CreateImm(16)); +    break; +  case 2: +    Inst.addOperand(MCOperand::CreateImm(32)); +    break; +  default : +    return MCDisassembler::Fail; +  } +  return MCDisassembler::Success; +} + diff --git a/test/MC/Disassembler/AArch64/neon-instructions.txt b/test/MC/Disassembler/AArch64/neon-instructions.txt index 23ee1eb..863730a 100644 --- a/test/MC/Disassembler/AArch64/neon-instructions.txt +++ b/test/MC/Disassembler/AArch64/neon-instructions.txt @@ -675,6 +675,23 @@  0xab 0xdc 0x77 0x4e  #---------------------------------------------------------------------- +# Vector Shift Left long  +#---------------------------------------------------------------------- +# CHECK: shll2	v2.8h, v4.16b, #8 +# CHECK: shll2	v6.4s, v8.8h, #16 +# CHECK: shll2	v6.2d, v8.4s, #32 +# CHECK: shll	v2.8h, v4.8b, #8 +# CHECK: shll	v6.4s, v8.4h, #16 +# CHECK: shll	v6.2d, v8.2s, #32 + +0x82,0x38,0x21,0x6e +0x06,0x39,0x61,0x6e +0x06,0x39,0xa1,0x6e +0x82,0x38,0x21,0x2e +0x06,0x39,0x61,0x2e +0x06,0x39,0xa1,0x2e + +#----------------------------------------------------------------------  # Vector Shift Left by Immediate  #----------------------------------------------------------------------  # CHECK: shl v0.4h, v1.4h, #3 | 
