[cfe-commits] r118898 - in /cfe/trunk: include/clang/AST/Type.h lib/CodeGen/Mangle.cpp
Bob Wilson
bob.wilson at apple.com
Fri Nov 12 09:24:46 PST 2010
Author: bwilson
Date: Fri Nov 12 11:24:46 2010
New Revision: 118898
URL: http://llvm.org/viewvc/llvm-project?rev=118898&view=rev
Log:
Add a separate NeonPolyVector kind to distinguish polynomial vector types.
Add support for mangling those types according to ARM's ABI.
Modified:
cfe/trunk/include/clang/AST/Type.h
cfe/trunk/lib/CodeGen/Mangle.cpp
Modified: cfe/trunk/include/clang/AST/Type.h
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/AST/Type.h?rev=118898&r1=118897&r2=118898&view=diff
==============================================================================
--- cfe/trunk/include/clang/AST/Type.h (original)
+++ cfe/trunk/include/clang/AST/Type.h Fri Nov 12 11:24:46 2010
@@ -1918,7 +1918,8 @@
AltiVecVector, // is AltiVec vector
AltiVecPixel, // is AltiVec 'vector Pixel'
AltiVecBool, // is AltiVec 'vector bool ...'
- NeonVector // is ARM Neon vector
+ NeonVector, // is ARM Neon vector
+ NeonPolyVector // is ARM Neon polynomial vector
};
protected:
/// ElementType - The element type of the vector.
Modified: cfe/trunk/lib/CodeGen/Mangle.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/Mangle.cpp?rev=118898&r1=118897&r2=118898&view=diff
==============================================================================
--- cfe/trunk/lib/CodeGen/Mangle.cpp (original)
+++ cfe/trunk/lib/CodeGen/Mangle.cpp Fri Nov 12 11:24:46 2010
@@ -1413,17 +1413,25 @@
return false;
unsigned EltBits = 0;
const char *EltName = 0;
- switch (cast<BuiltinType>(EltType)->getKind()) {
- case BuiltinType::SChar: EltBits = 8; EltName = "int8_t"; break;
- case BuiltinType::UChar: EltBits = 8; EltName = "uint8_t"; break;
- case BuiltinType::Short: EltBits = 16; EltName = "int16_t"; break;
- case BuiltinType::UShort: EltBits = 16; EltName = "uint16_t"; break;
- case BuiltinType::Int: EltBits = 32; EltName = "int32_t"; break;
- case BuiltinType::UInt: EltBits = 32; EltName = "uint32_t"; break;
- case BuiltinType::LongLong: EltBits = 64; EltName = "int64_t"; break;
- case BuiltinType::ULongLong: EltBits = 64; EltName = "uint64_t"; break;
- case BuiltinType::Float: EltBits = 32; EltName = "float32_t"; break;
- default: return false;
+ if (T->getVectorKind() == VectorType::NeonPolyVector) {
+ switch (cast<BuiltinType>(EltType)->getKind()) {
+ case BuiltinType::SChar: EltBits = 8; EltName = "poly8_t"; break;
+ case BuiltinType::Short: EltBits = 16; EltName = "poly16_t"; break;
+ default: return false;
+ }
+ } else {
+ switch (cast<BuiltinType>(EltType)->getKind()) {
+ case BuiltinType::SChar: EltBits = 8; EltName = "int8_t"; break;
+ case BuiltinType::UChar: EltBits = 8; EltName = "uint8_t"; break;
+ case BuiltinType::Short: EltBits = 16; EltName = "int16_t"; break;
+ case BuiltinType::UShort: EltBits = 16; EltName = "uint16_t"; break;
+ case BuiltinType::Int: EltBits = 32; EltName = "int32_t"; break;
+ case BuiltinType::UInt: EltBits = 32; EltName = "uint32_t"; break;
+ case BuiltinType::LongLong: EltBits = 64; EltName = "int64_t"; break;
+ case BuiltinType::ULongLong: EltBits = 64; EltName = "uint64_t"; break;
+ case BuiltinType::Float: EltBits = 32; EltName = "float32_t"; break;
+ default: return false;
+ }
}
const char *BaseName = 0;
unsigned BitSize = T->getNumElements() * EltBits;
@@ -1446,7 +1454,9 @@
// <extended element type> ::= <element type>
// ::= p # AltiVec vector pixel
void CXXNameMangler::mangleType(const VectorType *T) {
- if (T->getVectorKind() == VectorType::NeonVector && mangleNeonVectorType(T))
+ if ((T->getVectorKind() == VectorType::NeonVector ||
+ T->getVectorKind() == VectorType::NeonPolyVector) &&
+ mangleNeonVectorType(T))
return;
Out << "Dv" << T->getNumElements() << '_';
if (T->getVectorKind() == VectorType::AltiVecPixel)
More information about the cfe-commits
mailing list