diff options
| author | Dan Gohman <gohman@apple.com> | 2010-05-14 16:34:55 +0000 | 
|---|---|---|
| committer | Dan Gohman <gohman@apple.com> | 2010-05-14 16:34:55 +0000 | 
| commit | 02d9947e609da688b00aa42373ae613ed8984f11 (patch) | |
| tree | 73e6f9bf2ad801e234599a10184df163228d9c3a /llvm/lib/Target | |
| parent | 4707cef758e87d37b7205f666005954729a258ef (diff) | |
| download | bcm5719-llvm-02d9947e609da688b00aa42373ae613ed8984f11.tar.gz bcm5719-llvm-02d9947e609da688b00aa42373ae613ed8984f11.zip | |
Add mayLoad and mayStore flags to instructions which missed them.
llvm-svn: 103776
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/X86/X86Instr64bit.td | 7 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86InstrInfo.td | 10 | 
2 files changed, 15 insertions, 2 deletions
| diff --git a/llvm/lib/Target/X86/X86Instr64bit.td b/llvm/lib/Target/X86/X86Instr64bit.td index 3f41ffd9944..b67ea0e7c94 100644 --- a/llvm/lib/Target/X86/X86Instr64bit.td +++ b/llvm/lib/Target/X86/X86Instr64bit.td @@ -198,6 +198,7 @@ let isCall = 1, isTerminator = 1, isReturn = 1, isBarrier = 1 in    def TCRETURNri64 : I<0, Pseudo, (outs), (ins GR64_TC:$dst, i32imm:$offset,                                             variable_ops),                         "#TC_RETURN $dst $offset", []>; +  let mayLoad = 1 in    def TCRETURNmi64 : I<0, Pseudo, (outs),                          (ins i64mem_TC:$dst, i32imm:$offset, variable_ops),                         "#TC_RETURN $dst $offset", []>; @@ -208,6 +209,7 @@ let isCall = 1, isTerminator = 1, isReturn = 1, isBarrier = 1 in    def TAILJMPr64 : I<0xFF, MRM4r, (outs), (ins GR64_TC:$dst, variable_ops),                       "jmp{q}\t{*}$dst  # TAILCALL", []>; +  let mayLoad = 1 in    def TAILJMPm64 : I<0xFF, MRM4m, (outs), (ins i64mem_TC:$dst, variable_ops),                       "jmp{q}\t{*}$dst  # TAILCALL", []>;  } @@ -241,6 +243,7 @@ def EH_RETURN64   : I<0xC3, RawFrm, (outs), (ins GR64:$addr),  def POPCNT64rr : RI<0xB8, MRMSrcReg, (outs GR64:$dst), (ins GR64:$src),                      "popcnt{q}\t{$src, $dst|$dst, $src}", []>, XS; +let mayLoad = 1 in  def POPCNT64rm : RI<0xB8, MRMSrcMem, (outs GR64:$dst), (ins i64mem:$src),                      "popcnt{q}\t{$src, $dst|$dst, $src}", []>, XS; @@ -1720,11 +1723,13 @@ def XCHG64rr : RI<0x87, MRMSrcReg, (outs GR64:$dst), (ins GR64:$val,GR64:$src),  def XADD64rr  : RI<0xC1, MRMDestReg, (outs GR64:$dst), (ins GR64:$src),                     "xadd{q}\t{$src, $dst|$dst, $src}", []>, TB; +let mayLoad = 1, mayStore = 1 in  def XADD64rm  : RI<0xC1, MRMDestMem, (outs), (ins i64mem:$dst, GR64:$src),                     "xadd{q}\t{$src, $dst|$dst, $src}", []>, TB;  def CMPXCHG64rr  : RI<0xB1, MRMDestReg, (outs GR64:$dst), (ins GR64:$src),                        "cmpxchg{q}\t{$src, $dst|$dst, $src}", []>, TB; +let mayLoad = 1, mayStore = 1 in  def CMPXCHG64rm  : RI<0xB1, MRMDestMem, (outs), (ins i64mem:$dst, GR64:$src),                        "cmpxchg{q}\t{$src, $dst|$dst, $src}", []>, TB; @@ -1736,7 +1741,7 @@ def XCHG64ar : RI<0x90, AddRegFrm, (outs), (ins GR64:$src),                    "xchg{q}\t{$src, %rax|%rax, $src}", []>;  // Optimized codegen when the non-memory output is not used. -let Defs = [EFLAGS] in { +let Defs = [EFLAGS], mayLoad = 1, mayStore = 1 in {  // FIXME: Use normal add / sub instructions and add lock prefix dynamically.  def LOCK_ADD64mr : RI<0x03, MRMDestMem, (outs), (ins i64mem:$dst, GR64:$src2),                        "lock\n\t" diff --git a/llvm/lib/Target/X86/X86InstrInfo.td b/llvm/lib/Target/X86/X86InstrInfo.td index db80c80a96c..c24fc24ca9e 100644 --- a/llvm/lib/Target/X86/X86InstrInfo.td +++ b/llvm/lib/Target/X86/X86InstrInfo.td @@ -693,6 +693,7 @@ let isCall = 1, isTerminator = 1, isReturn = 1, isBarrier = 1 in    def TCRETURNri : I<0, Pseudo, (outs),                        (ins GR32_TC:$dst, i32imm:$offset, variable_ops),                       "#TC_RETURN $dst $offset", []>; +  let mayLoad = 1 in    def TCRETURNmi : I<0, Pseudo, (outs),                        (ins i32mem_TC:$dst, i32imm:$offset, variable_ops),                       "#TC_RETURN $dst $offset", []>; @@ -706,6 +707,7 @@ let isCall = 1, isTerminator = 1, isReturn = 1, isBarrier = 1 in    def TAILJMPr : I<0xFF, MRM4r, (outs), (ins GR32_TC:$dst, variable_ops),                      "jmp{l}\t{*}$dst  # TAILCALL",                   []>;      +  let mayLoad = 1 in    def TAILJMPm : I<0xFF, MRM4m, (outs), (ins i32mem_TC:$dst, variable_ops),                     "jmp{l}\t{*}$dst  # TAILCALL", []>;  } @@ -719,10 +721,12 @@ def LEAVE    : I<0xC9, RawFrm,  def POPCNT16rr : I<0xB8, MRMSrcReg, (outs GR16:$dst), (ins GR16:$src),                     "popcnt{w}\t{$src, $dst|$dst, $src}", []>, OpSize, XS; +let mayLoad = 1 in  def POPCNT16rm : I<0xB8, MRMSrcMem, (outs GR16:$dst), (ins i16mem:$src),                     "popcnt{w}\t{$src, $dst|$dst, $src}", []>, OpSize, XS;  def POPCNT32rr : I<0xB8, MRMSrcReg, (outs GR32:$dst), (ins GR32:$src),                     "popcnt{l}\t{$src, $dst|$dst, $src}", []>, XS; +let mayLoad = 1 in  def POPCNT32rm : I<0xB8, MRMSrcMem, (outs GR32:$dst), (ins i32mem:$src),                     "popcnt{l}\t{$src, $dst|$dst, $src}", []>, XS; @@ -3865,12 +3869,14 @@ def XADD16rr : I<0xC1, MRMDestReg, (outs GR16:$dst), (ins GR16:$src),  def XADD32rr  : I<0xC1, MRMDestReg, (outs GR32:$dst), (ins GR32:$src),                   "xadd{l}\t{$src, $dst|$dst, $src}", []>, TB; +let mayLoad = 1, mayStore = 1 in {  def XADD8rm   : I<0xC0, MRMDestMem, (outs), (ins i8mem:$dst, GR8:$src),                   "xadd{b}\t{$src, $dst|$dst, $src}", []>, TB;  def XADD16rm  : I<0xC1, MRMDestMem, (outs), (ins i16mem:$dst, GR16:$src),                   "xadd{w}\t{$src, $dst|$dst, $src}", []>, TB, OpSize;  def XADD32rm  : I<0xC1, MRMDestMem, (outs), (ins i32mem:$dst, GR32:$src),                   "xadd{l}\t{$src, $dst|$dst, $src}", []>, TB; +}  def CMPXCHG8rr : I<0xB0, MRMDestReg, (outs GR8:$dst), (ins GR8:$src),                     "cmpxchg{b}\t{$src, $dst|$dst, $src}", []>, TB; @@ -3879,12 +3885,14 @@ def CMPXCHG16rr : I<0xB1, MRMDestReg, (outs GR16:$dst), (ins GR16:$src),  def CMPXCHG32rr  : I<0xB1, MRMDestReg, (outs GR32:$dst), (ins GR32:$src),                       "cmpxchg{l}\t{$src, $dst|$dst, $src}", []>, TB; +let mayLoad = 1, mayStore = 1 in {  def CMPXCHG8rm   : I<0xB0, MRMDestMem, (outs), (ins i8mem:$dst, GR8:$src),                       "cmpxchg{b}\t{$src, $dst|$dst, $src}", []>, TB;  def CMPXCHG16rm  : I<0xB1, MRMDestMem, (outs), (ins i16mem:$dst, GR16:$src),                       "cmpxchg{w}\t{$src, $dst|$dst, $src}", []>, TB, OpSize;  def CMPXCHG32rm  : I<0xB1, MRMDestMem, (outs), (ins i32mem:$dst, GR32:$src),                       "cmpxchg{l}\t{$src, $dst|$dst, $src}", []>, TB; +}  let Defs = [EAX, EDX, EFLAGS], Uses = [EAX, EBX, ECX, EDX] in  def CMPXCHG8B : I<0xC7, MRM1m, (outs), (ins i64mem:$dst), @@ -3892,7 +3900,7 @@ def CMPXCHG8B : I<0xC7, MRM1m, (outs), (ins i64mem:$dst),  // Optimized codegen when the non-memory output is not used.  // FIXME: Use normal add / sub instructions and add lock prefix dynamically. -let Defs = [EFLAGS] in { +let Defs = [EFLAGS], mayLoad = 1, mayStore = 1 in {  def LOCK_ADD8mr  : I<0x00, MRMDestMem, (outs), (ins i8mem:$dst, GR8:$src2),                      "lock\n\t"                      "add{b}\t{$src2, $dst|$dst, $src2}", []>, LOCK; | 

