Add explicit casts for vector arguments to Neon builtins.

This avoids warnings with -Wvector-conversions.  Radar 8228022.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@120597 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Bob Wilson 2010-12-01 19:49:58 +00:00
parent 95148ad023
commit f00140c8e1

View File

@ -160,6 +160,10 @@ static char ModType(const char mod, char type, bool &quad, bool &poly,
case 'n': case 'n':
type = Widen(type); type = Widen(type);
break; break;
case 'i':
type = 'i';
scal = true;
break;
case 'l': case 'l':
type = 'l'; type = 'l';
scal = true; scal = true;
@ -699,8 +703,6 @@ static unsigned GetNeonEnum(const std::string &proto, StringRef typestr) {
// Generate the definition for this intrinsic, e.g. __builtin_neon_cls(a) // Generate the definition for this intrinsic, e.g. __builtin_neon_cls(a)
static std::string GenBuiltin(const std::string &name, const std::string &proto, static std::string GenBuiltin(const std::string &name, const std::string &proto,
StringRef typestr, ClassKind ck) { StringRef typestr, ClassKind ck) {
bool quad;
unsigned nElts = GetNumElements(typestr, quad);
char arg = 'a'; char arg = 'a';
std::string s; std::string s;
@ -757,10 +759,23 @@ static std::string GenBuiltin(const std::string &name, const std::string &proto,
// Wrap macro arguments in parenthesis. // Wrap macro arguments in parenthesis.
if (define) if (define)
args = "(" + args + ")"; args = "(" + args + ")";
bool argQuad = false;
bool argPoly = false;
bool argUsgn = false;
bool argScalar = false;
bool dummy = false;
char argType = ClassifyType(typestr, argQuad, argPoly, argUsgn);
argType = ModType(proto[i], argType, argQuad, argPoly, argUsgn, argScalar,
dummy, dummy);
// Handle multiple-vector values specially, emitting each subvector as an // Handle multiple-vector values specially, emitting each subvector as an
// argument to the __builtin. // argument to the __builtin.
if (proto[i] >= '2' && proto[i] <= '4') { if (proto[i] >= '2' && proto[i] <= '4') {
// Check if an explicit cast is needed.
if (argType != 'c' || argPoly || argUsgn)
args = (argQuad ? "(int8x16_t)" : "(int8x8_t)") + args;
for (unsigned vi = 0, ve = proto[i] - '0'; vi != ve; ++vi) { for (unsigned vi = 0, ve = proto[i] - '0'; vi != ve; ++vi) {
s += args + ".val[" + utostr(vi) + "]"; s += args + ".val[" + utostr(vi) + "]";
if ((vi + 1) < ve) if ((vi + 1) < ve)
@ -772,8 +787,19 @@ static std::string GenBuiltin(const std::string &name, const std::string &proto,
continue; continue;
} }
if (splat && (i + 1) == e) // Check if an explicit cast is needed.
s += Duplicate(nElts, typestr, args); if (!argScalar &&
((ck == ClassB && argType != 'c') || argPoly || argUsgn)) {
std::string argTypeStr = "c";
if (ck != ClassB)
argTypeStr = argType;
if (argQuad)
argTypeStr = "Q" + argTypeStr;
args = "(" + TypeString('d', argTypeStr) + ")" + args;
}
if (splat && (i + 1) == e)
s += Duplicate(GetNumElements(typestr, argQuad), typestr, args);
else else
s += args; s += args;
if ((i + 1) < e) if ((i + 1) < e)