Merging r229408:
authorHans Wennborg <hans@hanshq.net>
Tue, 17 Feb 2015 21:31:25 +0000 (21:31 +0000)
committerHans Wennborg <hans@hanshq.net>
Tue, 17 Feb 2015 21:31:25 +0000 (21:31 +0000)
commitbce1e8184fcb311e1ec3cbf03247bdf24e91d5e2
tree3deaacef2235b138ca55b9303dd47947fcac955d
parentf06a0c83eb2f36bf182224a127ad378f42ab5094
Merging r229408:
------------------------------------------------------------------------
r229408 | spatel | 2015-02-16 09:26:51 -0800 (Mon, 16 Feb 2015) | 10 lines

x86-64 ABI: unwrap single element structs / arrays of 256-bit vectors to pass and return in registers

This is a patch for PR22563 ( http://llvm.org/bugs/show_bug.cgi?id=22563 ).

We were not correctly unwrapping a single 256-bit AVX vector that was defined as an array of 1 inside a struct.

We would generate a <4 x float> param/return value instead of <8 x float> and lose half of the vector.

Differential Revision: http://reviews.llvm.org/D7614

------------------------------------------------------------------------

git-svn-id: https://llvm.org/svn/llvm-project/cfe/branches/release_36@229546 91177308-0d34-0410-b5e6-96231b3b80d8
lib/CodeGen/TargetInfo.cpp
test/CodeGen/x86_64-arguments.c