aboutsummaryrefslogtreecommitdiffstats
path: root/lib/CodeGen/IfConversion.cpp
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2008-10-21 03:24:31 +0000
committerDan Gohman <gohman@apple.com>2008-10-21 03:24:31 +0000
commit3afda6e9d1a74456b9baa87ee6aabbc06e356433 (patch)
tree3e4f2b16af3207fcc5650930342133e53eac4ee6 /lib/CodeGen/IfConversion.cpp
parente7d238ea239e6ab8a2c60ecd27468f3cfc1bb08b (diff)
downloadexternal_llvm-3afda6e9d1a74456b9baa87ee6aabbc06e356433.zip
external_llvm-3afda6e9d1a74456b9baa87ee6aabbc06e356433.tar.gz
external_llvm-3afda6e9d1a74456b9baa87ee6aabbc06e356433.tar.bz2
When the coalescer is doing rematerializing, have it remove
the copy instruction from the instruction list before asking the target to create the new instruction. This gets the old instruction out of the way so that it doesn't interfere with the target's rematerialization code. In the case of x86, this helps it find more cases where EFLAGS is not live. Also, in the X86InstrInfo.cpp, teach isSafeToClobberEFLAGS to check to see if it reached the end of the block after scanning each instruction, instead of just before. This lets it notice when the end of the block is only two instructions away, without doing any additional scanning. These changes allow rematerialization to clobber EFLAGS in more cases, for example using xor instead of mov to set the return value to zero in the included testcase. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@57872 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/IfConversion.cpp')
0 files changed, 0 insertions, 0 deletions