mirror of
https://github.com/intel/llvm.git
synced 2026-02-05 22:17:23 +08:00
Correct the code generation for function arguments of vec3 types on x86_64 when they are greater than 128 bits. This was incorrectly coercing things like long3 into a double2.
Add test case. llvm-svn: 145312
This commit is contained in:
@@ -1427,7 +1427,7 @@ llvm::Type *X86_64ABIInfo::GetByteVectorType(QualType Ty) const {
|
||||
if (llvm::VectorType *VT = dyn_cast<llvm::VectorType>(IRType)){
|
||||
llvm::Type *EltTy = VT->getElementType();
|
||||
unsigned BitWidth = VT->getBitWidth();
|
||||
if ((BitWidth == 128 || BitWidth == 256) &&
|
||||
if ((BitWidth >= 128 && BitWidth <= 256) &&
|
||||
(EltTy->isFloatTy() || EltTy->isDoubleTy() ||
|
||||
EltTy->isIntegerTy(8) || EltTy->isIntegerTy(16) ||
|
||||
EltTy->isIntegerTy(32) || EltTy->isIntegerTy(64) ||
|
||||
|
||||
@@ -318,3 +318,11 @@ int f44(int i, ...) {
|
||||
__builtin_va_end(ap);
|
||||
return s.y;
|
||||
}
|
||||
|
||||
// Text that vec3 returns the correct LLVM IR type.
|
||||
// CHECK: define i32 @foo(<3 x i64> %X)
|
||||
typedef long long3 __attribute((ext_vector_type(3)));
|
||||
int foo(long3 X)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user