1. Use pxor instead of xoraps / xorapd to clear FR32 / FR64 registers. This
authorEvan Cheng <evan.cheng@apple.com>
Thu, 16 Feb 2006 22:45:17 +0000 (22:45 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Thu, 16 Feb 2006 22:45:17 +0000 (22:45 +0000)
commitfe5cb19405794e478b944581c3a7be5c29cbaa0e
treef5a7c299d8f34276a22a56c68d872d99e9de4916
parent19ade3bf9ca6e92d29bb5f2bdf2195ba058e50b8
1. Use pxor instead of xoraps / xorapd to clear FR32 / FR64 registers. This
   proves to be worth 20% on Ptrdist/ks. Might be related to dependency
   breaking support.
2. Added FsMOVAPSrr and FsMOVAPDrr as aliases to MOVAPSrr and MOVAPDrr. These
   are used for FR32 / FR64 reg-to-reg copies.
3. Tell reg-allocator to generate MOVSSrm / MOVSDrm and MOVSSmr / MOVSDmr to
   spill / restore FsMOVAPSrr and FsMOVAPDrr.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@26241 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/X86/X86InstrInfo.cpp
lib/Target/X86/X86InstrInfo.td
lib/Target/X86/X86RegisterInfo.cpp