diff options
| author | Chris Lattner <sabre@nondot.org> | 2010-11-06 21:23:40 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2010-11-06 21:23:40 +0000 | 
| commit | 64f91b9825f620d62de34d15200d3a69d238759f (patch) | |
| tree | 7d138270aa74146139d99b4b48b985a5069aa4a1 /llvm/lib | |
| parent | 05031e7f1a4327bf41174a9aab019df779c16104 (diff) | |
| download | bcm5719-llvm-64f91b9825f620d62de34d15200d3a69d238759f.tar.gz bcm5719-llvm-64f91b9825f620d62de34d15200d3a69d238759f.zip | |
rework the rotate-by-1 instructions to be defined like the
shift-by-1 instructions, where the asmstring doesn't contain
the implicit 1.  It turns out that a bunch of these rotate
instructions were completely broken because they used 1 
instead of $1.
This fixes assembly mismatches on "rclb	$1, %bl" and friends,
where we used to generate the 3 byte form, we now generate the
proper 2-byte form.
llvm-svn: 118355
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp | 12 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86InstrInfo.td | 27 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86InstrShiftRotate.td | 32 | 
3 files changed, 46 insertions, 25 deletions
| diff --git a/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp b/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp index 37ffeb806a5..6d4849bc7c9 100644 --- a/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp +++ b/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp @@ -771,7 +771,9 @@ ParseInstruction(StringRef Name, SMLoc NameLoc,    // FIXME: Hack to handle recognize s{hr,ar,hl} $1, <op>.  Canonicalize to    // "shift <op>".    if ((Name.startswith("shr") || Name.startswith("sar") || -       Name.startswith("shl") || Name.startswith("sal")) && +       Name.startswith("shl") || Name.startswith("sal") || +       Name.startswith("rcl") || Name.startswith("rcr") || +       Name.startswith("rol") || Name.startswith("ror")) &&        Operands.size() == 3) {      X86Operand *Op1 = static_cast<X86Operand*>(Operands[1]);      if (Op1->isImm() && isa<MCConstantExpr>(Op1->getImm()) && @@ -781,14 +783,6 @@ ParseInstruction(StringRef Name, SMLoc NameLoc,      }    } -  // FIXME: Hack to handle recognize "rc[lr] <op>" -> "rcl $1, <op>". -  if ((Name.startswith("rcl") || Name.startswith("rcr")) && -      Operands.size() == 2) { -    const MCExpr *One = MCConstantExpr::Create(1, getParser().getContext()); -    Operands.push_back(X86Operand::CreateImm(One, NameLoc, NameLoc)); -    std::swap(Operands[1], Operands[2]); -  } -    // FIXME: Hack to handle recognize "sh[lr]d op,op" -> "shld $1, op,op".    if ((Name.startswith("shld") || Name.startswith("shrd")) &&        Operands.size() == 3) { diff --git a/llvm/lib/Target/X86/X86InstrInfo.td b/llvm/lib/Target/X86/X86InstrInfo.td index fc6d4aa24ee..8ae51b29286 100644 --- a/llvm/lib/Target/X86/X86InstrInfo.td +++ b/llvm/lib/Target/X86/X86InstrInfo.td @@ -1504,6 +1504,33 @@ def : InstAlias<"outl $port", (OUT32ir i8imm:$port)>;  // errors, since its encoding is the most compact.  def : InstAlias<"sldt $mem", (SLDT16m i16mem:$mem)>; +// "rc[lr] X" is an alias for "rcl X, 1" +/* +multiclass RotateAlias<string Mnemonic, string Opc> { + def : InstAlias<!strconcat(Mnemonic, "b $op, $$1"), +                 (!cast<Instruction>(!strconcat(Opc, "8r1")) GR8:$op)>; + def : InstAlias<!strconcat(Mnemonic, "w $op, $$1"), +                 (!cast<Instruction>(!strconcat(Opc, "16r1")) GR16:$op)>; + def : InstAlias<!strconcat(Mnemonic, "l $op, $$1"), +                 (!cast<Instruction>(!strconcat(Opc, "32r1")) GR32:$op)>; + def : InstAlias<!strconcat(Mnemonic, "q $op, $$1"), +                 (!cast<Instruction>(!strconcat(Opc, "64r1")) GR64:$op)>; + def : InstAlias<!strconcat(Mnemonic, "b $op, $$1"), +                 (!cast<Instruction>(!strconcat(Opc, "8m1")) i8mem:$op)>; + def : InstAlias<!strconcat(Mnemonic, "w $op, $$1"), +                 (!cast<Instruction>(!strconcat(Opc, "16m1")) i16mem:$op)>; + def : InstAlias<!strconcat(Mnemonic, "l $op, $$1"), +                 (!cast<Instruction>(!strconcat(Opc, "32m1")) i32mem:$op)>; + def : InstAlias<!strconcat(Mnemonic, "q $op, $$1"), +                 (!cast<Instruction>(!strconcat(Opc, "64m1")) i64mem:$op)>; +} + +defm : RotateAlias<"rcl", "RCL">; +defm : RotateAlias<"rcr", "RCR">; +defm : RotateAlias<"rol", "ROL">; +defm : RotateAlias<"ror", "ROR">; +*/ +  // test: We accept "testX <reg>, <mem>" and "testX <mem>, <reg>" as synonyms.  def : InstAlias<"testb $val, $mem", (TEST8rm  GR8 :$val, i8mem :$mem)>; diff --git a/llvm/lib/Target/X86/X86InstrShiftRotate.td b/llvm/lib/Target/X86/X86InstrShiftRotate.td index e7643bec07c..8278568184f 100644 --- a/llvm/lib/Target/X86/X86InstrShiftRotate.td +++ b/llvm/lib/Target/X86/X86InstrShiftRotate.td @@ -290,7 +290,7 @@ def SAR64m1 : RI<0xD1, MRM7m, (outs), (ins i64mem:$dst),  let Constraints = "$src1 = $dst" in {  def RCL8r1 : I<0xD0, MRM2r, (outs GR8:$dst), (ins GR8:$src1), -               "rcl{b}\t{1, $dst|$dst, 1}", []>; +               "rcl{b}\t$dst", []>;  def RCL8ri : Ii8<0xC0, MRM2r, (outs GR8:$dst), (ins GR8:$src1, i8imm:$cnt),                   "rcl{b}\t{$cnt, $dst|$dst, $cnt}", []>;  let Uses = [CL] in @@ -298,7 +298,7 @@ def RCL8rCL : I<0xD2, MRM2r, (outs GR8:$dst), (ins GR8:$src1),                  "rcl{b}\t{%cl, $dst|$dst, CL}", []>;  def RCL16r1 : I<0xD1, MRM2r, (outs GR16:$dst), (ins GR16:$src1), -                "rcl{w}\t{1, $dst|$dst, 1}", []>, OpSize; +                "rcl{w}\t$dst", []>, OpSize;  def RCL16ri : Ii8<0xC1, MRM2r, (outs GR16:$dst), (ins GR16:$src1, i8imm:$cnt),                    "rcl{w}\t{$cnt, $dst|$dst, $cnt}", []>, OpSize;  let Uses = [CL] in @@ -306,7 +306,7 @@ def RCL16rCL : I<0xD3, MRM2r, (outs GR16:$dst), (ins GR16:$src1),                   "rcl{w}\t{%cl, $dst|$dst, CL}", []>, OpSize;  def RCL32r1 : I<0xD1, MRM2r, (outs GR32:$dst), (ins GR32:$src1), -                "rcl{l}\t{1, $dst|$dst, 1}", []>; +                "rcl{l}\t$dst", []>;  def RCL32ri : Ii8<0xC1, MRM2r, (outs GR32:$dst), (ins GR32:$src1, i8imm:$cnt),                    "rcl{l}\t{$cnt, $dst|$dst, $cnt}", []>;  let Uses = [CL] in @@ -315,7 +315,7 @@ def RCL32rCL : I<0xD3, MRM2r, (outs GR32:$dst), (ins GR32:$src1),  def RCL64r1 : RI<0xD1, MRM2r, (outs GR64:$dst), (ins GR64:$src1), -                 "rcl{q}\t{1, $dst|$dst, 1}", []>; +                 "rcl{q}\t$dst", []>;  def RCL64ri : RIi8<0xC1, MRM2r, (outs GR64:$dst), (ins GR64:$src1, i8imm:$cnt),                     "rcl{q}\t{$cnt, $dst|$dst, $cnt}", []>;  let Uses = [CL] in @@ -324,7 +324,7 @@ def RCL64rCL : RI<0xD3, MRM2r, (outs GR64:$dst), (ins GR64:$src1),  def RCR8r1 : I<0xD0, MRM3r, (outs GR8:$dst), (ins GR8:$src1), -               "rcr{b}\t{1, $dst|$dst, 1}", []>; +               "rcr{b}\t$dst", []>;  def RCR8ri : Ii8<0xC0, MRM3r, (outs GR8:$dst), (ins GR8:$src1, i8imm:$cnt),                   "rcr{b}\t{$cnt, $dst|$dst, $cnt}", []>;  let Uses = [CL] in @@ -332,7 +332,7 @@ def RCR8rCL : I<0xD2, MRM3r, (outs GR8:$dst), (ins GR8:$src1),                  "rcr{b}\t{%cl, $dst|$dst, CL}", []>;  def RCR16r1 : I<0xD1, MRM3r, (outs GR16:$dst), (ins GR16:$src1), -                "rcr{w}\t{1, $dst|$dst, 1}", []>, OpSize; +                "rcr{w}\t$dst", []>, OpSize;  def RCR16ri : Ii8<0xC1, MRM3r, (outs GR16:$dst), (ins GR16:$src1, i8imm:$cnt),                    "rcr{w}\t{$cnt, $dst|$dst, $cnt}", []>, OpSize;  let Uses = [CL] in @@ -340,7 +340,7 @@ def RCR16rCL : I<0xD3, MRM3r, (outs GR16:$dst), (ins GR16:$src1),                   "rcr{w}\t{%cl, $dst|$dst, CL}", []>, OpSize;  def RCR32r1 : I<0xD1, MRM3r, (outs GR32:$dst), (ins GR32:$src1), -                "rcr{l}\t{1, $dst|$dst, 1}", []>; +                "rcr{l}\t$dst", []>;  def RCR32ri : Ii8<0xC1, MRM3r, (outs GR32:$dst), (ins GR32:$src1, i8imm:$cnt),                    "rcr{l}\t{$cnt, $dst|$dst, $cnt}", []>;  let Uses = [CL] in @@ -348,7 +348,7 @@ def RCR32rCL : I<0xD3, MRM3r, (outs GR32:$dst), (ins GR32:$src1),                   "rcr{l}\t{%cl, $dst|$dst, CL}", []>;  def RCR64r1 : RI<0xD1, MRM3r, (outs GR64:$dst), (ins GR64:$src1), -                 "rcr{q}\t{1, $dst|$dst, 1}", []>; +                 "rcr{q}\t$dst", []>;  def RCR64ri : RIi8<0xC1, MRM3r, (outs GR64:$dst), (ins GR64:$src1, i8imm:$cnt),                     "rcr{q}\t{$cnt, $dst|$dst, $cnt}", []>;  let Uses = [CL] in @@ -358,36 +358,36 @@ def RCR64rCL : RI<0xD3, MRM3r, (outs GR64:$dst), (ins GR64:$src1),  } // Constraints = "$src = $dst"  def RCL8m1 : I<0xD0, MRM2m, (outs), (ins i8mem:$dst), -               "rcl{b}\t{1, $dst|$dst, 1}", []>; +               "rcl{b}\t$dst", []>;  def RCL8mi : Ii8<0xC0, MRM2m, (outs), (ins i8mem:$dst, i8imm:$cnt),                   "rcl{b}\t{$cnt, $dst|$dst, $cnt}", []>;  def RCL16m1 : I<0xD1, MRM2m, (outs), (ins i16mem:$dst), -                "rcl{w}\t{1, $dst|$dst, 1}", []>, OpSize; +                "rcl{w}\t$dst", []>, OpSize;  def RCL16mi : Ii8<0xC1, MRM2m, (outs), (ins i16mem:$dst, i8imm:$cnt),                    "rcl{w}\t{$cnt, $dst|$dst, $cnt}", []>, OpSize;  def RCL32m1 : I<0xD1, MRM2m, (outs), (ins i32mem:$dst), -                "rcl{l}\t{1, $dst|$dst, 1}", []>; +                "rcl{l}\t$dst", []>;  def RCL32mi : Ii8<0xC1, MRM2m, (outs), (ins i32mem:$dst, i8imm:$cnt),                    "rcl{l}\t{$cnt, $dst|$dst, $cnt}", []>;  def RCL64m1 : RI<0xD1, MRM2m, (outs), (ins i64mem:$dst), -                 "rcl{q}\t{1, $dst|$dst, 1}", []>; +                 "rcl{q}\t$dst", []>;  def RCL64mi : RIi8<0xC1, MRM2m, (outs), (ins i64mem:$dst, i8imm:$cnt),                     "rcl{q}\t{$cnt, $dst|$dst, $cnt}", []>;  def RCR8m1 : I<0xD0, MRM3m, (outs), (ins i8mem:$dst), -               "rcr{b}\t{1, $dst|$dst, 1}", []>; +               "rcr{b}\t$dst", []>;  def RCR8mi : Ii8<0xC0, MRM3m, (outs), (ins i8mem:$dst, i8imm:$cnt),                   "rcr{b}\t{$cnt, $dst|$dst, $cnt}", []>;  def RCR16m1 : I<0xD1, MRM3m, (outs), (ins i16mem:$dst), -                "rcr{w}\t{1, $dst|$dst, 1}", []>, OpSize; +                "rcr{w}\t$dst", []>, OpSize;  def RCR16mi : Ii8<0xC1, MRM3m, (outs), (ins i16mem:$dst, i8imm:$cnt),                    "rcr{w}\t{$cnt, $dst|$dst, $cnt}", []>, OpSize;  def RCR32m1 : I<0xD1, MRM3m, (outs), (ins i32mem:$dst), -                "rcr{l}\t{1, $dst|$dst, 1}", []>; +                "rcr{l}\t$dst", []>;  def RCR32mi : Ii8<0xC1, MRM3m, (outs), (ins i32mem:$dst, i8imm:$cnt),                    "rcr{l}\t{$cnt, $dst|$dst, $cnt}", []>;  def RCR64m1 : RI<0xD1, MRM3m, (outs), (ins i64mem:$dst), -                 "rcr{q}\t{1, $dst|$dst, 1}", []>; +                 "rcr{q}\t$dst", []>;  def RCR64mi : RIi8<0xC1, MRM3m, (outs), (ins i64mem:$dst, i8imm:$cnt),                     "rcr{q}\t{$cnt, $dst|$dst, $cnt}", []>; | 

