forked from OSchip/llvm-project
Use an ArrayRef when we can instead of passing in a SmallVectorImpl reference.
llvm-svn: 151150
This commit is contained in:
parent
94602b48ee
commit
f1a3fcac0d
|
@ -2019,7 +2019,7 @@ Value *CodeGenFunction::EmitARMBuiltinExpr(unsigned BuiltinID,
|
||||||
}
|
}
|
||||||
|
|
||||||
llvm::Value *CodeGenFunction::
|
llvm::Value *CodeGenFunction::
|
||||||
BuildVector(const SmallVectorImpl<llvm::Value*> &Ops) {
|
BuildVector(ArrayRef<llvm::Value*> Ops) {
|
||||||
assert((Ops.size() & (Ops.size() - 1)) == 0 &&
|
assert((Ops.size() & (Ops.size() - 1)) == 0 &&
|
||||||
"Not a power-of-two sized vector!");
|
"Not a power-of-two sized vector!");
|
||||||
bool AllConstants = true;
|
bool AllConstants = true;
|
||||||
|
|
|
@ -337,10 +337,9 @@ private:
|
||||||
/// containing a size and an array of structures containing instance variable
|
/// containing a size and an array of structures containing instance variable
|
||||||
/// metadata. This is used purely for introspection in the fragile ABI. In
|
/// metadata. This is used purely for introspection in the fragile ABI. In
|
||||||
/// the non-fragile ABI, it's used for instance variable fixup.
|
/// the non-fragile ABI, it's used for instance variable fixup.
|
||||||
llvm::Constant *GenerateIvarList(
|
llvm::Constant *GenerateIvarList(ArrayRef<llvm::Constant *> IvarNames,
|
||||||
const SmallVectorImpl<llvm::Constant *> &IvarNames,
|
ArrayRef<llvm::Constant *> IvarTypes,
|
||||||
const SmallVectorImpl<llvm::Constant *> &IvarTypes,
|
ArrayRef<llvm::Constant *> IvarOffsets);
|
||||||
const SmallVectorImpl<llvm::Constant *> &IvarOffsets);
|
|
||||||
/// Generates a method list structure. This is a structure containing a size
|
/// Generates a method list structure. This is a structure containing a size
|
||||||
/// and an array of structures containing method metadata.
|
/// and an array of structures containing method metadata.
|
||||||
///
|
///
|
||||||
|
@ -348,8 +347,8 @@ private:
|
||||||
/// pointer allowing them to be chained together in a linked list.
|
/// pointer allowing them to be chained together in a linked list.
|
||||||
llvm::Constant *GenerateMethodList(const StringRef &ClassName,
|
llvm::Constant *GenerateMethodList(const StringRef &ClassName,
|
||||||
const StringRef &CategoryName,
|
const StringRef &CategoryName,
|
||||||
const SmallVectorImpl<Selector> &MethodSels,
|
ArrayRef<Selector> MethodSels,
|
||||||
const SmallVectorImpl<llvm::Constant *> &MethodTypes,
|
ArrayRef<llvm::Constant *> MethodTypes,
|
||||||
bool isClassMethodList);
|
bool isClassMethodList);
|
||||||
/// Emits an empty protocol. This is used for @protocol() where no protocol
|
/// Emits an empty protocol. This is used for @protocol() where no protocol
|
||||||
/// is found. The runtime will (hopefully) fix up the pointer to refer to the
|
/// is found. The runtime will (hopefully) fix up the pointer to refer to the
|
||||||
|
@ -362,8 +361,7 @@ private:
|
||||||
SmallVectorImpl<llvm::Constant*> &InstanceMethodTypes);
|
SmallVectorImpl<llvm::Constant*> &InstanceMethodTypes);
|
||||||
/// Generates a list of referenced protocols. Classes, categories, and
|
/// Generates a list of referenced protocols. Classes, categories, and
|
||||||
/// protocols all use this structure.
|
/// protocols all use this structure.
|
||||||
llvm::Constant *GenerateProtocolList(
|
llvm::Constant *GenerateProtocolList(ArrayRef<std::string> Protocols);
|
||||||
const SmallVectorImpl<std::string> &Protocols);
|
|
||||||
/// To ensure that all protocols are seen by the runtime, we add a category on
|
/// To ensure that all protocols are seen by the runtime, we add a category on
|
||||||
/// a class defined in the runtime, declaring no methods, but adopting the
|
/// a class defined in the runtime, declaring no methods, but adopting the
|
||||||
/// protocols. This is a horribly ugly hack, but it allows us to collect all
|
/// protocols. This is a horribly ugly hack, but it allows us to collect all
|
||||||
|
@ -388,8 +386,8 @@ private:
|
||||||
/// Generates a method list. This is used by protocols to define the required
|
/// Generates a method list. This is used by protocols to define the required
|
||||||
/// and optional methods.
|
/// and optional methods.
|
||||||
llvm::Constant *GenerateProtocolMethodList(
|
llvm::Constant *GenerateProtocolMethodList(
|
||||||
const SmallVectorImpl<llvm::Constant *> &MethodNames,
|
ArrayRef<llvm::Constant *> MethodNames,
|
||||||
const SmallVectorImpl<llvm::Constant *> &MethodTypes);
|
ArrayRef<llvm::Constant *> MethodTypes);
|
||||||
/// Returns a selector with the specified type encoding. An empty string is
|
/// Returns a selector with the specified type encoding. An empty string is
|
||||||
/// used to return an untyped selector (with the types field set to NULL).
|
/// used to return an untyped selector (with the types field set to NULL).
|
||||||
llvm::Value *GetSelector(CGBuilderTy &Builder, Selector Sel,
|
llvm::Value *GetSelector(CGBuilderTy &Builder, Selector Sel,
|
||||||
|
@ -428,7 +426,7 @@ protected:
|
||||||
/// significant bit being assumed to come first in the bitfield. Therefore,
|
/// significant bit being assumed to come first in the bitfield. Therefore,
|
||||||
/// a bitfield with the 64th bit set will be (int64_t)&{ 2, [0, 1<<31] },
|
/// a bitfield with the 64th bit set will be (int64_t)&{ 2, [0, 1<<31] },
|
||||||
/// while a bitfield / with the 63rd bit set will be 1<<64.
|
/// while a bitfield / with the 63rd bit set will be 1<<64.
|
||||||
llvm::Constant *MakeBitField(llvm::SmallVectorImpl<bool> &bits);
|
llvm::Constant *MakeBitField(ArrayRef<bool> bits);
|
||||||
public:
|
public:
|
||||||
CGObjCGNU(CodeGenModule &cgm, unsigned runtimeABIVersion,
|
CGObjCGNU(CodeGenModule &cgm, unsigned runtimeABIVersion,
|
||||||
unsigned protocolClassVersion);
|
unsigned protocolClassVersion);
|
||||||
|
@ -1257,10 +1255,11 @@ CGObjCGNU::GenerateMessageSend(CodeGenFunction &CGF,
|
||||||
|
|
||||||
/// Generates a MethodList. Used in construction of a objc_class and
|
/// Generates a MethodList. Used in construction of a objc_class and
|
||||||
/// objc_category structures.
|
/// objc_category structures.
|
||||||
llvm::Constant *CGObjCGNU::GenerateMethodList(const StringRef &ClassName,
|
llvm::Constant *CGObjCGNU::
|
||||||
|
GenerateMethodList(const StringRef &ClassName,
|
||||||
const StringRef &CategoryName,
|
const StringRef &CategoryName,
|
||||||
const SmallVectorImpl<Selector> &MethodSels,
|
ArrayRef<Selector> MethodSels,
|
||||||
const SmallVectorImpl<llvm::Constant *> &MethodTypes,
|
ArrayRef<llvm::Constant *> MethodTypes,
|
||||||
bool isClassMethodList) {
|
bool isClassMethodList) {
|
||||||
if (MethodSels.empty())
|
if (MethodSels.empty())
|
||||||
return NULLPtr;
|
return NULLPtr;
|
||||||
|
@ -1314,10 +1313,10 @@ llvm::Constant *CGObjCGNU::GenerateMethodList(const StringRef &ClassName,
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Generates an IvarList. Used in construction of a objc_class.
|
/// Generates an IvarList. Used in construction of a objc_class.
|
||||||
llvm::Constant *CGObjCGNU::GenerateIvarList(
|
llvm::Constant *CGObjCGNU::
|
||||||
const SmallVectorImpl<llvm::Constant *> &IvarNames,
|
GenerateIvarList(ArrayRef<llvm::Constant *> IvarNames,
|
||||||
const SmallVectorImpl<llvm::Constant *> &IvarTypes,
|
ArrayRef<llvm::Constant *> IvarTypes,
|
||||||
const SmallVectorImpl<llvm::Constant *> &IvarOffsets) {
|
ArrayRef<llvm::Constant *> IvarOffsets) {
|
||||||
if (IvarNames.size() == 0)
|
if (IvarNames.size() == 0)
|
||||||
return NULLPtr;
|
return NULLPtr;
|
||||||
// Get the method structure type.
|
// Get the method structure type.
|
||||||
|
@ -1444,9 +1443,9 @@ llvm::Constant *CGObjCGNU::GenerateClassStructure(
|
||||||
return Class;
|
return Class;
|
||||||
}
|
}
|
||||||
|
|
||||||
llvm::Constant *CGObjCGNU::GenerateProtocolMethodList(
|
llvm::Constant *CGObjCGNU::
|
||||||
const SmallVectorImpl<llvm::Constant *> &MethodNames,
|
GenerateProtocolMethodList(ArrayRef<llvm::Constant *> MethodNames,
|
||||||
const SmallVectorImpl<llvm::Constant *> &MethodTypes) {
|
ArrayRef<llvm::Constant *> MethodTypes) {
|
||||||
// Get the method structure type.
|
// Get the method structure type.
|
||||||
llvm::StructType *ObjCMethodDescTy = llvm::StructType::get(
|
llvm::StructType *ObjCMethodDescTy = llvm::StructType::get(
|
||||||
PtrToInt8Ty, // Really a selector, but the runtime does the casting for us.
|
PtrToInt8Ty, // Really a selector, but the runtime does the casting for us.
|
||||||
|
@ -1473,8 +1472,7 @@ llvm::Constant *CGObjCGNU::GenerateProtocolMethodList(
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create the protocol list structure used in classes, categories and so on
|
// Create the protocol list structure used in classes, categories and so on
|
||||||
llvm::Constant *CGObjCGNU::GenerateProtocolList(
|
llvm::Constant *CGObjCGNU::GenerateProtocolList(ArrayRef<std::string>Protocols){
|
||||||
const SmallVectorImpl<std::string> &Protocols) {
|
|
||||||
llvm::ArrayType *ProtocolArrayTy = llvm::ArrayType::get(PtrToInt8Ty,
|
llvm::ArrayType *ProtocolArrayTy = llvm::ArrayType::get(PtrToInt8Ty,
|
||||||
Protocols.size());
|
Protocols.size());
|
||||||
llvm::StructType *ProtocolListTy = llvm::StructType::get(
|
llvm::StructType *ProtocolListTy = llvm::StructType::get(
|
||||||
|
@ -1771,7 +1769,7 @@ void CGObjCGNU::GenerateProtocolHolderCategory(void) {
|
||||||
/// significant bit being assumed to come first in the bitfield. Therefore, a
|
/// significant bit being assumed to come first in the bitfield. Therefore, a
|
||||||
/// bitfield with the 64th bit set will be (int64_t)&{ 2, [0, 1<<31] }, while a
|
/// bitfield with the 64th bit set will be (int64_t)&{ 2, [0, 1<<31] }, while a
|
||||||
/// bitfield / with the 63rd bit set will be 1<<64.
|
/// bitfield / with the 63rd bit set will be 1<<64.
|
||||||
llvm::Constant *CGObjCGNU::MakeBitField(llvm::SmallVectorImpl<bool> &bits) {
|
llvm::Constant *CGObjCGNU::MakeBitField(ArrayRef<bool> bits) {
|
||||||
int bitCount = bits.size();
|
int bitCount = bits.size();
|
||||||
int ptrBits =
|
int ptrBits =
|
||||||
(TheModule.getPointerSize() == llvm::Module::Pointer32) ? 32 : 64;
|
(TheModule.getPointerSize() == llvm::Module::Pointer32) ? 32 : 64;
|
||||||
|
|
|
@ -831,7 +831,7 @@ protected:
|
||||||
void BuildAggrIvarLayout(const ObjCImplementationDecl *OI,
|
void BuildAggrIvarLayout(const ObjCImplementationDecl *OI,
|
||||||
const llvm::StructLayout *Layout,
|
const llvm::StructLayout *Layout,
|
||||||
const RecordDecl *RD,
|
const RecordDecl *RD,
|
||||||
const SmallVectorImpl<const FieldDecl*> &RecFields,
|
ArrayRef<const FieldDecl*> RecFields,
|
||||||
unsigned int BytePos, bool ForStrongLayout,
|
unsigned int BytePos, bool ForStrongLayout,
|
||||||
bool &HasUnion);
|
bool &HasUnion);
|
||||||
|
|
||||||
|
@ -3768,7 +3768,7 @@ void CGObjCCommonMac::BuildAggrIvarRecordLayout(const RecordType *RT,
|
||||||
void CGObjCCommonMac::BuildAggrIvarLayout(const ObjCImplementationDecl *OI,
|
void CGObjCCommonMac::BuildAggrIvarLayout(const ObjCImplementationDecl *OI,
|
||||||
const llvm::StructLayout *Layout,
|
const llvm::StructLayout *Layout,
|
||||||
const RecordDecl *RD,
|
const RecordDecl *RD,
|
||||||
const SmallVectorImpl<const FieldDecl*> &RecFields,
|
ArrayRef<const FieldDecl*> RecFields,
|
||||||
unsigned int BytePos, bool ForStrongLayout,
|
unsigned int BytePos, bool ForStrongLayout,
|
||||||
bool &HasUnion) {
|
bool &HasUnion) {
|
||||||
bool IsUnion = (RD && RD->isUnion());
|
bool IsUnion = (RD && RD->isUnion());
|
||||||
|
|
|
@ -2226,7 +2226,7 @@ public:
|
||||||
llvm::Value *EmitNeonShiftVector(llvm::Value *V, llvm::Type *Ty,
|
llvm::Value *EmitNeonShiftVector(llvm::Value *V, llvm::Type *Ty,
|
||||||
bool negateForRightShift);
|
bool negateForRightShift);
|
||||||
|
|
||||||
llvm::Value *BuildVector(const SmallVectorImpl<llvm::Value*> &Ops);
|
llvm::Value *BuildVector(ArrayRef<llvm::Value*> Ops);
|
||||||
llvm::Value *EmitX86BuiltinExpr(unsigned BuiltinID, const CallExpr *E);
|
llvm::Value *EmitX86BuiltinExpr(unsigned BuiltinID, const CallExpr *E);
|
||||||
llvm::Value *EmitHexagonBuiltinExpr(unsigned BuiltinID, const CallExpr *E);
|
llvm::Value *EmitHexagonBuiltinExpr(unsigned BuiltinID, const CallExpr *E);
|
||||||
llvm::Value *EmitPPCBuiltinExpr(unsigned BuiltinID, const CallExpr *E);
|
llvm::Value *EmitPPCBuiltinExpr(unsigned BuiltinID, const CallExpr *E);
|
||||||
|
|
Loading…
Reference in New Issue