diff options
| author | Eli Friedman <eli.friedman@gmail.com> | 2009-12-26 20:08:30 +0000 |
|---|---|---|
| committer | Eli Friedman <eli.friedman@gmail.com> | 2009-12-26 20:08:30 +0000 |
| commit | ac6216d84c0a062d9c6efd38a515a3b10dfea788 (patch) | |
| tree | 71574b9eb057be05b1287784399d27e9578b8fab /llvm | |
| parent | e14b1997db6e09028b3dfdb982fee7eb3ffe5e9f (diff) | |
| download | bcm5719-llvm-ac6216d84c0a062d9c6efd38a515a3b10dfea788.tar.gz bcm5719-llvm-ac6216d84c0a062d9c6efd38a515a3b10dfea788.zip | |
PR5886: Make sure IMUL32m is marked as setting EFLAGS, so scheduling doesn't
do illegal stuff around it. No testcase because the issue is very fragile.
llvm-svn: 92167
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/Target/X86/X86InstrInfo.td | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/llvm/lib/Target/X86/X86InstrInfo.td b/llvm/lib/Target/X86/X86InstrInfo.td index 51a128aaf51..4d922a54ec2 100644 --- a/llvm/lib/Target/X86/X86InstrInfo.td +++ b/llvm/lib/Target/X86/X86InstrInfo.td @@ -1128,7 +1128,7 @@ def IMUL8m : I<0xF6, MRM5m, (outs), (ins i8mem :$src), let Defs = [AX,DX,EFLAGS], Uses = [AX] in def IMUL16m : I<0xF7, MRM5m, (outs), (ins i16mem:$src), "imul{w}\t$src", []>, OpSize; // AX,DX = AX*[mem16] -let Defs = [EAX,EDX], Uses = [EAX] in +let Defs = [EAX,EDX,EFLAGS], Uses = [EAX] in def IMUL32m : I<0xF7, MRM5m, (outs), (ins i32mem:$src), "imul{l}\t$src", []>; // EAX,EDX = EAX*[mem32] } |

