Tweak ARM fastcc by adopting these two AAPCS rules:
authorEvan Cheng <evan.cheng@apple.com>
Tue, 11 Feb 2014 23:49:31 +0000 (23:49 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Tue, 11 Feb 2014 23:49:31 +0000 (23:49 +0000)
commit9f5baa3c7e01e632722a0d7c37b3aa82591bc8a8
treee99668f1d962ebed1f93617d766e50b8a49440f1
parente48e9419eaa7f3cf18924ecf99da9fd84f7b94d8
Tweak ARM fastcc by adopting these two AAPCS rules:
* CPRCs may be allocated to co-processor registers or the stack – they may never be allocated to core registers
* When a CPRC is allocated to the stack, all other VFP registers should be marked as unavailable

The difference is only noticeable in rare cases where there are a large number of floating point arguments (e.g.
7 doubles + additional float, double arguments). Although it's probably still better to avoid vmov as it can cause
stalls in some older ARM cores. The other, more subtle benefit, is to minimize difference between the various
calling conventions.

rdar://16039676

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@201193 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/ARM/ARMCallingConv.td
test/CodeGen/ARM/fastcc-vfp.ll [new file with mode: 0644]