forked from OSchip/llvm-project
fix rdar://9546171 - -Wshorten-64-to-32 shouldn't warn on vector bitcasts.
llvm-svn: 132975
This commit is contained in:
parent
da24f2f8e1
commit
ee7286f02d
|
@ -2895,6 +2895,11 @@ void CheckImplicitConversion(Sema &S, Expr *E, QualType T,
|
|||
return;
|
||||
return DiagnoseImpCast(S, E, T, CC, diag::warn_impcast_vector_scalar);
|
||||
}
|
||||
|
||||
// If the vector cast is cast between two vectors of the same size, it is
|
||||
// a bitcast, not a conversion.
|
||||
if (S.Context.getTypeSize(Source) == S.Context.getTypeSize(Target))
|
||||
return;
|
||||
|
||||
Source = cast<VectorType>(Source)->getElementType().getTypePtr();
|
||||
Target = cast<VectorType>(Target)->getElementType().getTypePtr();
|
||||
|
@ -2989,9 +2994,7 @@ void CheckImplicitConversion(Sema &S, Expr *E, QualType T,
|
|||
return;
|
||||
}
|
||||
|
||||
// People want to build with -Wshorten-64-to-32 and not -Wconversion
|
||||
// and by god we'll let them.
|
||||
|
||||
// People want to build with -Wshorten-64-to-32 and not -Wconversion.
|
||||
if (isFromSystemMacro(S, CC))
|
||||
return;
|
||||
|
||||
|
|
|
@ -3,3 +3,13 @@
|
|||
int test0(long v) {
|
||||
return v; // expected-warning {{implicit conversion loses integer precision}}
|
||||
}
|
||||
|
||||
|
||||
// rdar://9546171
|
||||
typedef int int4 __attribute__ ((vector_size(16)));
|
||||
typedef long long long2 __attribute__((__vector_size__(16)));
|
||||
|
||||
int4 test1(long2 a) {
|
||||
int4 v127 = a; // no warning.
|
||||
return v127;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue