Index: llvm/include/llvm-c/DebugInfo.h =================================================================== --- llvm/include/llvm-c/DebugInfo.h +++ llvm/include/llvm-c/DebugInfo.h @@ -160,7 +160,8 @@ LLVMDIMacroMetadataKind, LLVMDIMacroFileMetadataKind, LLVMDICommonBlockMetadataKind, - LLVMDIStringTypeMetadataKind + LLVMDIStringTypeMetadataKind, + LLVMDIGenericSubrangeMetadataKind }; typedef unsigned LLVMMetadataKind; Index: llvm/include/llvm/Bitcode/LLVMBitCodes.h =================================================================== --- llvm/include/llvm/Bitcode/LLVMBitCodes.h +++ llvm/include/llvm/Bitcode/LLVMBitCodes.h @@ -341,7 +341,8 @@ METADATA_STRING_TYPE = 41, // [distinct, name, size, align,...] // Codes 42 and 43 are reserved for support for Fortran array specific debug // info. - METADATA_COMMON_BLOCK = 44 // [distinct, scope, name, variable,...] + METADATA_COMMON_BLOCK = 44, // [distinct, scope, name, variable,...] + METADATA_GENERIC_SUBRANGE = 45 // [distinct, count, lo, up, stride] }; // The constants block (CONSTANTS_BLOCK_ID) describes emission for each Index: llvm/include/llvm/IR/DIBuilder.h =================================================================== --- llvm/include/llvm/IR/DIBuilder.h +++ llvm/include/llvm/IR/DIBuilder.h @@ -582,6 +582,11 @@ DISubrange *getOrCreateSubrange(Metadata *Count, Metadata *LowerBound, Metadata *UpperBound, Metadata *Stride); + DIGenericSubrange *getOrCreateGenericSubrange(Metadata *Count, + Metadata *LowerBound, + Metadata *UpperBound, + Metadata *Stride); + /// Create a new descriptor for the specified variable. /// \param Context Variable scope. /// \param Name Name of the variable. Index: llvm/include/llvm/IR/DebugInfoMetadata.h =================================================================== --- llvm/include/llvm/IR/DebugInfoMetadata.h +++ llvm/include/llvm/IR/DebugInfoMetadata.h @@ -201,6 +201,7 @@ case DIObjCPropertyKind: case DIImportedEntityKind: case DIModuleKind: + case DIGenericSubrangeKind: return true; } } @@ -351,6 +352,58 @@ } }; +class DIGenericSubrange : public DINode { + friend class LLVMContextImpl; + friend class MDNode; + + DIGenericSubrange(LLVMContext &C, StorageType Storage, + ArrayRef Ops) + : DINode(C, DIGenericSubrangeKind, Storage, + dwarf::DW_TAG_generic_subrange, Ops) {} + + ~DIGenericSubrange() = default; + + static DIGenericSubrange *getImpl(LLVMContext &Context, Metadata *CountNode, + Metadata *LowerBound, Metadata *UpperBound, + Metadata *Stride, StorageType Storage, + bool ShouldCreate = true); + + TempDIGenericSubrange cloneImpl() const { + return getTemporary(getContext(), getRawCountNode(), getRawLowerBound(), + getRawUpperBound(), getRawStride()); + } + +public: + DEFINE_MDNODE_GET(DIGenericSubrange, + (Metadata * CountNode, Metadata *LowerBound, + Metadata *UpperBound, Metadata *Stride), + (CountNode, LowerBound, UpperBound, Stride)) + + TempDIGenericSubrange clone() const { return cloneImpl(); } + + Metadata *getRawCountNode() const { return getOperand(0).get(); } + + Metadata *getRawLowerBound() const { return getOperand(1).get(); } + + Metadata *getRawUpperBound() const { return getOperand(2).get(); } + + Metadata *getRawStride() const { return getOperand(3).get(); } + + using BoundType = PointerUnion; + + BoundType getCount() const; + + BoundType getLowerBound() const; + + BoundType getUpperBound() const; + + BoundType getStride() const; + + static bool classof(const Metadata *MD) { + return MD->getMetadataID() == DIGenericSubrangeKind; + } +}; + /// Enumeration value. /// /// TODO: Add a pointer to the context (DW_TAG_enumeration_type) once that no Index: llvm/include/llvm/IR/Metadata.def =================================================================== --- llvm/include/llvm/IR/Metadata.def +++ llvm/include/llvm/IR/Metadata.def @@ -115,6 +115,7 @@ HANDLE_SPECIALIZED_MDNODE_LEAF_UNIQUABLE(DIMacroFile) HANDLE_SPECIALIZED_MDNODE_LEAF_UNIQUABLE(DICommonBlock) HANDLE_SPECIALIZED_MDNODE_LEAF_UNIQUABLE(DIStringType) +HANDLE_SPECIALIZED_MDNODE_LEAF_UNIQUABLE(DIGenericSubrange) #undef HANDLE_METADATA #undef HANDLE_METADATA_LEAF Index: llvm/lib/AsmParser/LLParser.h =================================================================== --- llvm/lib/AsmParser/LLParser.h +++ llvm/lib/AsmParser/LLParser.h @@ -178,30 +178,30 @@ private: - bool Error(LocTy L, const Twine &Msg) const { + bool error(LocTy L, const Twine &Msg) const { return Lex.Error(L, Msg); } - bool TokError(const Twine &Msg) const { - return Error(Lex.getLoc(), Msg); + bool tokError(const Twine &Msg) const { + return error(Lex.getLoc(), Msg); } /// Restore the internal name and slot mappings using the mappings that /// were created at an earlier parsing stage. void restoreParsingState(const SlotMapping *Slots); - /// GetGlobalVal - Get a value with the specified name or ID, creating a + /// getGlobalVal - Get a value with the specified name or ID, creating a /// forward reference record if needed. This can return null if the value /// exists but does not have the right type. - GlobalValue *GetGlobalVal(const std::string &N, Type *Ty, LocTy Loc, + GlobalValue *getGlobalVal(const std::string &N, Type *Ty, LocTy Loc, bool IsCall); - GlobalValue *GetGlobalVal(unsigned ID, Type *Ty, LocTy Loc, bool IsCall); + GlobalValue *getGlobalVal(unsigned ID, Type *Ty, LocTy Loc, bool IsCall); /// Get a Comdat with the specified name, creating a forward reference /// record if needed. Comdat *getComdat(const std::string &Name, LocTy Loc); // Helper Routines. - bool ParseToken(lltok::Kind T, const char *ErrMsg); + bool parseToken(lltok::Kind T, const char *ErrMsg); bool EatIfPresent(lltok::Kind T) { if (Lex.getKind() != T) return false; Lex.Lex(); @@ -228,7 +228,7 @@ return FMF; } - bool ParseOptionalToken(lltok::Kind T, bool &Present, + bool parseOptionalToken(lltok::Kind T, bool &Present, LocTy *Loc = nullptr) { if (Lex.getKind() != T) { Present = false; @@ -240,80 +240,80 @@ } return false; } - bool ParseStringConstant(std::string &Result); - bool ParseUInt32(unsigned &Val); - bool ParseUInt32(unsigned &Val, LocTy &Loc) { + bool parseStringConstant(std::string &Result); + bool parseUInt32(unsigned &Val); + bool parseUInt32(unsigned &Val, LocTy &Loc) { Loc = Lex.getLoc(); - return ParseUInt32(Val); + return parseUInt32(Val); } - bool ParseUInt64(uint64_t &Val); - bool ParseUInt64(uint64_t &Val, LocTy &Loc) { + bool parseUInt64(uint64_t &Val); + bool parseUInt64(uint64_t &Val, LocTy &Loc) { Loc = Lex.getLoc(); - return ParseUInt64(Val); + return parseUInt64(Val); } - bool ParseFlag(unsigned &Val); + bool parseFlag(unsigned &Val); - bool ParseStringAttribute(AttrBuilder &B); + bool parseStringAttribute(AttrBuilder &B); - bool ParseTLSModel(GlobalVariable::ThreadLocalMode &TLM); - bool ParseOptionalThreadLocal(GlobalVariable::ThreadLocalMode &TLM); - bool ParseOptionalUnnamedAddr(GlobalVariable::UnnamedAddr &UnnamedAddr); - bool ParseOptionalAddrSpace(unsigned &AddrSpace, unsigned DefaultAS = 0); - bool ParseOptionalProgramAddrSpace(unsigned &AddrSpace) { - return ParseOptionalAddrSpace( + bool parseTLSModel(GlobalVariable::ThreadLocalMode &TLM); + bool parseOptionalThreadLocal(GlobalVariable::ThreadLocalMode &TLM); + bool parseOptionalUnnamedAddr(GlobalVariable::UnnamedAddr &UnnamedAddr); + bool parseOptionalAddrSpace(unsigned &AddrSpace, unsigned DefaultAS = 0); + bool parseOptionalProgramAddrSpace(unsigned &AddrSpace) { + return parseOptionalAddrSpace( AddrSpace, M->getDataLayout().getProgramAddressSpace()); }; - bool ParseOptionalParamAttrs(AttrBuilder &B); - bool ParseOptionalReturnAttrs(AttrBuilder &B); - bool ParseOptionalLinkage(unsigned &Res, bool &HasLinkage, + bool parseOptionalParamAttrs(AttrBuilder &B); + bool parseOptionalReturnAttrs(AttrBuilder &B); + bool parseOptionalLinkage(unsigned &Res, bool &HasLinkage, unsigned &Visibility, unsigned &DLLStorageClass, bool &DSOLocal); - void ParseOptionalDSOLocal(bool &DSOLocal); - void ParseOptionalVisibility(unsigned &Res); - void ParseOptionalDLLStorageClass(unsigned &Res); - bool ParseOptionalCallingConv(unsigned &CC); - bool ParseOptionalAlignment(MaybeAlign &Alignment, + void parseOptionalDSOLocal(bool &DSOLocal); + void parseOptionalVisibility(unsigned &Res); + void parseOptionalDLLStorageClass(unsigned &Res); + bool parseOptionalCallingConv(unsigned &CC); + bool parseOptionalAlignment(MaybeAlign &Alignment, bool AllowParens = false); - bool ParseOptionalDerefAttrBytes(lltok::Kind AttrKind, uint64_t &Bytes); - bool ParseScopeAndOrdering(bool isAtomic, SyncScope::ID &SSID, + bool parseOptionalDerefAttrBytes(lltok::Kind AttrKind, uint64_t &Bytes); + bool parseScopeAndOrdering(bool isAtomic, SyncScope::ID &SSID, AtomicOrdering &Ordering); - bool ParseScope(SyncScope::ID &SSID); - bool ParseOrdering(AtomicOrdering &Ordering); - bool ParseOptionalStackAlignment(unsigned &Alignment); - bool ParseOptionalCommaAlign(MaybeAlign &Alignment, bool &AteExtraComma); - bool ParseOptionalCommaAddrSpace(unsigned &AddrSpace, LocTy &Loc, + bool parseScope(SyncScope::ID &SSID); + bool parseOrdering(AtomicOrdering &Ordering); + bool parseOptionalStackAlignment(unsigned &Alignment); + bool parseOptionalCommaAlign(MaybeAlign &Alignment, bool &AteExtraComma); + bool parseOptionalCommaAddrSpace(unsigned &AddrSpace, LocTy &Loc, bool &AteExtraComma); - bool ParseOptionalCommaInAlloca(bool &IsInAlloca); + bool parseOptionalCommaInAlloca(bool &IsInAlloca); bool parseAllocSizeArguments(unsigned &BaseSizeArg, Optional &HowManyArg); - bool ParseIndexList(SmallVectorImpl &Indices, + bool parseIndexList(SmallVectorImpl &Indices, bool &AteExtraComma); - bool ParseIndexList(SmallVectorImpl &Indices) { + bool parseIndexList(SmallVectorImpl &Indices) { bool AteExtraComma; - if (ParseIndexList(Indices, AteExtraComma)) return true; + if (parseIndexList(Indices, AteExtraComma)) return true; if (AteExtraComma) - return TokError("expected index"); + return tokError("expected index"); return false; } // Top-Level Entities - bool ParseTopLevelEntities(); - bool ValidateEndOfModule(bool UpgradeDebugInfo); - bool ValidateEndOfIndex(); - bool ParseTargetDefinitions(); - bool ParseTargetDefinition(); - bool ParseModuleAsm(); - bool ParseSourceFileName(); - bool ParseDepLibs(); // FIXME: Remove in 4.0. - bool ParseUnnamedType(); - bool ParseNamedType(); - bool ParseDeclare(); - bool ParseDefine(); - - bool ParseGlobalType(bool &IsConstant); - bool ParseUnnamedGlobal(); - bool ParseNamedGlobal(); - bool ParseGlobal(const std::string &Name, LocTy NameLoc, unsigned Linkage, + bool parseTopLevelEntities(); + bool validateEndOfModule(bool UpgradeDebugInfo); + bool validateEndOfIndex(); + bool parseTargetDefinitions(); + bool parseTargetDefinition(); + bool parseModuleAsm(); + bool parseSourceFileName(); + bool parseDepLibs(); // FIXME: Remove in 4.0. + bool parseUnnamedType(); + bool parseNamedType(); + bool parseDeclare(); + bool parseDefine(); + + bool parseGlobalType(bool &IsConstant); + bool parseUnnamedGlobal(); + bool parseNamedGlobal(); + bool parseGlobal(const std::string &Name, LocTy NameLoc, unsigned Linkage, bool HasLinkage, unsigned Visibility, unsigned DLLStorageClass, bool DSOLocal, GlobalVariable::ThreadLocalMode TLM, @@ -324,98 +324,98 @@ GlobalVariable::ThreadLocalMode TLM, GlobalVariable::UnnamedAddr UnnamedAddr); bool parseComdat(); - bool ParseStandaloneMetadata(); - bool ParseNamedMetadata(); - bool ParseMDString(MDString *&Result); - bool ParseMDNodeID(MDNode *&Result); - bool ParseUnnamedAttrGrp(); - bool ParseFnAttributeValuePairs(AttrBuilder &B, + bool parseStandaloneMetadata(); + bool parseNamedMetadata(); + bool parseMDString(MDString *&Result); + bool parseMDNodeID(MDNode *&Result); + bool parseUnnamedAttrGrp(); + bool parseFnAttributeValuePairs(AttrBuilder &B, std::vector &FwdRefAttrGrps, bool inAttrGrp, LocTy &BuiltinLoc); - bool ParseByValWithOptionalType(Type *&Result); + bool parseByValWithOptionalType(Type *&Result); - bool ParseRequiredTypeAttr(Type *&Result, lltok::Kind AttrName); - bool ParsePreallocated(Type *&Result); - bool ParseByRef(Type *&Result); + bool parseRequiredTypeAttr(Type *&Result, lltok::Kind AttrName); + bool parsePreallocated(Type *&Result); + bool parseByRef(Type *&Result); // Module Summary Index Parsing. - bool SkipModuleSummaryEntry(); - bool ParseSummaryEntry(); - bool ParseModuleEntry(unsigned ID); - bool ParseModuleReference(StringRef &ModulePath); - bool ParseGVReference(ValueInfo &VI, unsigned &GVId); - bool ParseSummaryIndexFlags(); - bool ParseBlockCount(); - bool ParseGVEntry(unsigned ID); - bool ParseFunctionSummary(std::string Name, GlobalValue::GUID, unsigned ID); - bool ParseVariableSummary(std::string Name, GlobalValue::GUID, unsigned ID); - bool ParseAliasSummary(std::string Name, GlobalValue::GUID, unsigned ID); - bool ParseGVFlags(GlobalValueSummary::GVFlags &GVFlags); - bool ParseGVarFlags(GlobalVarSummary::GVarFlags &GVarFlags); - bool ParseOptionalFFlags(FunctionSummary::FFlags &FFlags); - bool ParseOptionalCalls(std::vector &Calls); - bool ParseHotness(CalleeInfo::HotnessType &Hotness); - bool ParseOptionalTypeIdInfo(FunctionSummary::TypeIdInfo &TypeIdInfo); - bool ParseTypeTests(std::vector &TypeTests); - bool ParseVFuncIdList(lltok::Kind Kind, + bool skipModuleSummaryEntry(); + bool parseSummaryEntry(); + bool parseModuleEntry(unsigned ID); + bool parseModuleReference(StringRef &ModulePath); + bool parseGVReference(ValueInfo &VI, unsigned &GVId); + bool parseSummaryIndexFlags(); + bool parseBlockCount(); + bool parseGVEntry(unsigned ID); + bool parseFunctionSummary(std::string Name, GlobalValue::GUID, unsigned ID); + bool parseVariableSummary(std::string Name, GlobalValue::GUID, unsigned ID); + bool parseAliasSummary(std::string Name, GlobalValue::GUID, unsigned ID); + bool parseGVFlags(GlobalValueSummary::GVFlags &GVFlags); + bool parseGVarFlags(GlobalVarSummary::GVarFlags &GVarFlags); + bool parseOptionalFFlags(FunctionSummary::FFlags &FFlags); + bool parseOptionalCalls(std::vector &Calls); + bool parseHotness(CalleeInfo::HotnessType &Hotness); + bool parseOptionalTypeIdInfo(FunctionSummary::TypeIdInfo &TypeIdInfo); + bool parseTypeTests(std::vector &TypeTests); + bool parseVFuncIdList(lltok::Kind Kind, std::vector &VFuncIdList); - bool ParseConstVCallList( + bool parseConstVCallList( lltok::Kind Kind, std::vector &ConstVCallList); using IdToIndexMapType = std::map>>; - bool ParseConstVCall(FunctionSummary::ConstVCall &ConstVCall, + bool parseConstVCall(FunctionSummary::ConstVCall &ConstVCall, IdToIndexMapType &IdToIndexMap, unsigned Index); - bool ParseVFuncId(FunctionSummary::VFuncId &VFuncId, + bool parseVFuncId(FunctionSummary::VFuncId &VFuncId, IdToIndexMapType &IdToIndexMap, unsigned Index); - bool ParseOptionalVTableFuncs(VTableFuncList &VTableFuncs); - bool ParseOptionalParamAccesses( + bool parseOptionalVTableFuncs(VTableFuncList &VTableFuncs); + bool parseOptionalParamAccesses( std::vector &Params); - bool ParseParamNo(uint64_t &ParamNo); + bool parseParamNo(uint64_t &ParamNo); using IdLocListType = std::vector>; - bool ParseParamAccess(FunctionSummary::ParamAccess &Param, + bool parseParamAccess(FunctionSummary::ParamAccess &Param, IdLocListType &IdLocList); - bool ParseParamAccessCall(FunctionSummary::ParamAccess::Call &Call, + bool parseParamAccessCall(FunctionSummary::ParamAccess::Call &Call, IdLocListType &IdLocList); - bool ParseParamAccessOffset(ConstantRange &range); - bool ParseOptionalRefs(std::vector &Refs); - bool ParseTypeIdEntry(unsigned ID); - bool ParseTypeIdSummary(TypeIdSummary &TIS); - bool ParseTypeIdCompatibleVtableEntry(unsigned ID); - bool ParseTypeTestResolution(TypeTestResolution &TTRes); - bool ParseOptionalWpdResolutions( + bool parseParamAccessOffset(ConstantRange &range); + bool parseOptionalRefs(std::vector &Refs); + bool parseTypeIdEntry(unsigned ID); + bool parseTypeIdSummary(TypeIdSummary &TIS); + bool parseTypeIdCompatibleVtableEntry(unsigned ID); + bool parseTypeTestResolution(TypeTestResolution &TTRes); + bool parseOptionalWpdResolutions( std::map &WPDResMap); - bool ParseWpdRes(WholeProgramDevirtResolution &WPDRes); - bool ParseOptionalResByArg( + bool parseWpdRes(WholeProgramDevirtResolution &WPDRes); + bool parseOptionalResByArg( std::map, WholeProgramDevirtResolution::ByArg> &ResByArg); - bool ParseArgs(std::vector &Args); - void AddGlobalValueToIndex(std::string Name, GlobalValue::GUID, + bool parseArgs(std::vector &Args); + void addGlobalValueToIndex(std::string Name, GlobalValue::GUID, GlobalValue::LinkageTypes Linkage, unsigned ID, std::unique_ptr Summary); // Type Parsing. - bool ParseType(Type *&Result, const Twine &Msg, bool AllowVoid = false); - bool ParseType(Type *&Result, bool AllowVoid = false) { - return ParseType(Result, "expected type", AllowVoid); + bool parseType(Type *&Result, const Twine &Msg, bool AllowVoid = false); + bool parseType(Type *&Result, bool AllowVoid = false) { + return parseType(Result, "expected type", AllowVoid); } - bool ParseType(Type *&Result, const Twine &Msg, LocTy &Loc, + bool parseType(Type *&Result, const Twine &Msg, LocTy &Loc, bool AllowVoid = false) { Loc = Lex.getLoc(); - return ParseType(Result, Msg, AllowVoid); + return parseType(Result, Msg, AllowVoid); } - bool ParseType(Type *&Result, LocTy &Loc, bool AllowVoid = false) { + bool parseType(Type *&Result, LocTy &Loc, bool AllowVoid = false) { Loc = Lex.getLoc(); - return ParseType(Result, AllowVoid); + return parseType(Result, AllowVoid); } - bool ParseAnonStructType(Type *&Result, bool Packed); - bool ParseStructBody(SmallVectorImpl &Body); - bool ParseStructDefinition(SMLoc TypeLoc, StringRef Name, + bool parseAnonStructType(Type *&Result, bool Packed); + bool parseStructBody(SmallVectorImpl &Body); + bool parseStructDefinition(SMLoc TypeLoc, StringRef Name, std::pair &Entry, Type *&ResultTy); - bool ParseArrayVectorType(Type *&Result, bool isVector); - bool ParseFunctionType(Type *&Result); + bool parseArrayVectorType(Type *&Result, bool isVector); + bool parseFunctionType(Type *&Result); // Function Semantic Analysis. class PerFunctionState { @@ -434,64 +434,64 @@ Function &getFunction() const { return F; } - bool FinishFunction(); + bool finishFunction(); /// GetVal - Get a value with the specified name or ID, creating a /// forward reference record if needed. This can return null if the value /// exists but does not have the right type. - Value *GetVal(const std::string &Name, Type *Ty, LocTy Loc, bool IsCall); - Value *GetVal(unsigned ID, Type *Ty, LocTy Loc, bool IsCall); + Value *getVal(const std::string &Name, Type *Ty, LocTy Loc, bool IsCall); + Value *getVal(unsigned ID, Type *Ty, LocTy Loc, bool IsCall); - /// SetInstName - After an instruction is parsed and inserted into its + /// setInstName - After an instruction is parsed and inserted into its /// basic block, this installs its name. - bool SetInstName(int NameID, const std::string &NameStr, LocTy NameLoc, + bool setInstName(int NameID, const std::string &NameStr, LocTy NameLoc, Instruction *Inst); /// GetBB - Get a basic block with the specified name or ID, creating a /// forward reference record if needed. This can return null if the value /// is not a BasicBlock. - BasicBlock *GetBB(const std::string &Name, LocTy Loc); - BasicBlock *GetBB(unsigned ID, LocTy Loc); + BasicBlock *getBB(const std::string &Name, LocTy Loc); + BasicBlock *getBB(unsigned ID, LocTy Loc); /// DefineBB - Define the specified basic block, which is either named or /// unnamed. If there is an error, this returns null otherwise it returns /// the block being defined. - BasicBlock *DefineBB(const std::string &Name, int NameID, LocTy Loc); + BasicBlock *defineBB(const std::string &Name, int NameID, LocTy Loc); bool resolveForwardRefBlockAddresses(); }; - bool ConvertValIDToValue(Type *Ty, ValID &ID, Value *&V, + bool convertValIDToValue(Type *Ty, ValID &ID, Value *&V, PerFunctionState *PFS, bool IsCall); Value *checkValidVariableType(LocTy Loc, const Twine &Name, Type *Ty, Value *Val, bool IsCall); bool parseConstantValue(Type *Ty, Constant *&C); - bool ParseValue(Type *Ty, Value *&V, PerFunctionState *PFS); - bool ParseValue(Type *Ty, Value *&V, PerFunctionState &PFS) { - return ParseValue(Ty, V, &PFS); + bool parseValue(Type *Ty, Value *&V, PerFunctionState *PFS); + bool parseValue(Type *Ty, Value *&V, PerFunctionState &PFS) { + return parseValue(Ty, V, &PFS); } - bool ParseValue(Type *Ty, Value *&V, LocTy &Loc, + bool parseValue(Type *Ty, Value *&V, LocTy &Loc, PerFunctionState &PFS) { Loc = Lex.getLoc(); - return ParseValue(Ty, V, &PFS); + return parseValue(Ty, V, &PFS); } - bool ParseTypeAndValue(Value *&V, PerFunctionState *PFS); - bool ParseTypeAndValue(Value *&V, PerFunctionState &PFS) { - return ParseTypeAndValue(V, &PFS); + bool parseTypeAndValue(Value *&V, PerFunctionState *PFS); + bool parseTypeAndValue(Value *&V, PerFunctionState &PFS) { + return parseTypeAndValue(V, &PFS); } - bool ParseTypeAndValue(Value *&V, LocTy &Loc, PerFunctionState &PFS) { + bool parseTypeAndValue(Value *&V, LocTy &Loc, PerFunctionState &PFS) { Loc = Lex.getLoc(); - return ParseTypeAndValue(V, PFS); + return parseTypeAndValue(V, PFS); } - bool ParseTypeAndBasicBlock(BasicBlock *&BB, LocTy &Loc, + bool parseTypeAndBasicBlock(BasicBlock *&BB, LocTy &Loc, PerFunctionState &PFS); - bool ParseTypeAndBasicBlock(BasicBlock *&BB, PerFunctionState &PFS) { + bool parseTypeAndBasicBlock(BasicBlock *&BB, PerFunctionState &PFS) { LocTy Loc; - return ParseTypeAndBasicBlock(BB, Loc, PFS); + return parseTypeAndBasicBlock(BB, Loc, PFS); } @@ -502,49 +502,49 @@ ParamInfo(LocTy loc, Value *v, AttributeSet attrs) : Loc(loc), V(v), Attrs(attrs) {} }; - bool ParseParameterList(SmallVectorImpl &ArgList, + bool parseParameterList(SmallVectorImpl &ArgList, PerFunctionState &PFS, bool IsMustTailCall = false, bool InVarArgsFunc = false); bool - ParseOptionalOperandBundles(SmallVectorImpl &BundleList, + parseOptionalOperandBundles(SmallVectorImpl &BundleList, PerFunctionState &PFS); - bool ParseExceptionArgs(SmallVectorImpl &Args, + bool parseExceptionArgs(SmallVectorImpl &Args, PerFunctionState &PFS); // Constant Parsing. - bool ParseValID(ValID &ID, PerFunctionState *PFS = nullptr); - bool ParseGlobalValue(Type *Ty, Constant *&C); - bool ParseGlobalTypeAndValue(Constant *&V); - bool ParseGlobalValueVector(SmallVectorImpl &Elts, + bool parseValID(ValID &ID, PerFunctionState *PFS = nullptr); + bool parseGlobalValue(Type *Ty, Constant *&C); + bool parseGlobalTypeAndValue(Constant *&V); + bool parseGlobalValueVector(SmallVectorImpl &Elts, Optional *InRangeOp = nullptr); bool parseOptionalComdat(StringRef GlobalName, Comdat *&C); - bool ParseMetadataAsValue(Value *&V, PerFunctionState &PFS); - bool ParseValueAsMetadata(Metadata *&MD, const Twine &TypeMsg, + bool parseMetadataAsValue(Value *&V, PerFunctionState &PFS); + bool parseValueAsMetadata(Metadata *&MD, const Twine &TypeMsg, PerFunctionState *PFS); - bool ParseMetadata(Metadata *&MD, PerFunctionState *PFS); - bool ParseMDTuple(MDNode *&MD, bool IsDistinct = false); - bool ParseMDNode(MDNode *&N); - bool ParseMDNodeTail(MDNode *&N); - bool ParseMDNodeVector(SmallVectorImpl &Elts); - bool ParseMetadataAttachment(unsigned &Kind, MDNode *&MD); - bool ParseInstructionMetadata(Instruction &Inst); - bool ParseGlobalObjectMetadataAttachment(GlobalObject &GO); - bool ParseOptionalFunctionMetadata(Function &F); + bool parseMetadata(Metadata *&MD, PerFunctionState *PFS); + bool parseMDTuple(MDNode *&MD, bool IsDistinct = false); + bool parseMDNode(MDNode *&N); + bool parseMDNodeTail(MDNode *&N); + bool parseMDNodeVector(SmallVectorImpl &Elts); + bool parseMetadataAttachment(unsigned &Kind, MDNode *&MD); + bool parseInstructionMetadata(Instruction &Inst); + bool parseGlobalObjectMetadataAttachment(GlobalObject &GO); + bool parseOptionalFunctionMetadata(Function &F); template - bool ParseMDField(LocTy Loc, StringRef Name, FieldTy &Result); - template bool ParseMDField(StringRef Name, FieldTy &Result); + bool parseMDField(LocTy Loc, StringRef Name, FieldTy &Result); + template bool parseMDField(StringRef Name, FieldTy &Result); template - bool ParseMDFieldsImplBody(ParserTy parseField); + bool parseMDFieldsImplBody(ParserTy parseField); template - bool ParseMDFieldsImpl(ParserTy parseField, LocTy &ClosingLoc); - bool ParseSpecializedMDNode(MDNode *&N, bool IsDistinct = false); + bool parseMDFieldsImpl(ParserTy parseField, LocTy &ClosingLoc); + bool parseSpecializedMDNode(MDNode *&N, bool IsDistinct = false); #define HANDLE_SPECIALIZED_MDNODE_LEAF(CLASS) \ - bool Parse##CLASS(MDNode *&Result, bool IsDistinct); + bool parse##CLASS(MDNode *&Result, bool IsDistinct); #include "llvm/IR/Metadata.def" // Function Parsing. @@ -556,64 +556,64 @@ ArgInfo(LocTy L, Type *ty, AttributeSet Attr, const std::string &N) : Loc(L), Ty(ty), Attrs(Attr), Name(N) {} }; - bool ParseArgumentList(SmallVectorImpl &ArgList, bool &isVarArg); - bool ParseFunctionHeader(Function *&Fn, bool isDefine); - bool ParseFunctionBody(Function &Fn); - bool ParseBasicBlock(PerFunctionState &PFS); + bool parseArgumentList(SmallVectorImpl &ArgList, bool &isVarArg); + bool parseFunctionHeader(Function *&Fn, bool isDefine); + bool parseFunctionBody(Function &Fn); + bool parseBasicBlock(PerFunctionState &PFS); enum TailCallType { TCT_None, TCT_Tail, TCT_MustTail }; // Instruction Parsing. Each instruction parsing routine can return with a // normal result, an error result, or return having eaten an extra comma. enum InstResult { InstNormal = 0, InstError = 1, InstExtraComma = 2 }; - int ParseInstruction(Instruction *&Inst, BasicBlock *BB, + int parseInstruction(Instruction *&Inst, BasicBlock *BB, PerFunctionState &PFS); - bool ParseCmpPredicate(unsigned &P, unsigned Opc); - - bool ParseRet(Instruction *&Inst, BasicBlock *BB, PerFunctionState &PFS); - bool ParseBr(Instruction *&Inst, PerFunctionState &PFS); - bool ParseSwitch(Instruction *&Inst, PerFunctionState &PFS); - bool ParseIndirectBr(Instruction *&Inst, PerFunctionState &PFS); - bool ParseInvoke(Instruction *&Inst, PerFunctionState &PFS); - bool ParseResume(Instruction *&Inst, PerFunctionState &PFS); - bool ParseCleanupRet(Instruction *&Inst, PerFunctionState &PFS); - bool ParseCatchRet(Instruction *&Inst, PerFunctionState &PFS); - bool ParseCatchSwitch(Instruction *&Inst, PerFunctionState &PFS); - bool ParseCatchPad(Instruction *&Inst, PerFunctionState &PFS); - bool ParseCleanupPad(Instruction *&Inst, PerFunctionState &PFS); - bool ParseCallBr(Instruction *&Inst, PerFunctionState &PFS); - - bool ParseUnaryOp(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc, + bool parseCmpPredicate(unsigned &P, unsigned Opc); + + bool parseRet(Instruction *&Inst, BasicBlock *BB, PerFunctionState &PFS); + bool parseBr(Instruction *&Inst, PerFunctionState &PFS); + bool parseSwitch(Instruction *&Inst, PerFunctionState &PFS); + bool parseIndirectBr(Instruction *&Inst, PerFunctionState &PFS); + bool parseInvoke(Instruction *&Inst, PerFunctionState &PFS); + bool parseResume(Instruction *&Inst, PerFunctionState &PFS); + bool parseCleanupRet(Instruction *&Inst, PerFunctionState &PFS); + bool parseCatchRet(Instruction *&Inst, PerFunctionState &PFS); + bool parseCatchSwitch(Instruction *&Inst, PerFunctionState &PFS); + bool parseCatchPad(Instruction *&Inst, PerFunctionState &PFS); + bool parseCleanupPad(Instruction *&Inst, PerFunctionState &PFS); + bool parseCallBr(Instruction *&Inst, PerFunctionState &PFS); + + bool parseUnaryOp(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc, bool IsFP); - bool ParseArithmetic(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc, + bool parseArithmetic(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc, bool IsFP); - bool ParseLogical(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc); - bool ParseCompare(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc); - bool ParseCast(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc); - bool ParseSelect(Instruction *&Inst, PerFunctionState &PFS); - bool ParseVA_Arg(Instruction *&Inst, PerFunctionState &PFS); - bool ParseExtractElement(Instruction *&Inst, PerFunctionState &PFS); - bool ParseInsertElement(Instruction *&Inst, PerFunctionState &PFS); - bool ParseShuffleVector(Instruction *&Inst, PerFunctionState &PFS); - int ParsePHI(Instruction *&Inst, PerFunctionState &PFS); - bool ParseLandingPad(Instruction *&Inst, PerFunctionState &PFS); - bool ParseCall(Instruction *&Inst, PerFunctionState &PFS, + bool parseLogical(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc); + bool parseCompare(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc); + bool parseCast(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc); + bool parseSelect(Instruction *&Inst, PerFunctionState &PFS); + bool parseVA_Arg(Instruction *&Inst, PerFunctionState &PFS); + bool parseExtractElement(Instruction *&Inst, PerFunctionState &PFS); + bool parseInsertElement(Instruction *&Inst, PerFunctionState &PFS); + bool parseShuffleVector(Instruction *&Inst, PerFunctionState &PFS); + int parsePHI(Instruction *&Inst, PerFunctionState &PFS); + bool parseLandingPad(Instruction *&Inst, PerFunctionState &PFS); + bool parseCall(Instruction *&Inst, PerFunctionState &PFS, CallInst::TailCallKind TCK); - int ParseAlloc(Instruction *&Inst, PerFunctionState &PFS); - int ParseLoad(Instruction *&Inst, PerFunctionState &PFS); - int ParseStore(Instruction *&Inst, PerFunctionState &PFS); - int ParseCmpXchg(Instruction *&Inst, PerFunctionState &PFS); - int ParseAtomicRMW(Instruction *&Inst, PerFunctionState &PFS); - int ParseFence(Instruction *&Inst, PerFunctionState &PFS); - int ParseGetElementPtr(Instruction *&Inst, PerFunctionState &PFS); - int ParseExtractValue(Instruction *&Inst, PerFunctionState &PFS); - int ParseInsertValue(Instruction *&Inst, PerFunctionState &PFS); - bool ParseFreeze(Instruction *&I, PerFunctionState &PFS); + int parseAlloc(Instruction *&Inst, PerFunctionState &PFS); + int parseLoad(Instruction *&Inst, PerFunctionState &PFS); + int parseStore(Instruction *&Inst, PerFunctionState &PFS); + int parseCmpXchg(Instruction *&Inst, PerFunctionState &PFS); + int parseAtomicRMW(Instruction *&Inst, PerFunctionState &PFS); + int parseFence(Instruction *&Inst, PerFunctionState &PFS); + int parseGetElementPtr(Instruction *&Inst, PerFunctionState &PFS); + int parseExtractValue(Instruction *&Inst, PerFunctionState &PFS); + int parseInsertValue(Instruction *&Inst, PerFunctionState &PFS); + bool parseFreeze(Instruction *&I, PerFunctionState &PFS); // Use-list order directives. - bool ParseUseListOrder(PerFunctionState *PFS = nullptr); - bool ParseUseListOrderBB(); - bool ParseUseListOrderIndexes(SmallVectorImpl &Indexes); + bool parseUseListOrder(PerFunctionState *PFS = nullptr); + bool parseUseListOrderBB(); + bool parseUseListOrderIndexes(SmallVectorImpl &Indexes); bool sortUseListOrder(Value *V, ArrayRef Indexes, SMLoc Loc); }; } // End llvm namespace Index: llvm/lib/AsmParser/LLParser.cpp =================================================================== --- llvm/lib/AsmParser/LLParser.cpp +++ llvm/lib/AsmParser/LLParser.cpp @@ -1,4 +1,4 @@ -//===-- LLParser.cpp - Parser Class ---------------------------------------===// +//===-- LLParser.cpp - parser Class ---------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. @@ -65,20 +65,20 @@ Lex.Lex(); if (Context.shouldDiscardValueNames()) - return Error( + return error( Lex.getLoc(), "Can't read textual IR with a Context that discards named Values"); if (M) { - if (ParseTargetDefinitions()) + if (parseTargetDefinitions()) return true; if (auto LayoutOverride = DataLayoutCallback(M->getTargetTriple())) M->setDataLayout(*LayoutOverride); } - return ParseTopLevelEntities() || ValidateEndOfModule(UpgradeDebugInfo) || - ValidateEndOfIndex(); + return parseTopLevelEntities() || validateEndOfModule(UpgradeDebugInfo) || + validateEndOfIndex(); } bool LLParser::parseStandaloneConstantValue(Constant *&C, @@ -87,10 +87,10 @@ Lex.Lex(); Type *Ty = nullptr; - if (ParseType(Ty) || parseConstantValue(Ty, C)) + if (parseType(Ty) || parseConstantValue(Ty, C)) return true; if (Lex.getKind() != lltok::Eof) - return Error(Lex.getLoc(), "expected end of string"); + return error(Lex.getLoc(), "expected end of string"); return false; } @@ -102,7 +102,7 @@ Read = 0; SMLoc Start = Lex.getLoc(); Ty = nullptr; - if (ParseType(Ty)) + if (parseType(Ty)) return true; SMLoc End = Lex.getLoc(); Read = End.getPointer() - Start.getPointer(); @@ -123,9 +123,9 @@ std::make_pair(I.first, std::make_pair(I.second, LocTy()))); } -/// ValidateEndOfModule - Do final validity and sanity checks at the end of the +/// validateEndOfModule - Do final validity and sanity checks at the end of the /// module. -bool LLParser::ValidateEndOfModule(bool UpgradeDebugInfo) { +bool LLParser::validateEndOfModule(bool UpgradeDebugInfo) { if (!M) return false; // Handle any function attribute group forward references. @@ -190,37 +190,37 @@ // If there are entries in ForwardRefBlockAddresses at this point, the // function was never defined. if (!ForwardRefBlockAddresses.empty()) - return Error(ForwardRefBlockAddresses.begin()->first.Loc, + return error(ForwardRefBlockAddresses.begin()->first.Loc, "expected function name in blockaddress"); for (const auto &NT : NumberedTypes) if (NT.second.second.isValid()) - return Error(NT.second.second, + return error(NT.second.second, "use of undefined type '%" + Twine(NT.first) + "'"); for (StringMap >::iterator I = NamedTypes.begin(), E = NamedTypes.end(); I != E; ++I) if (I->second.second.isValid()) - return Error(I->second.second, + return error(I->second.second, "use of undefined type named '" + I->getKey() + "'"); if (!ForwardRefComdats.empty()) - return Error(ForwardRefComdats.begin()->second, + return error(ForwardRefComdats.begin()->second, "use of undefined comdat '$" + ForwardRefComdats.begin()->first + "'"); if (!ForwardRefVals.empty()) - return Error(ForwardRefVals.begin()->second.second, + return error(ForwardRefVals.begin()->second.second, "use of undefined value '@" + ForwardRefVals.begin()->first + "'"); if (!ForwardRefValIDs.empty()) - return Error(ForwardRefValIDs.begin()->second.second, + return error(ForwardRefValIDs.begin()->second.second, "use of undefined value '@" + Twine(ForwardRefValIDs.begin()->first) + "'"); if (!ForwardRefMDNodes.empty()) - return Error(ForwardRefMDNodes.begin()->second.second, + return error(ForwardRefMDNodes.begin()->second.second, "use of undefined metadata '!" + Twine(ForwardRefMDNodes.begin()->first) + "'"); @@ -275,22 +275,22 @@ } /// Do final validity and sanity checks at the end of the index. -bool LLParser::ValidateEndOfIndex() { +bool LLParser::validateEndOfIndex() { if (!Index) return false; if (!ForwardRefValueInfos.empty()) - return Error(ForwardRefValueInfos.begin()->second.front().second, + return error(ForwardRefValueInfos.begin()->second.front().second, "use of undefined summary '^" + Twine(ForwardRefValueInfos.begin()->first) + "'"); if (!ForwardRefAliasees.empty()) - return Error(ForwardRefAliasees.begin()->second.front().second, + return error(ForwardRefAliasees.begin()->second.front().second, "use of undefined summary '^" + Twine(ForwardRefAliasees.begin()->first) + "'"); if (!ForwardRefTypeIds.empty()) - return Error(ForwardRefTypeIds.begin()->second.front().second, + return error(ForwardRefTypeIds.begin()->second.front().second, "use of undefined type id summary '^" + Twine(ForwardRefTypeIds.begin()->first) + "'"); @@ -301,15 +301,15 @@ // Top-Level Entities //===----------------------------------------------------------------------===// -bool LLParser::ParseTargetDefinitions() { +bool LLParser::parseTargetDefinitions() { while (true) { switch (Lex.getKind()) { case lltok::kw_target: - if (ParseTargetDefinition()) + if (parseTargetDefinition()) return true; break; case lltok::kw_source_filename: - if (ParseSourceFileName()) + if (parseSourceFileName()) return true; break; default: @@ -318,7 +318,7 @@ } } -bool LLParser::ParseTopLevelEntities() { +bool LLParser::parseTopLevelEntities() { // If there is no Module, then parse just the summary index entries. if (!M) { while (true) { @@ -326,11 +326,11 @@ case lltok::Eof: return false; case lltok::SummaryID: - if (ParseSummaryEntry()) + if (parseSummaryEntry()) return true; break; case lltok::kw_source_filename: - if (ParseSourceFileName()) + if (parseSourceFileName()) return true; break; default: @@ -341,27 +341,27 @@ } while (true) { switch (Lex.getKind()) { - default: return TokError("expected top-level entity"); + default: return tokError("expected top-level entity"); case lltok::Eof: return false; - case lltok::kw_declare: if (ParseDeclare()) return true; break; - case lltok::kw_define: if (ParseDefine()) return true; break; - case lltok::kw_module: if (ParseModuleAsm()) return true; break; - case lltok::kw_deplibs: if (ParseDepLibs()) return true; break; - case lltok::LocalVarID: if (ParseUnnamedType()) return true; break; - case lltok::LocalVar: if (ParseNamedType()) return true; break; - case lltok::GlobalID: if (ParseUnnamedGlobal()) return true; break; - case lltok::GlobalVar: if (ParseNamedGlobal()) return true; break; + case lltok::kw_declare: if (parseDeclare()) return true; break; + case lltok::kw_define: if (parseDefine()) return true; break; + case lltok::kw_module: if (parseModuleAsm()) return true; break; + case lltok::kw_deplibs: if (parseDepLibs()) return true; break; + case lltok::LocalVarID: if (parseUnnamedType()) return true; break; + case lltok::LocalVar: if (parseNamedType()) return true; break; + case lltok::GlobalID: if (parseUnnamedGlobal()) return true; break; + case lltok::GlobalVar: if (parseNamedGlobal()) return true; break; case lltok::ComdatVar: if (parseComdat()) return true; break; - case lltok::exclaim: if (ParseStandaloneMetadata()) return true; break; + case lltok::exclaim: if (parseStandaloneMetadata()) return true; break; case lltok::SummaryID: - if (ParseSummaryEntry()) + if (parseSummaryEntry()) return true; break; - case lltok::MetadataVar:if (ParseNamedMetadata()) return true; break; - case lltok::kw_attributes: if (ParseUnnamedAttrGrp()) return true; break; - case lltok::kw_uselistorder: if (ParseUseListOrder()) return true; break; + case lltok::MetadataVar:if (parseNamedMetadata()) return true; break; + case lltok::kw_attributes: if (parseUnnamedAttrGrp()) return true; break; + case lltok::kw_uselistorder: if (parseUseListOrder()) return true; break; case lltok::kw_uselistorder_bb: - if (ParseUseListOrderBB()) + if (parseUseListOrderBB()) return true; break; } @@ -370,13 +370,13 @@ /// toplevelentity /// ::= 'module' 'asm' STRINGCONSTANT -bool LLParser::ParseModuleAsm() { +bool LLParser::parseModuleAsm() { assert(Lex.getKind() == lltok::kw_module); Lex.Lex(); std::string AsmStr; - if (ParseToken(lltok::kw_asm, "expected 'module asm'") || - ParseStringConstant(AsmStr)) return true; + if (parseToken(lltok::kw_asm, "expected 'module asm'") || + parseStringConstant(AsmStr)) return true; M->appendModuleInlineAsm(AsmStr); return false; @@ -385,22 +385,22 @@ /// toplevelentity /// ::= 'target' 'triple' '=' STRINGCONSTANT /// ::= 'target' 'datalayout' '=' STRINGCONSTANT -bool LLParser::ParseTargetDefinition() { +bool LLParser::parseTargetDefinition() { assert(Lex.getKind() == lltok::kw_target); std::string Str; switch (Lex.Lex()) { - default: return TokError("unknown target property"); + default: return tokError("unknown target property"); case lltok::kw_triple: Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' after target triple") || - ParseStringConstant(Str)) + if (parseToken(lltok::equal, "expected '=' after target triple") || + parseStringConstant(Str)) return true; M->setTargetTriple(Str); return false; case lltok::kw_datalayout: Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' after target datalayout") || - ParseStringConstant(Str)) + if (parseToken(lltok::equal, "expected '=' after target datalayout") || + parseStringConstant(Str)) return true; M->setDataLayout(Str); return false; @@ -409,11 +409,11 @@ /// toplevelentity /// ::= 'source_filename' '=' STRINGCONSTANT -bool LLParser::ParseSourceFileName() { +bool LLParser::parseSourceFileName() { assert(Lex.getKind() == lltok::kw_source_filename); Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' after source_filename") || - ParseStringConstant(SourceFileName)) + if (parseToken(lltok::equal, "expected '=' after source_filename") || + parseStringConstant(SourceFileName)) return true; if (M) M->setSourceFileName(SourceFileName); @@ -424,11 +424,11 @@ /// ::= 'deplibs' '=' '[' ']' /// ::= 'deplibs' '=' '[' STRINGCONSTANT (',' STRINGCONSTANT)* ']' /// FIXME: Remove in 4.0. Currently parse, but ignore. -bool LLParser::ParseDepLibs() { +bool LLParser::parseDepLibs() { assert(Lex.getKind() == lltok::kw_deplibs); Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' after deplibs") || - ParseToken(lltok::lsquare, "expected '=' after deplibs")) + if (parseToken(lltok::equal, "expected '=' after deplibs") || + parseToken(lltok::lsquare, "expected '=' after deplibs")) return true; if (EatIfPresent(lltok::rsquare)) @@ -436,31 +436,31 @@ do { std::string Str; - if (ParseStringConstant(Str)) return true; + if (parseStringConstant(Str)) return true; } while (EatIfPresent(lltok::comma)); - return ParseToken(lltok::rsquare, "expected ']' at end of list"); + return parseToken(lltok::rsquare, "expected ']' at end of list"); } -/// ParseUnnamedType: +/// parseUnnamedType: /// ::= LocalVarID '=' 'type' type -bool LLParser::ParseUnnamedType() { +bool LLParser::parseUnnamedType() { LocTy TypeLoc = Lex.getLoc(); unsigned TypeID = Lex.getUIntVal(); Lex.Lex(); // eat LocalVarID; - if (ParseToken(lltok::equal, "expected '=' after name") || - ParseToken(lltok::kw_type, "expected 'type' after '='")) + if (parseToken(lltok::equal, "expected '=' after name") || + parseToken(lltok::kw_type, "expected 'type' after '='")) return true; Type *Result = nullptr; - if (ParseStructDefinition(TypeLoc, "", + if (parseStructDefinition(TypeLoc, "", NumberedTypes[TypeID], Result)) return true; if (!isa(Result)) { std::pair &Entry = NumberedTypes[TypeID]; if (Entry.first) - return Error(TypeLoc, "non-struct types may not be recursive"); + return error(TypeLoc, "non-struct types may not be recursive"); Entry.first = Result; Entry.second = SMLoc(); } @@ -470,23 +470,23 @@ /// toplevelentity /// ::= LocalVar '=' 'type' type -bool LLParser::ParseNamedType() { +bool LLParser::parseNamedType() { std::string Name = Lex.getStrVal(); LocTy NameLoc = Lex.getLoc(); Lex.Lex(); // eat LocalVar. - if (ParseToken(lltok::equal, "expected '=' after name") || - ParseToken(lltok::kw_type, "expected 'type' after name")) + if (parseToken(lltok::equal, "expected '=' after name") || + parseToken(lltok::kw_type, "expected 'type' after name")) return true; Type *Result = nullptr; - if (ParseStructDefinition(NameLoc, Name, + if (parseStructDefinition(NameLoc, Name, NamedTypes[Name], Result)) return true; if (!isa(Result)) { std::pair &Entry = NamedTypes[Name]; if (Entry.first) - return Error(NameLoc, "non-struct types may not be recursive"); + return error(NameLoc, "non-struct types may not be recursive"); Entry.first = Result; Entry.second = SMLoc(); } @@ -496,7 +496,7 @@ /// toplevelentity /// ::= 'declare' FunctionHeader -bool LLParser::ParseDeclare() { +bool LLParser::parseDeclare() { assert(Lex.getKind() == lltok::kw_declare); Lex.Lex(); @@ -504,13 +504,13 @@ while (Lex.getKind() == lltok::MetadataVar) { unsigned MDK; MDNode *N; - if (ParseMetadataAttachment(MDK, N)) + if (parseMetadataAttachment(MDK, N)) return true; MDs.push_back({MDK, N}); } Function *F; - if (ParseFunctionHeader(F, false)) + if (parseFunctionHeader(F, false)) return true; for (auto &MD : MDs) F->addMetadata(MD.first, *MD.second); @@ -519,33 +519,33 @@ /// toplevelentity /// ::= 'define' FunctionHeader (!dbg !56)* '{' ... -bool LLParser::ParseDefine() { +bool LLParser::parseDefine() { assert(Lex.getKind() == lltok::kw_define); Lex.Lex(); Function *F; - return ParseFunctionHeader(F, true) || - ParseOptionalFunctionMetadata(*F) || - ParseFunctionBody(*F); + return parseFunctionHeader(F, true) || + parseOptionalFunctionMetadata(*F) || + parseFunctionBody(*F); } -/// ParseGlobalType +/// parseGlobalType /// ::= 'constant' /// ::= 'global' -bool LLParser::ParseGlobalType(bool &IsConstant) { +bool LLParser::parseGlobalType(bool &IsConstant) { if (Lex.getKind() == lltok::kw_constant) IsConstant = true; else if (Lex.getKind() == lltok::kw_global) IsConstant = false; else { IsConstant = false; - return TokError("expected 'global' or 'constant'"); + return tokError("expected 'global' or 'constant'"); } Lex.Lex(); return false; } -bool LLParser::ParseOptionalUnnamedAddr( +bool LLParser::parseOptionalUnnamedAddr( GlobalVariable::UnnamedAddr &UnnamedAddr) { if (EatIfPresent(lltok::kw_unnamed_addr)) UnnamedAddr = GlobalValue::UnnamedAddr::Global; @@ -556,7 +556,7 @@ return false; } -/// ParseUnnamedGlobal: +/// parseUnnamedGlobal: /// OptionalVisibility (ALIAS | IFUNC) ... /// OptionalLinkage OptionalPreemptionSpecifier OptionalVisibility /// OptionalDLLStorageClass @@ -565,7 +565,7 @@ /// GlobalID '=' OptionalLinkage OptionalPreemptionSpecifier OptionalVisibility /// OptionalDLLStorageClass /// ... -> global variable -bool LLParser::ParseUnnamedGlobal() { +bool LLParser::parseUnnamedGlobal() { unsigned VarID = NumberedVals.size(); std::string Name; LocTy NameLoc = Lex.getLoc(); @@ -573,11 +573,11 @@ // Handle the GlobalID form. if (Lex.getKind() == lltok::GlobalID) { if (Lex.getUIntVal() != VarID) - return Error(Lex.getLoc(), "variable expected to be numbered '%" + + return error(Lex.getLoc(), "variable expected to be numbered '%" + Twine(VarID) + "'"); Lex.Lex(); // eat GlobalID; - if (ParseToken(lltok::equal, "expected '=' after name")) + if (parseToken(lltok::equal, "expected '=' after name")) return true; } @@ -586,25 +586,25 @@ bool DSOLocal; GlobalVariable::ThreadLocalMode TLM; GlobalVariable::UnnamedAddr UnnamedAddr; - if (ParseOptionalLinkage(Linkage, HasLinkage, Visibility, DLLStorageClass, + if (parseOptionalLinkage(Linkage, HasLinkage, Visibility, DLLStorageClass, DSOLocal) || - ParseOptionalThreadLocal(TLM) || ParseOptionalUnnamedAddr(UnnamedAddr)) + parseOptionalThreadLocal(TLM) || parseOptionalUnnamedAddr(UnnamedAddr)) return true; if (Lex.getKind() != lltok::kw_alias && Lex.getKind() != lltok::kw_ifunc) - return ParseGlobal(Name, NameLoc, Linkage, HasLinkage, Visibility, + return parseGlobal(Name, NameLoc, Linkage, HasLinkage, Visibility, DLLStorageClass, DSOLocal, TLM, UnnamedAddr); return parseIndirectSymbol(Name, NameLoc, Linkage, Visibility, DLLStorageClass, DSOLocal, TLM, UnnamedAddr); } -/// ParseNamedGlobal: +/// parseNamedGlobal: /// GlobalVar '=' OptionalVisibility (ALIAS | IFUNC) ... /// GlobalVar '=' OptionalLinkage OptionalPreemptionSpecifier /// OptionalVisibility OptionalDLLStorageClass /// ... -> global variable -bool LLParser::ParseNamedGlobal() { +bool LLParser::parseNamedGlobal() { assert(Lex.getKind() == lltok::GlobalVar); LocTy NameLoc = Lex.getLoc(); std::string Name = Lex.getStrVal(); @@ -615,14 +615,14 @@ bool DSOLocal; GlobalVariable::ThreadLocalMode TLM; GlobalVariable::UnnamedAddr UnnamedAddr; - if (ParseToken(lltok::equal, "expected '=' in global variable") || - ParseOptionalLinkage(Linkage, HasLinkage, Visibility, DLLStorageClass, + if (parseToken(lltok::equal, "expected '=' in global variable") || + parseOptionalLinkage(Linkage, HasLinkage, Visibility, DLLStorageClass, DSOLocal) || - ParseOptionalThreadLocal(TLM) || ParseOptionalUnnamedAddr(UnnamedAddr)) + parseOptionalThreadLocal(TLM) || parseOptionalUnnamedAddr(UnnamedAddr)) return true; if (Lex.getKind() != lltok::kw_alias && Lex.getKind() != lltok::kw_ifunc) - return ParseGlobal(Name, NameLoc, Linkage, HasLinkage, Visibility, + return parseGlobal(Name, NameLoc, Linkage, HasLinkage, Visibility, DLLStorageClass, DSOLocal, TLM, UnnamedAddr); return parseIndirectSymbol(Name, NameLoc, Linkage, Visibility, @@ -635,16 +635,16 @@ LocTy NameLoc = Lex.getLoc(); Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' here")) + if (parseToken(lltok::equal, "expected '=' here")) return true; - if (ParseToken(lltok::kw_comdat, "expected comdat keyword")) - return TokError("expected comdat type"); + if (parseToken(lltok::kw_comdat, "expected comdat keyword")) + return tokError("expected comdat type"); Comdat::SelectionKind SK; switch (Lex.getKind()) { default: - return TokError("unknown selection kind"); + return tokError("unknown selection kind"); case lltok::kw_any: SK = Comdat::Any; break; @@ -667,7 +667,7 @@ Module::ComdatSymTabType &ComdatSymTab = M->getComdatSymbolTable(); Module::ComdatSymTabType::iterator I = ComdatSymTab.find(Name); if (I != ComdatSymTab.end() && !ForwardRefComdats.erase(Name)) - return Error(NameLoc, "redefinition of comdat '$" + Name + "'"); + return error(NameLoc, "redefinition of comdat '$" + Name + "'"); Comdat *C; if (I != ComdatSymTab.end()) @@ -681,20 +681,20 @@ // MDString: // ::= '!' STRINGCONSTANT -bool LLParser::ParseMDString(MDString *&Result) { +bool LLParser::parseMDString(MDString *&Result) { std::string Str; - if (ParseStringConstant(Str)) return true; + if (parseStringConstant(Str)) return true; Result = MDString::get(Context, Str); return false; } // MDNode: // ::= '!' MDNodeNumber -bool LLParser::ParseMDNodeID(MDNode *&Result) { +bool LLParser::parseMDNodeID(MDNode *&Result) { // !{ ..., !42, ... } LocTy IDLoc = Lex.getLoc(); unsigned MID = 0; - if (ParseUInt32(MID)) + if (parseUInt32(MID)) return true; // If not a forward reference, just return it now. @@ -712,61 +712,61 @@ return false; } -/// ParseNamedMetadata: +/// parseNamedMetadata: /// !foo = !{ !1, !2 } -bool LLParser::ParseNamedMetadata() { +bool LLParser::parseNamedMetadata() { assert(Lex.getKind() == lltok::MetadataVar); std::string Name = Lex.getStrVal(); Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' here") || - ParseToken(lltok::exclaim, "Expected '!' here") || - ParseToken(lltok::lbrace, "Expected '{' here")) + if (parseToken(lltok::equal, "expected '=' here") || + parseToken(lltok::exclaim, "Expected '!' here") || + parseToken(lltok::lbrace, "Expected '{' here")) return true; NamedMDNode *NMD = M->getOrInsertNamedMetadata(Name); if (Lex.getKind() != lltok::rbrace) do { MDNode *N = nullptr; - // Parse DIExpressions inline as a special case. They are still MDNodes, + // parse DIExpressions inline as a special case. They are still MDNodes, // so they can still appear in named metadata. Remove this logic if they // become plain Metadata. if (Lex.getKind() == lltok::MetadataVar && Lex.getStrVal() == "DIExpression") { - if (ParseDIExpression(N, /*IsDistinct=*/false)) + if (parseDIExpression(N, /*IsDistinct=*/false)) return true; - } else if (ParseToken(lltok::exclaim, "Expected '!' here") || - ParseMDNodeID(N)) { + } else if (parseToken(lltok::exclaim, "Expected '!' here") || + parseMDNodeID(N)) { return true; } NMD->addOperand(N); } while (EatIfPresent(lltok::comma)); - return ParseToken(lltok::rbrace, "expected end of metadata node"); + return parseToken(lltok::rbrace, "expected end of metadata node"); } -/// ParseStandaloneMetadata: +/// parseStandaloneMetadata: /// !42 = !{...} -bool LLParser::ParseStandaloneMetadata() { +bool LLParser::parseStandaloneMetadata() { assert(Lex.getKind() == lltok::exclaim); Lex.Lex(); unsigned MetadataID = 0; MDNode *Init; - if (ParseUInt32(MetadataID) || - ParseToken(lltok::equal, "expected '=' here")) + if (parseUInt32(MetadataID) || + parseToken(lltok::equal, "expected '=' here")) return true; // Detect common error, from old metadata syntax. if (Lex.getKind() == lltok::Type) - return TokError("unexpected type in metadata definition"); + return tokError("unexpected type in metadata definition"); bool IsDistinct = EatIfPresent(lltok::kw_distinct); if (Lex.getKind() == lltok::MetadataVar) { - if (ParseSpecializedMDNode(Init, IsDistinct)) + if (parseSpecializedMDNode(Init, IsDistinct)) return true; - } else if (ParseToken(lltok::exclaim, "Expected '!' here") || - ParseMDTuple(Init, IsDistinct)) + } else if (parseToken(lltok::exclaim, "Expected '!' here") || + parseMDTuple(Init, IsDistinct)) return true; // See if this was forward referenced, if so, handle it. @@ -778,7 +778,7 @@ assert(NumberedMetadata[MetadataID] == Init && "Tracking VH didn't work"); } else { if (NumberedMetadata.count(MetadataID)) - return TokError("Metadata id is already used"); + return tokError("Metadata id is already used"); NumberedMetadata[MetadataID].reset(Init); } @@ -786,7 +786,7 @@ } // Skips a single module summary entry. -bool LLParser::SkipModuleSummaryEntry() { +bool LLParser::skipModuleSummaryEntry() { // Each module summary entry consists of a tag for the entry // type, followed by a colon, then the fields which may be surrounded by // nested sets of parentheses. The "tag:" looks like a Label. Once parsing @@ -795,16 +795,16 @@ if (Lex.getKind() != lltok::kw_gv && Lex.getKind() != lltok::kw_module && Lex.getKind() != lltok::kw_typeid && Lex.getKind() != lltok::kw_flags && Lex.getKind() != lltok::kw_blockcount) - return TokError( + return tokError( "Expected 'gv', 'module', 'typeid', 'flags' or 'blockcount' at the " "start of summary entry"); if (Lex.getKind() == lltok::kw_flags) - return ParseSummaryIndexFlags(); + return parseSummaryIndexFlags(); if (Lex.getKind() == lltok::kw_blockcount) - return ParseBlockCount(); + return parseBlockCount(); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' at start of summary entry") || - ParseToken(lltok::lparen, "expected '(' at start of summary entry")) + if (parseToken(lltok::colon, "expected ':' at start of summary entry") || + parseToken(lltok::lparen, "expected '(' at start of summary entry")) return true; // Now walk through the parenthesized entry, until the number of open // parentheses goes back down to 0 (the first '(' was parsed above). @@ -818,7 +818,7 @@ NumOpenParen--; break; case lltok::Eof: - return TokError("found end of file while parsing summary entry"); + return tokError("found end of file while parsing summary entry"); default: // Skip everything in between parentheses. break; @@ -830,7 +830,7 @@ /// SummaryEntry /// ::= SummaryID '=' GVEntry | ModuleEntry | TypeIdEntry -bool LLParser::ParseSummaryEntry() { +bool LLParser::parseSummaryEntry() { assert(Lex.getKind() == lltok::SummaryID); unsigned SummaryID = Lex.getUIntVal(); @@ -839,35 +839,35 @@ Lex.setIgnoreColonInIdentifiers(true); Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' here")) + if (parseToken(lltok::equal, "expected '=' here")) return true; // If we don't have an index object, skip the summary entry. if (!Index) - return SkipModuleSummaryEntry(); + return skipModuleSummaryEntry(); bool result = false; switch (Lex.getKind()) { case lltok::kw_gv: - result = ParseGVEntry(SummaryID); + result = parseGVEntry(SummaryID); break; case lltok::kw_module: - result = ParseModuleEntry(SummaryID); + result = parseModuleEntry(SummaryID); break; case lltok::kw_typeid: - result = ParseTypeIdEntry(SummaryID); + result = parseTypeIdEntry(SummaryID); break; case lltok::kw_typeidCompatibleVTable: - result = ParseTypeIdCompatibleVtableEntry(SummaryID); + result = parseTypeIdCompatibleVtableEntry(SummaryID); break; case lltok::kw_flags: - result = ParseSummaryIndexFlags(); + result = parseSummaryIndexFlags(); break; case lltok::kw_blockcount: - result = ParseBlockCount(); + result = parseBlockCount(); break; default: - result = Error(Lex.getLoc(), "unexpected summary kind"); + result = error(Lex.getLoc(), "unexpected summary kind"); break; } Lex.setIgnoreColonInIdentifiers(false); @@ -917,16 +917,16 @@ GlobalValue::LinkageTypes Linkage = (GlobalValue::LinkageTypes) L; if(IsAlias && !GlobalAlias::isValidLinkage(Linkage)) - return Error(NameLoc, "invalid linkage type for alias"); + return error(NameLoc, "invalid linkage type for alias"); if (!isValidVisibilityForLinkage(Visibility, L)) - return Error(NameLoc, + return error(NameLoc, "symbol with local linkage must have default visibility"); Type *Ty; LocTy ExplicitTypeLoc = Lex.getLoc(); - if (ParseType(Ty) || - ParseToken(lltok::comma, "expected comma after alias or ifunc's type")) + if (parseType(Ty) || + parseToken(lltok::comma, "expected comma after alias or ifunc's type")) return true; Constant *Aliasee; @@ -935,31 +935,31 @@ Lex.getKind() != lltok::kw_getelementptr && Lex.getKind() != lltok::kw_addrspacecast && Lex.getKind() != lltok::kw_inttoptr) { - if (ParseGlobalTypeAndValue(Aliasee)) + if (parseGlobalTypeAndValue(Aliasee)) return true; } else { // The bitcast dest type is not present, it is implied by the dest type. ValID ID; - if (ParseValID(ID)) + if (parseValID(ID)) return true; if (ID.Kind != ValID::t_Constant) - return Error(AliaseeLoc, "invalid aliasee"); + return error(AliaseeLoc, "invalid aliasee"); Aliasee = ID.ConstantVal; } Type *AliaseeType = Aliasee->getType(); auto *PTy = dyn_cast(AliaseeType); if (!PTy) - return Error(AliaseeLoc, "An alias or ifunc must have pointer type"); + return error(AliaseeLoc, "An alias or ifunc must have pointer type"); unsigned AddrSpace = PTy->getAddressSpace(); if (IsAlias && Ty != PTy->getElementType()) - return Error( + return error( ExplicitTypeLoc, "explicit pointee type doesn't match operand's pointee type"); if (!IsAlias && !PTy->getElementType()->isFunctionTy()) - return Error( + return error( ExplicitTypeLoc, "explicit pointee type should be a function type"); @@ -971,7 +971,7 @@ GVal = M->getNamedValue(Name); if (GVal) { if (!ForwardRefVals.erase(Name)) - return Error(NameLoc, "redefinition of global '@" + Name + "'"); + return error(NameLoc, "redefinition of global '@" + Name + "'"); } } else { auto I = ForwardRefValIDs.find(NumberedVals.size()); @@ -1005,10 +1005,10 @@ if (Lex.getKind() == lltok::kw_partition) { Lex.Lex(); GA->setPartition(Lex.getStrVal()); - if (ParseToken(lltok::StringConstant, "expected partition string")) + if (parseToken(lltok::StringConstant, "expected partition string")) return true; } else { - return TokError("unknown alias or ifunc property!"); + return tokError("unknown alias or ifunc property!"); } } @@ -1018,7 +1018,7 @@ if (GVal) { // Verify that types agree. if (GVal->getType() != GA->getType()) - return Error( + return error( ExplicitTypeLoc, "forward reference and definition of alias have different types"); @@ -1041,7 +1041,7 @@ return false; } -/// ParseGlobal +/// parseGlobal /// ::= GlobalVar '=' OptionalLinkage OptionalPreemptionSpecifier /// OptionalVisibility OptionalDLLStorageClass /// OptionalThreadLocal OptionalUnnamedAddr OptionalAddrSpace @@ -1054,13 +1054,13 @@ /// Everything up to and including OptionalUnnamedAddr has been parsed /// already. /// -bool LLParser::ParseGlobal(const std::string &Name, LocTy NameLoc, +bool LLParser::parseGlobal(const std::string &Name, LocTy NameLoc, unsigned Linkage, bool HasLinkage, unsigned Visibility, unsigned DLLStorageClass, bool DSOLocal, GlobalVariable::ThreadLocalMode TLM, GlobalVariable::UnnamedAddr UnnamedAddr) { if (!isValidVisibilityForLinkage(Visibility, Linkage)) - return Error(NameLoc, + return error(NameLoc, "symbol with local linkage must have default visibility"); unsigned AddrSpace; @@ -1069,12 +1069,12 @@ LocTy TyLoc; Type *Ty = nullptr; - if (ParseOptionalAddrSpace(AddrSpace) || - ParseOptionalToken(lltok::kw_externally_initialized, + if (parseOptionalAddrSpace(AddrSpace) || + parseOptionalToken(lltok::kw_externally_initialized, IsExternallyInitialized, &IsExternallyInitializedLoc) || - ParseGlobalType(IsConstant) || - ParseType(Ty, TyLoc)) + parseGlobalType(IsConstant) || + parseType(Ty, TyLoc)) return true; // If the linkage is specified and is external, then no initializer is @@ -1083,12 +1083,12 @@ if (!HasLinkage || !GlobalValue::isValidDeclarationLinkage( (GlobalValue::LinkageTypes)Linkage)) { - if (ParseGlobalValue(Ty, Init)) + if (parseGlobalValue(Ty, Init)) return true; } if (Ty->isFunctionTy() || !PointerType::isValidElementType(Ty)) - return Error(TyLoc, "invalid type for global variable"); + return error(TyLoc, "invalid type for global variable"); GlobalValue *GVal = nullptr; @@ -1097,7 +1097,7 @@ GVal = M->getNamedValue(Name); if (GVal) { if (!ForwardRefVals.erase(Name)) - return Error(NameLoc, "redefinition of global '@" + Name + "'"); + return error(NameLoc, "redefinition of global '@" + Name + "'"); } } else { auto I = ForwardRefValIDs.find(NumberedVals.size()); @@ -1114,7 +1114,7 @@ AddrSpace); } else { if (GVal->getValueType() != Ty) - return Error(TyLoc, + return error(TyLoc, "forward reference and definition of global have different types"); GV = cast(GVal); @@ -1138,26 +1138,26 @@ GV->setThreadLocalMode(TLM); GV->setUnnamedAddr(UnnamedAddr); - // Parse attributes on the global. + // parse attributes on the global. while (Lex.getKind() == lltok::comma) { Lex.Lex(); if (Lex.getKind() == lltok::kw_section) { Lex.Lex(); GV->setSection(Lex.getStrVal()); - if (ParseToken(lltok::StringConstant, "expected global section string")) + if (parseToken(lltok::StringConstant, "expected global section string")) return true; } else if (Lex.getKind() == lltok::kw_partition) { Lex.Lex(); GV->setPartition(Lex.getStrVal()); - if (ParseToken(lltok::StringConstant, "expected partition string")) + if (parseToken(lltok::StringConstant, "expected partition string")) return true; } else if (Lex.getKind() == lltok::kw_align) { MaybeAlign Alignment; - if (ParseOptionalAlignment(Alignment)) return true; + if (parseOptionalAlignment(Alignment)) return true; GV->setAlignment(Alignment); } else if (Lex.getKind() == lltok::MetadataVar) { - if (ParseGlobalObjectMetadataAttachment(*GV)) + if (parseGlobalObjectMetadataAttachment(*GV)) return true; } else { Comdat *C; @@ -1166,14 +1166,14 @@ if (C) GV->setComdat(C); else - return TokError("unknown global variable property!"); + return tokError("unknown global variable property!"); } } AttrBuilder Attrs; LocTy BuiltinLoc; std::vector FwdRefAttrGrps; - if (ParseFnAttributeValuePairs(Attrs, FwdRefAttrGrps, false, BuiltinLoc)) + if (parseFnAttributeValuePairs(Attrs, FwdRefAttrGrps, false, BuiltinLoc)) return true; if (Attrs.hasAttributes() || !FwdRefAttrGrps.empty()) { GV->setAttributes(AttributeSet::get(Context, Attrs)); @@ -1183,37 +1183,37 @@ return false; } -/// ParseUnnamedAttrGrp +/// parseUnnamedAttrGrp /// ::= 'attributes' AttrGrpID '=' '{' AttrValPair+ '}' -bool LLParser::ParseUnnamedAttrGrp() { +bool LLParser::parseUnnamedAttrGrp() { assert(Lex.getKind() == lltok::kw_attributes); LocTy AttrGrpLoc = Lex.getLoc(); Lex.Lex(); if (Lex.getKind() != lltok::AttrGrpID) - return TokError("expected attribute group id"); + return tokError("expected attribute group id"); unsigned VarID = Lex.getUIntVal(); std::vector unused; LocTy BuiltinLoc; Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' here") || - ParseToken(lltok::lbrace, "expected '{' here") || - ParseFnAttributeValuePairs(NumberedAttrBuilders[VarID], unused, true, + if (parseToken(lltok::equal, "expected '=' here") || + parseToken(lltok::lbrace, "expected '{' here") || + parseFnAttributeValuePairs(NumberedAttrBuilders[VarID], unused, true, BuiltinLoc) || - ParseToken(lltok::rbrace, "expected end of attribute group")) + parseToken(lltok::rbrace, "expected end of attribute group")) return true; if (!NumberedAttrBuilders[VarID].hasAttributes()) - return Error(AttrGrpLoc, "attribute group has no attributes"); + return error(AttrGrpLoc, "attribute group has no attributes"); return false; } -/// ParseFnAttributeValuePairs +/// parseFnAttributeValuePairs /// ::= | '=' -bool LLParser::ParseFnAttributeValuePairs(AttrBuilder &B, +bool LLParser::parseFnAttributeValuePairs(AttrBuilder &B, std::vector &FwdRefAttrGrps, bool inAttrGrp, LocTy &BuiltinLoc) { bool HaveError = false; @@ -1227,7 +1227,7 @@ switch (Token) { default: if (!inAttrGrp) return HaveError; - return Error(Lex.getLoc(), "unterminated attribute group"); + return error(Lex.getLoc(), "unterminated attribute group"); case lltok::rbrace: // Finished. return false; @@ -1238,7 +1238,7 @@ // define void @foo() #1 { ... } if (inAttrGrp) HaveError |= - Error(Lex.getLoc(), + error(Lex.getLoc(), "cannot have an attribute group reference in an attribute group"); unsigned AttrGrpNum = Lex.getUIntVal(); @@ -1250,7 +1250,7 @@ } // Target-dependent attributes: case lltok::StringConstant: { - if (ParseStringAttribute(B)) + if (parseStringAttribute(B)) return true; continue; } @@ -1264,11 +1264,11 @@ if (inAttrGrp) { Lex.Lex(); uint32_t Value = 0; - if (ParseToken(lltok::equal, "expected '=' here") || ParseUInt32(Value)) + if (parseToken(lltok::equal, "expected '=' here") || parseUInt32(Value)) return true; Alignment = Align(Value); } else { - if (ParseOptionalAlignment(Alignment)) + if (parseOptionalAlignment(Alignment)) return true; } B.addAlignmentAttr(Alignment); @@ -1278,11 +1278,11 @@ unsigned Alignment; if (inAttrGrp) { Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' here") || - ParseUInt32(Alignment)) + if (parseToken(lltok::equal, "expected '=' here") || + parseUInt32(Alignment)) return true; } else { - if (ParseOptionalStackAlignment(Alignment)) + if (parseOptionalStackAlignment(Alignment)) return true; } B.addStackAlignmentAttr(Alignment); @@ -1361,18 +1361,18 @@ case lltok::kw_writeonly: B.addAttribute(Attribute::WriteOnly); break; case lltok::kw_preallocated: { Type *Ty; - if (ParsePreallocated(Ty)) + if (parsePreallocated(Ty)) return true; B.addPreallocatedAttr(Ty); break; } - // Error handling. + // error handling. case lltok::kw_inreg: case lltok::kw_signext: case lltok::kw_zeroext: HaveError |= - Error(Lex.getLoc(), + error(Lex.getLoc(), "invalid use of attribute on a function"); break; case lltok::kw_byval: @@ -1391,12 +1391,12 @@ case lltok::kw_immarg: case lltok::kw_byref: HaveError |= - Error(Lex.getLoc(), + error(Lex.getLoc(), "invalid use of parameter-only attribute on a function"); break; } - // ParsePreallocated() consumes token + // parsePreallocated() consumes token if (Token != lltok::kw_preallocated) Lex.Lex(); } @@ -1432,22 +1432,22 @@ return Val; } if (Ty->isLabelTy()) - Error(Loc, "'" + Name + "' is not a basic block"); + error(Loc, "'" + Name + "' is not a basic block"); else - Error(Loc, "'" + Name + "' defined with type '" + + error(Loc, "'" + Name + "' defined with type '" + getTypeString(Val->getType()) + "' but expected '" + getTypeString(SuggestedTy) + "'"); return nullptr; } -/// GetGlobalVal - Get a value with the specified name or ID, creating a +/// getGlobalVal - Get a value with the specified name or ID, creating a /// forward reference record if needed. This can return null if the value /// exists but does not have the right type. -GlobalValue *LLParser::GetGlobalVal(const std::string &Name, Type *Ty, +GlobalValue *LLParser::getGlobalVal(const std::string &Name, Type *Ty, LocTy Loc, bool IsCall) { PointerType *PTy = dyn_cast(Ty); if (!PTy) { - Error(Loc, "global variable reference must have pointer type"); + error(Loc, "global variable reference must have pointer type"); return nullptr; } @@ -1474,11 +1474,11 @@ return FwdVal; } -GlobalValue *LLParser::GetGlobalVal(unsigned ID, Type *Ty, LocTy Loc, +GlobalValue *LLParser::getGlobalVal(unsigned ID, Type *Ty, LocTy Loc, bool IsCall) { PointerType *PTy = dyn_cast(Ty); if (!PTy) { - Error(Loc, "global variable reference must have pointer type"); + error(Loc, "global variable reference must have pointer type"); return nullptr; } @@ -1524,56 +1524,56 @@ // Helper Routines. //===----------------------------------------------------------------------===// -/// ParseToken - If the current token has the specified kind, eat it and return +/// parseToken - If the current token has the specified kind, eat it and return /// success. Otherwise, emit the specified error and return failure. -bool LLParser::ParseToken(lltok::Kind T, const char *ErrMsg) { +bool LLParser::parseToken(lltok::Kind T, const char *ErrMsg) { if (Lex.getKind() != T) - return TokError(ErrMsg); + return tokError(ErrMsg); Lex.Lex(); return false; } -/// ParseStringConstant +/// parseStringConstant /// ::= StringConstant -bool LLParser::ParseStringConstant(std::string &Result) { +bool LLParser::parseStringConstant(std::string &Result) { if (Lex.getKind() != lltok::StringConstant) - return TokError("expected string constant"); + return tokError("expected string constant"); Result = Lex.getStrVal(); Lex.Lex(); return false; } -/// ParseUInt32 +/// parseUInt32 /// ::= uint32 -bool LLParser::ParseUInt32(uint32_t &Val) { +bool LLParser::parseUInt32(uint32_t &Val) { if (Lex.getKind() != lltok::APSInt || Lex.getAPSIntVal().isSigned()) - return TokError("expected integer"); + return tokError("expected integer"); uint64_t Val64 = Lex.getAPSIntVal().getLimitedValue(0xFFFFFFFFULL+1); if (Val64 != unsigned(Val64)) - return TokError("expected 32-bit integer (too large)"); + return tokError("expected 32-bit integer (too large)"); Val = Val64; Lex.Lex(); return false; } -/// ParseUInt64 +/// parseUInt64 /// ::= uint64 -bool LLParser::ParseUInt64(uint64_t &Val) { +bool LLParser::parseUInt64(uint64_t &Val) { if (Lex.getKind() != lltok::APSInt || Lex.getAPSIntVal().isSigned()) - return TokError("expected integer"); + return tokError("expected integer"); Val = Lex.getAPSIntVal().getLimitedValue(); Lex.Lex(); return false; } -/// ParseTLSModel +/// parseTLSModel /// := 'localdynamic' /// := 'initialexec' /// := 'localexec' -bool LLParser::ParseTLSModel(GlobalVariable::ThreadLocalMode &TLM) { +bool LLParser::parseTLSModel(GlobalVariable::ThreadLocalMode &TLM) { switch (Lex.getKind()) { default: - return TokError("expected localdynamic, initialexec or localexec"); + return tokError("expected localdynamic, initialexec or localexec"); case lltok::kw_localdynamic: TLM = GlobalVariable::LocalDynamicTLSModel; break; @@ -1589,11 +1589,11 @@ return false; } -/// ParseOptionalThreadLocal +/// parseOptionalThreadLocal /// := /*empty*/ /// := 'thread_local' /// := 'thread_local' '(' tlsmodel ')' -bool LLParser::ParseOptionalThreadLocal(GlobalVariable::ThreadLocalMode &TLM) { +bool LLParser::parseOptionalThreadLocal(GlobalVariable::ThreadLocalMode &TLM) { TLM = GlobalVariable::NotThreadLocal; if (!EatIfPresent(lltok::kw_thread_local)) return false; @@ -1601,39 +1601,39 @@ TLM = GlobalVariable::GeneralDynamicTLSModel; if (Lex.getKind() == lltok::lparen) { Lex.Lex(); - return ParseTLSModel(TLM) || - ParseToken(lltok::rparen, "expected ')' after thread local model"); + return parseTLSModel(TLM) || + parseToken(lltok::rparen, "expected ')' after thread local model"); } return false; } -/// ParseOptionalAddrSpace +/// parseOptionalAddrSpace /// := /*empty*/ /// := 'addrspace' '(' uint32 ')' -bool LLParser::ParseOptionalAddrSpace(unsigned &AddrSpace, unsigned DefaultAS) { +bool LLParser::parseOptionalAddrSpace(unsigned &AddrSpace, unsigned DefaultAS) { AddrSpace = DefaultAS; if (!EatIfPresent(lltok::kw_addrspace)) return false; - return ParseToken(lltok::lparen, "expected '(' in address space") || - ParseUInt32(AddrSpace) || - ParseToken(lltok::rparen, "expected ')' in address space"); + return parseToken(lltok::lparen, "expected '(' in address space") || + parseUInt32(AddrSpace) || + parseToken(lltok::rparen, "expected ')' in address space"); } -/// ParseStringAttribute +/// parseStringAttribute /// := StringConstant /// := StringConstant '=' StringConstant -bool LLParser::ParseStringAttribute(AttrBuilder &B) { +bool LLParser::parseStringAttribute(AttrBuilder &B) { std::string Attr = Lex.getStrVal(); Lex.Lex(); std::string Val; - if (EatIfPresent(lltok::equal) && ParseStringConstant(Val)) + if (EatIfPresent(lltok::equal) && parseStringConstant(Val)) return true; B.addAttribute(Attr, Val); return false; } -/// ParseOptionalParamAttrs - Parse a potentially empty list of parameter attributes. -bool LLParser::ParseOptionalParamAttrs(AttrBuilder &B) { +/// parseOptionalParamAttrs - parse a potentially empty list of parameter attributes. +bool LLParser::parseOptionalParamAttrs(AttrBuilder &B) { bool HaveError = false; B.clear(); @@ -1644,48 +1644,48 @@ default: // End of attributes. return HaveError; case lltok::StringConstant: { - if (ParseStringAttribute(B)) + if (parseStringAttribute(B)) return true; continue; } case lltok::kw_align: { MaybeAlign Alignment; - if (ParseOptionalAlignment(Alignment, true)) + if (parseOptionalAlignment(Alignment, true)) return true; B.addAlignmentAttr(Alignment); continue; } case lltok::kw_byval: { Type *Ty; - if (ParseByValWithOptionalType(Ty)) + if (parseByValWithOptionalType(Ty)) return true; B.addByValAttr(Ty); continue; } case lltok::kw_preallocated: { Type *Ty; - if (ParsePreallocated(Ty)) + if (parsePreallocated(Ty)) return true; B.addPreallocatedAttr(Ty); continue; } case lltok::kw_dereferenceable: { uint64_t Bytes; - if (ParseOptionalDerefAttrBytes(lltok::kw_dereferenceable, Bytes)) + if (parseOptionalDerefAttrBytes(lltok::kw_dereferenceable, Bytes)) return true; B.addDereferenceableAttr(Bytes); continue; } case lltok::kw_dereferenceable_or_null: { uint64_t Bytes; - if (ParseOptionalDerefAttrBytes(lltok::kw_dereferenceable_or_null, Bytes)) + if (parseOptionalDerefAttrBytes(lltok::kw_dereferenceable_or_null, Bytes)) return true; B.addDereferenceableOrNullAttr(Bytes); continue; } case lltok::kw_byref: { Type *Ty; - if (ParseByRef(Ty)) + if (parseByRef(Ty)) return true; B.addByRefAttr(Ty); continue; @@ -1746,7 +1746,7 @@ case lltok::kw_shadowcallstack: case lltok::kw_strictfp: case lltok::kw_uwtable: - HaveError |= Error(Lex.getLoc(), "invalid use of function-only attribute"); + HaveError |= error(Lex.getLoc(), "invalid use of function-only attribute"); break; } @@ -1754,8 +1754,8 @@ } } -/// ParseOptionalReturnAttrs - Parse a potentially empty list of return attributes. -bool LLParser::ParseOptionalReturnAttrs(AttrBuilder &B) { +/// parseOptionalReturnAttrs - parse a potentially empty list of return attributes. +bool LLParser::parseOptionalReturnAttrs(AttrBuilder &B) { bool HaveError = false; B.clear(); @@ -1766,27 +1766,27 @@ default: // End of attributes. return HaveError; case lltok::StringConstant: { - if (ParseStringAttribute(B)) + if (parseStringAttribute(B)) return true; continue; } case lltok::kw_dereferenceable: { uint64_t Bytes; - if (ParseOptionalDerefAttrBytes(lltok::kw_dereferenceable, Bytes)) + if (parseOptionalDerefAttrBytes(lltok::kw_dereferenceable, Bytes)) return true; B.addDereferenceableAttr(Bytes); continue; } case lltok::kw_dereferenceable_or_null: { uint64_t Bytes; - if (ParseOptionalDerefAttrBytes(lltok::kw_dereferenceable_or_null, Bytes)) + if (parseOptionalDerefAttrBytes(lltok::kw_dereferenceable_or_null, Bytes)) return true; B.addDereferenceableOrNullAttr(Bytes); continue; } case lltok::kw_align: { MaybeAlign Alignment; - if (ParseOptionalAlignment(Alignment)) + if (parseOptionalAlignment(Alignment)) return true; B.addAlignmentAttr(Alignment); continue; @@ -1800,7 +1800,7 @@ case lltok::kw_signext: B.addAttribute(Attribute::SExt); break; case lltok::kw_zeroext: B.addAttribute(Attribute::ZExt); break; - // Error handling. + // error handling. case lltok::kw_byval: case lltok::kw_inalloca: case lltok::kw_nest: @@ -1811,7 +1811,7 @@ case lltok::kw_swiftself: case lltok::kw_immarg: case lltok::kw_byref: - HaveError |= Error(Lex.getLoc(), "invalid use of parameter-only attribute"); + HaveError |= error(Lex.getLoc(), "invalid use of parameter-only attribute"); break; case lltok::kw_alignstack: @@ -1850,15 +1850,15 @@ case lltok::kw_shadowcallstack: case lltok::kw_strictfp: case lltok::kw_uwtable: - HaveError |= Error(Lex.getLoc(), "invalid use of function-only attribute"); + HaveError |= error(Lex.getLoc(), "invalid use of function-only attribute"); break; case lltok::kw_readnone: case lltok::kw_readonly: - HaveError |= Error(Lex.getLoc(), "invalid use of attribute on return type"); + HaveError |= error(Lex.getLoc(), "invalid use of attribute on return type"); break; case lltok::kw_preallocated: HaveError |= - Error(Lex.getLoc(), + error(Lex.getLoc(), "invalid use of parameter-only/call site-only attribute"); break; } @@ -1898,7 +1898,7 @@ } } -/// ParseOptionalLinkage +/// parseOptionalLinkage /// ::= /*empty*/ /// ::= 'private' /// ::= 'internal' @@ -1911,25 +1911,25 @@ /// ::= 'common' /// ::= 'extern_weak' /// ::= 'external' -bool LLParser::ParseOptionalLinkage(unsigned &Res, bool &HasLinkage, +bool LLParser::parseOptionalLinkage(unsigned &Res, bool &HasLinkage, unsigned &Visibility, unsigned &DLLStorageClass, bool &DSOLocal) { Res = parseOptionalLinkageAux(Lex.getKind(), HasLinkage); if (HasLinkage) Lex.Lex(); - ParseOptionalDSOLocal(DSOLocal); - ParseOptionalVisibility(Visibility); - ParseOptionalDLLStorageClass(DLLStorageClass); + parseOptionalDSOLocal(DSOLocal); + parseOptionalVisibility(Visibility); + parseOptionalDLLStorageClass(DLLStorageClass); if (DSOLocal && DLLStorageClass == GlobalValue::DLLImportStorageClass) { - return Error(Lex.getLoc(), "dso_location and DLL-StorageClass mismatch"); + return error(Lex.getLoc(), "dso_location and DLL-StorageClass mismatch"); } return false; } -void LLParser::ParseOptionalDSOLocal(bool &DSOLocal) { +void LLParser::parseOptionalDSOLocal(bool &DSOLocal) { switch (Lex.getKind()) { default: DSOLocal = false; @@ -1945,13 +1945,13 @@ } } -/// ParseOptionalVisibility +/// parseOptionalVisibility /// ::= /*empty*/ /// ::= 'default' /// ::= 'hidden' /// ::= 'protected' /// -void LLParser::ParseOptionalVisibility(unsigned &Res) { +void LLParser::parseOptionalVisibility(unsigned &Res) { switch (Lex.getKind()) { default: Res = GlobalValue::DefaultVisibility; @@ -1969,12 +1969,12 @@ Lex.Lex(); } -/// ParseOptionalDLLStorageClass +/// parseOptionalDLLStorageClass /// ::= /*empty*/ /// ::= 'dllimport' /// ::= 'dllexport' /// -void LLParser::ParseOptionalDLLStorageClass(unsigned &Res) { +void LLParser::parseOptionalDLLStorageClass(unsigned &Res) { switch (Lex.getKind()) { default: Res = GlobalValue::DefaultStorageClass; @@ -1989,7 +1989,7 @@ Lex.Lex(); } -/// ParseOptionalCallingConv +/// parseOptionalCallingConv /// ::= /*empty*/ /// ::= 'ccc' /// ::= 'fastcc' @@ -2035,7 +2035,7 @@ /// ::= 'tailcc' /// ::= 'cc' UINT /// -bool LLParser::ParseOptionalCallingConv(unsigned &CC) { +bool LLParser::parseOptionalCallingConv(unsigned &CC) { switch (Lex.getKind()) { default: CC = CallingConv::C; return false; case lltok::kw_ccc: CC = CallingConv::C; break; @@ -2085,7 +2085,7 @@ case lltok::kw_tailcc: CC = CallingConv::Tail; break; case lltok::kw_cc: { Lex.Lex(); - return ParseUInt32(CC); + return parseUInt32(CC); } } @@ -2093,28 +2093,28 @@ return false; } -/// ParseMetadataAttachment +/// parseMetadataAttachment /// ::= !dbg !42 -bool LLParser::ParseMetadataAttachment(unsigned &Kind, MDNode *&MD) { +bool LLParser::parseMetadataAttachment(unsigned &Kind, MDNode *&MD) { assert(Lex.getKind() == lltok::MetadataVar && "Expected metadata attachment"); std::string Name = Lex.getStrVal(); Kind = M->getMDKindID(Name); Lex.Lex(); - return ParseMDNode(MD); + return parseMDNode(MD); } -/// ParseInstructionMetadata +/// parseInstructionMetadata /// ::= !dbg !42 (',' !dbg !57)* -bool LLParser::ParseInstructionMetadata(Instruction &Inst) { +bool LLParser::parseInstructionMetadata(Instruction &Inst) { do { if (Lex.getKind() != lltok::MetadataVar) - return TokError("expected metadata after comma"); + return tokError("expected metadata after comma"); unsigned MDK; MDNode *N; - if (ParseMetadataAttachment(MDK, N)) + if (parseMetadataAttachment(MDK, N)) return true; Inst.setMetadata(MDK, N); @@ -2126,31 +2126,31 @@ return false; } -/// ParseGlobalObjectMetadataAttachment +/// parseGlobalObjectMetadataAttachment /// ::= !dbg !57 -bool LLParser::ParseGlobalObjectMetadataAttachment(GlobalObject &GO) { +bool LLParser::parseGlobalObjectMetadataAttachment(GlobalObject &GO) { unsigned MDK; MDNode *N; - if (ParseMetadataAttachment(MDK, N)) + if (parseMetadataAttachment(MDK, N)) return true; GO.addMetadata(MDK, *N); return false; } -/// ParseOptionalFunctionMetadata +/// parseOptionalFunctionMetadata /// ::= (!dbg !57)* -bool LLParser::ParseOptionalFunctionMetadata(Function &F) { +bool LLParser::parseOptionalFunctionMetadata(Function &F) { while (Lex.getKind() == lltok::MetadataVar) - if (ParseGlobalObjectMetadataAttachment(F)) + if (parseGlobalObjectMetadataAttachment(F)) return true; return false; } -/// ParseOptionalAlignment +/// parseOptionalAlignment /// ::= /* empty */ /// ::= 'align' 4 -bool LLParser::ParseOptionalAlignment(MaybeAlign &Alignment, bool AllowParens) { +bool LLParser::parseOptionalAlignment(MaybeAlign &Alignment, bool AllowParens) { Alignment = None; if (!EatIfPresent(lltok::kw_align)) return false; @@ -2164,26 +2164,26 @@ HaveParens = true; } - if (ParseUInt32(Value)) + if (parseUInt32(Value)) return true; if (HaveParens && !EatIfPresent(lltok::rparen)) - return Error(ParenLoc, "expected ')'"); + return error(ParenLoc, "expected ')'"); if (!isPowerOf2_32(Value)) - return Error(AlignLoc, "alignment is not a power of two"); + return error(AlignLoc, "alignment is not a power of two"); if (Value > Value::MaximumAlignment) - return Error(AlignLoc, "huge alignments are not supported yet"); + return error(AlignLoc, "huge alignments are not supported yet"); Alignment = Align(Value); return false; } -/// ParseOptionalDerefAttrBytes +/// parseOptionalDerefAttrBytes /// ::= /* empty */ /// ::= AttrKind '(' 4 ')' /// /// where AttrKind is either 'dereferenceable' or 'dereferenceable_or_null'. -bool LLParser::ParseOptionalDerefAttrBytes(lltok::Kind AttrKind, +bool LLParser::parseOptionalDerefAttrBytes(lltok::Kind AttrKind, uint64_t &Bytes) { assert((AttrKind == lltok::kw_dereferenceable || AttrKind == lltok::kw_dereferenceable_or_null) && @@ -2194,24 +2194,24 @@ return false; LocTy ParenLoc = Lex.getLoc(); if (!EatIfPresent(lltok::lparen)) - return Error(ParenLoc, "expected '('"); + return error(ParenLoc, "expected '('"); LocTy DerefLoc = Lex.getLoc(); - if (ParseUInt64(Bytes)) return true; + if (parseUInt64(Bytes)) return true; ParenLoc = Lex.getLoc(); if (!EatIfPresent(lltok::rparen)) - return Error(ParenLoc, "expected ')'"); + return error(ParenLoc, "expected ')'"); if (!Bytes) - return Error(DerefLoc, "dereferenceable bytes must be non-zero"); + return error(DerefLoc, "dereferenceable bytes must be non-zero"); return false; } -/// ParseOptionalCommaAlign +/// parseOptionalCommaAlign /// ::= /// ::= ',' align 4 /// /// This returns with AteExtraComma set to true if it ate an excess comma at the /// end. -bool LLParser::ParseOptionalCommaAlign(MaybeAlign &Alignment, +bool LLParser::parseOptionalCommaAlign(MaybeAlign &Alignment, bool &AteExtraComma) { AteExtraComma = false; while (EatIfPresent(lltok::comma)) { @@ -2222,21 +2222,21 @@ } if (Lex.getKind() != lltok::kw_align) - return Error(Lex.getLoc(), "expected metadata or 'align'"); + return error(Lex.getLoc(), "expected metadata or 'align'"); - if (ParseOptionalAlignment(Alignment)) return true; + if (parseOptionalAlignment(Alignment)) return true; } return false; } -/// ParseOptionalCommaAddrSpace +/// parseOptionalCommaAddrSpace /// ::= /// ::= ',' addrspace(1) /// /// This returns with AteExtraComma set to true if it ate an excess comma at the /// end. -bool LLParser::ParseOptionalCommaAddrSpace(unsigned &AddrSpace, +bool LLParser::parseOptionalCommaAddrSpace(unsigned &AddrSpace, LocTy &Loc, bool &AteExtraComma) { AteExtraComma = false; @@ -2249,9 +2249,9 @@ Loc = Lex.getLoc(); if (Lex.getKind() != lltok::kw_addrspace) - return Error(Lex.getLoc(), "expected metadata or 'addrspace'"); + return error(Lex.getLoc(), "expected metadata or 'addrspace'"); - if (ParseOptionalAddrSpace(AddrSpace)) + if (parseOptionalAddrSpace(AddrSpace)) return true; } @@ -2264,18 +2264,18 @@ auto StartParen = Lex.getLoc(); if (!EatIfPresent(lltok::lparen)) - return Error(StartParen, "expected '('"); + return error(StartParen, "expected '('"); - if (ParseUInt32(BaseSizeArg)) + if (parseUInt32(BaseSizeArg)) return true; if (EatIfPresent(lltok::comma)) { auto HowManyAt = Lex.getLoc(); unsigned HowMany; - if (ParseUInt32(HowMany)) + if (parseUInt32(HowMany)) return true; if (HowMany == BaseSizeArg) - return Error(HowManyAt, + return error(HowManyAt, "'allocsize' indices can't refer to the same parameter"); HowManyArg = HowMany; } else @@ -2283,42 +2283,42 @@ auto EndParen = Lex.getLoc(); if (!EatIfPresent(lltok::rparen)) - return Error(EndParen, "expected ')'"); + return error(EndParen, "expected ')'"); return false; } -/// ParseScopeAndOrdering +/// parseScopeAndOrdering /// if isAtomic: ::= SyncScope? AtomicOrdering /// else: ::= /// /// This sets Scope and Ordering to the parsed values. -bool LLParser::ParseScopeAndOrdering(bool isAtomic, SyncScope::ID &SSID, +bool LLParser::parseScopeAndOrdering(bool isAtomic, SyncScope::ID &SSID, AtomicOrdering &Ordering) { if (!isAtomic) return false; - return ParseScope(SSID) || ParseOrdering(Ordering); + return parseScope(SSID) || parseOrdering(Ordering); } -/// ParseScope +/// parseScope /// ::= syncscope("singlethread" | "")? /// /// This sets synchronization scope ID to the ID of the parsed value. -bool LLParser::ParseScope(SyncScope::ID &SSID) { +bool LLParser::parseScope(SyncScope::ID &SSID) { SSID = SyncScope::System; if (EatIfPresent(lltok::kw_syncscope)) { auto StartParenAt = Lex.getLoc(); if (!EatIfPresent(lltok::lparen)) - return Error(StartParenAt, "Expected '(' in syncscope"); + return error(StartParenAt, "Expected '(' in syncscope"); std::string SSN; auto SSNAt = Lex.getLoc(); - if (ParseStringConstant(SSN)) - return Error(SSNAt, "Expected synchronization scope name"); + if (parseStringConstant(SSN)) + return error(SSNAt, "Expected synchronization scope name"); auto EndParenAt = Lex.getLoc(); if (!EatIfPresent(lltok::rparen)) - return Error(EndParenAt, "Expected ')' in syncscope"); + return error(EndParenAt, "Expected ')' in syncscope"); SSID = Context.getOrInsertSyncScopeID(SSN); } @@ -2326,13 +2326,13 @@ return false; } -/// ParseOrdering +/// parseOrdering /// ::= AtomicOrdering /// /// This sets Ordering to the parsed value. -bool LLParser::ParseOrdering(AtomicOrdering &Ordering) { +bool LLParser::parseOrdering(AtomicOrdering &Ordering) { switch (Lex.getKind()) { - default: return TokError("Expected ordering on atomic instruction"); + default: return tokError("Expected ordering on atomic instruction"); case lltok::kw_unordered: Ordering = AtomicOrdering::Unordered; break; case lltok::kw_monotonic: Ordering = AtomicOrdering::Monotonic; break; // Not specified yet: @@ -2348,50 +2348,50 @@ return false; } -/// ParseOptionalStackAlignment +/// parseOptionalStackAlignment /// ::= /* empty */ /// ::= 'alignstack' '(' 4 ')' -bool LLParser::ParseOptionalStackAlignment(unsigned &Alignment) { +bool LLParser::parseOptionalStackAlignment(unsigned &Alignment) { Alignment = 0; if (!EatIfPresent(lltok::kw_alignstack)) return false; LocTy ParenLoc = Lex.getLoc(); if (!EatIfPresent(lltok::lparen)) - return Error(ParenLoc, "expected '('"); + return error(ParenLoc, "expected '('"); LocTy AlignLoc = Lex.getLoc(); - if (ParseUInt32(Alignment)) return true; + if (parseUInt32(Alignment)) return true; ParenLoc = Lex.getLoc(); if (!EatIfPresent(lltok::rparen)) - return Error(ParenLoc, "expected ')'"); + return error(ParenLoc, "expected ')'"); if (!isPowerOf2_32(Alignment)) - return Error(AlignLoc, "stack alignment is not a power of two"); + return error(AlignLoc, "stack alignment is not a power of two"); return false; } -/// ParseIndexList - This parses the index list for an insert/extractvalue +/// parseIndexList - This parses the index list for an insert/extractvalue /// instruction. This sets AteExtraComma in the case where we eat an extra /// comma at the end of the line and find that it is followed by metadata. /// Clients that don't allow metadata can call the version of this function that /// only takes one argument. /// -/// ParseIndexList +/// parseIndexList /// ::= (',' uint32)+ /// -bool LLParser::ParseIndexList(SmallVectorImpl &Indices, +bool LLParser::parseIndexList(SmallVectorImpl &Indices, bool &AteExtraComma) { AteExtraComma = false; if (Lex.getKind() != lltok::comma) - return TokError("expected ',' as start of index list"); + return tokError("expected ',' as start of index list"); while (EatIfPresent(lltok::comma)) { if (Lex.getKind() == lltok::MetadataVar) { - if (Indices.empty()) return TokError("expected index"); + if (Indices.empty()) return tokError("expected index"); AteExtraComma = true; return false; } unsigned Idx = 0; - if (ParseUInt32(Idx)) return true; + if (parseUInt32(Idx)) return true; Indices.push_back(Idx); } @@ -2402,12 +2402,12 @@ // Type Parsing. //===----------------------------------------------------------------------===// -/// ParseType - Parse a type. -bool LLParser::ParseType(Type *&Result, const Twine &Msg, bool AllowVoid) { +/// parseType - parse a type. +bool LLParser::parseType(Type *&Result, const Twine &Msg, bool AllowVoid) { SMLoc TypeLoc = Lex.getLoc(); switch (Lex.getKind()) { default: - return TokError(Msg); + return tokError(Msg); case lltok::Type: // Type ::= 'float' | 'void' (etc) Result = Lex.getTyVal(); @@ -2415,23 +2415,23 @@ break; case lltok::lbrace: // Type ::= StructType - if (ParseAnonStructType(Result, false)) + if (parseAnonStructType(Result, false)) return true; break; case lltok::lsquare: // Type ::= '[' ... ']' Lex.Lex(); // eat the lsquare. - if (ParseArrayVectorType(Result, false)) + if (parseArrayVectorType(Result, false)) return true; break; case lltok::less: // Either vector or packed struct. // Type ::= '<' ... '>' Lex.Lex(); if (Lex.getKind() == lltok::lbrace) { - if (ParseAnonStructType(Result, true) || - ParseToken(lltok::greater, "expected '>' at end of packed struct")) + if (parseAnonStructType(Result, true) || + parseToken(lltok::greater, "expected '>' at end of packed struct")) return true; - } else if (ParseArrayVectorType(Result, true)) + } else if (parseArrayVectorType(Result, true)) return true; break; case lltok::LocalVar: { @@ -2465,23 +2465,23 @@ } } - // Parse the type suffixes. + // parse the type suffixes. while (true) { switch (Lex.getKind()) { // End of type. default: if (!AllowVoid && Result->isVoidTy()) - return Error(TypeLoc, "void type only allowed for function results"); + return error(TypeLoc, "void type only allowed for function results"); return false; // Type ::= Type '*' case lltok::star: if (Result->isLabelTy()) - return TokError("basic block pointers are invalid"); + return tokError("basic block pointers are invalid"); if (Result->isVoidTy()) - return TokError("pointers to void are invalid - use i8* instead"); + return tokError("pointers to void are invalid - use i8* instead"); if (!PointerType::isValidElementType(Result)) - return TokError("pointer to this type is invalid"); + return tokError("pointer to this type is invalid"); Result = PointerType::getUnqual(Result); Lex.Lex(); break; @@ -2489,14 +2489,14 @@ // Type ::= Type 'addrspace' '(' uint32 ')' '*' case lltok::kw_addrspace: { if (Result->isLabelTy()) - return TokError("basic block pointers are invalid"); + return tokError("basic block pointers are invalid"); if (Result->isVoidTy()) - return TokError("pointers to void are invalid; use i8* instead"); + return tokError("pointers to void are invalid; use i8* instead"); if (!PointerType::isValidElementType(Result)) - return TokError("pointer to this type is invalid"); + return tokError("pointer to this type is invalid"); unsigned AddrSpace; - if (ParseOptionalAddrSpace(AddrSpace) || - ParseToken(lltok::star, "expected '*' in address space")) + if (parseOptionalAddrSpace(AddrSpace) || + parseToken(lltok::star, "expected '*' in address space")) return true; Result = PointerType::get(Result, AddrSpace); @@ -2505,55 +2505,55 @@ /// Types '(' ArgTypeListI ')' OptFuncAttrs case lltok::lparen: - if (ParseFunctionType(Result)) + if (parseFunctionType(Result)) return true; break; } } } -/// ParseParameterList +/// parseParameterList /// ::= '(' ')' /// ::= '(' Arg (',' Arg)* ')' /// Arg /// ::= Type OptionalAttributes Value OptionalAttributes -bool LLParser::ParseParameterList(SmallVectorImpl &ArgList, +bool LLParser::parseParameterList(SmallVectorImpl &ArgList, PerFunctionState &PFS, bool IsMustTailCall, bool InVarArgsFunc) { - if (ParseToken(lltok::lparen, "expected '(' in call")) + if (parseToken(lltok::lparen, "expected '(' in call")) return true; while (Lex.getKind() != lltok::rparen) { // If this isn't the first argument, we need a comma. if (!ArgList.empty() && - ParseToken(lltok::comma, "expected ',' in argument list")) + parseToken(lltok::comma, "expected ',' in argument list")) return true; - // Parse an ellipsis if this is a musttail call in a variadic function. + // parse an ellipsis if this is a musttail call in a variadic function. if (Lex.getKind() == lltok::dotdotdot) { const char *Msg = "unexpected ellipsis in argument list for "; if (!IsMustTailCall) - return TokError(Twine(Msg) + "non-musttail call"); + return tokError(Twine(Msg) + "non-musttail call"); if (!InVarArgsFunc) - return TokError(Twine(Msg) + "musttail call in non-varargs function"); + return tokError(Twine(Msg) + "musttail call in non-varargs function"); Lex.Lex(); // Lex the '...', it is purely for readability. - return ParseToken(lltok::rparen, "expected ')' at end of argument list"); + return parseToken(lltok::rparen, "expected ')' at end of argument list"); } - // Parse the argument. + // parse the argument. LocTy ArgLoc; Type *ArgTy = nullptr; AttrBuilder ArgAttrs; Value *V; - if (ParseType(ArgTy, ArgLoc)) + if (parseType(ArgTy, ArgLoc)) return true; if (ArgTy->isMetadataTy()) { - if (ParseMetadataAsValue(V, PFS)) + if (parseMetadataAsValue(V, PFS)) return true; } else { // Otherwise, handle normal operands. - if (ParseOptionalParamAttrs(ArgAttrs) || ParseValue(ArgTy, V, PFS)) + if (parseOptionalParamAttrs(ArgAttrs) || parseValue(ArgTy, V, PFS)) return true; } ArgList.push_back(ParamInfo( @@ -2561,57 +2561,57 @@ } if (IsMustTailCall && InVarArgsFunc) - return TokError("expected '...' at end of argument list for musttail call " + return tokError("expected '...' at end of argument list for musttail call " "in varargs function"); Lex.Lex(); // Lex the ')'. return false; } -/// ParseByValWithOptionalType +/// parseByValWithOptionalType /// ::= byval /// ::= byval() -bool LLParser::ParseByValWithOptionalType(Type *&Result) { +bool LLParser::parseByValWithOptionalType(Type *&Result) { Result = nullptr; if (!EatIfPresent(lltok::kw_byval)) return true; if (!EatIfPresent(lltok::lparen)) return false; - if (ParseType(Result)) + if (parseType(Result)) return true; if (!EatIfPresent(lltok::rparen)) - return Error(Lex.getLoc(), "expected ')'"); + return error(Lex.getLoc(), "expected ')'"); return false; } -/// ParseRequiredTypeAttr +/// parseRequiredTypeAttr /// ::= attrname() -bool LLParser::ParseRequiredTypeAttr(Type *&Result, lltok::Kind AttrName) { +bool LLParser::parseRequiredTypeAttr(Type *&Result, lltok::Kind AttrName) { Result = nullptr; if (!EatIfPresent(AttrName)) return true; if (!EatIfPresent(lltok::lparen)) - return Error(Lex.getLoc(), "expected '('"); - if (ParseType(Result)) + return error(Lex.getLoc(), "expected '('"); + if (parseType(Result)) return true; if (!EatIfPresent(lltok::rparen)) - return Error(Lex.getLoc(), "expected ')'"); + return error(Lex.getLoc(), "expected ')'"); return false; } -/// ParsePreallocated +/// parsePreallocated /// ::= preallocated() -bool LLParser::ParsePreallocated(Type *&Result) { - return ParseRequiredTypeAttr(Result, lltok::kw_preallocated); +bool LLParser::parsePreallocated(Type *&Result) { + return parseRequiredTypeAttr(Result, lltok::kw_preallocated); } -/// ParseByRef +/// parseByRef /// ::= byref() -bool LLParser::ParseByRef(Type *&Result) { - return ParseRequiredTypeAttr(Result, lltok::kw_byref); +bool LLParser::parseByRef(Type *&Result) { + return parseRequiredTypeAttr(Result, lltok::kw_byref); } -/// ParseOptionalOperandBundles +/// parseOptionalOperandBundles /// ::= /*empty*/ /// ::= '[' OperandBundle [, OperandBundle ]* ']' /// @@ -2620,7 +2620,7 @@ /// ::= bundle-tag '(' Type Value [, Type Value ]* ')' /// /// bundle-tag ::= String Constant -bool LLParser::ParseOptionalOperandBundles( +bool LLParser::parseOptionalOperandBundles( SmallVectorImpl &BundleList, PerFunctionState &PFS) { LocTy BeginLoc = Lex.getLoc(); if (!EatIfPresent(lltok::lsquare)) @@ -2629,26 +2629,26 @@ while (Lex.getKind() != lltok::rsquare) { // If this isn't the first operand bundle, we need a comma. if (!BundleList.empty() && - ParseToken(lltok::comma, "expected ',' in input list")) + parseToken(lltok::comma, "expected ',' in input list")) return true; std::string Tag; - if (ParseStringConstant(Tag)) + if (parseStringConstant(Tag)) return true; - if (ParseToken(lltok::lparen, "expected '(' in operand bundle")) + if (parseToken(lltok::lparen, "expected '(' in operand bundle")) return true; std::vector Inputs; while (Lex.getKind() != lltok::rparen) { // If this isn't the first input, we need a comma. if (!Inputs.empty() && - ParseToken(lltok::comma, "expected ',' in input list")) + parseToken(lltok::comma, "expected ',' in input list")) return true; Type *Ty = nullptr; Value *Input = nullptr; - if (ParseType(Ty) || ParseValue(Ty, Input, PFS)) + if (parseType(Ty) || parseValue(Ty, Input, PFS)) return true; Inputs.push_back(Input); } @@ -2659,13 +2659,13 @@ } if (BundleList.empty()) - return Error(BeginLoc, "operand bundle set must not be empty"); + return error(BeginLoc, "operand bundle set must not be empty"); Lex.Lex(); // Lex the ']'. return false; } -/// ParseArgumentList - Parse the argument list for a function type or function +/// parseArgumentList - parse the argument list for a function type or function /// prototype. /// ::= '(' ArgTypeListI ')' /// ArgTypeListI @@ -2674,7 +2674,7 @@ /// ::= ArgTypeList ',' '...' /// ::= ArgType (',' ArgType)* /// -bool LLParser::ParseArgumentList(SmallVectorImpl &ArgList, +bool LLParser::parseArgumentList(SmallVectorImpl &ArgList, bool &isVarArg){ unsigned CurValID = 0; isVarArg = false; @@ -2692,25 +2692,25 @@ AttrBuilder Attrs; std::string Name; - if (ParseType(ArgTy) || - ParseOptionalParamAttrs(Attrs)) return true; + if (parseType(ArgTy) || + parseOptionalParamAttrs(Attrs)) return true; if (ArgTy->isVoidTy()) - return Error(TypeLoc, "argument can not have void type"); + return error(TypeLoc, "argument can not have void type"); if (Lex.getKind() == lltok::LocalVar) { Name = Lex.getStrVal(); Lex.Lex(); } else if (Lex.getKind() == lltok::LocalVarID) { if (Lex.getUIntVal() != CurValID) - return Error(TypeLoc, "argument expected to be numbered '%" + + return error(TypeLoc, "argument expected to be numbered '%" + Twine(CurValID) + "'"); ++CurValID; Lex.Lex(); } if (!FunctionType::isValidArgumentType(ArgTy)) - return Error(TypeLoc, "invalid type for function argument"); + return error(TypeLoc, "invalid type for function argument"); ArgList.emplace_back(TypeLoc, ArgTy, AttributeSet::get(ArgTy->getContext(), Attrs), @@ -2725,10 +2725,10 @@ // Otherwise must be an argument type. TypeLoc = Lex.getLoc(); - if (ParseType(ArgTy) || ParseOptionalParamAttrs(Attrs)) return true; + if (parseType(ArgTy) || parseOptionalParamAttrs(Attrs)) return true; if (ArgTy->isVoidTy()) - return Error(TypeLoc, "argument can not have void type"); + return error(TypeLoc, "argument can not have void type"); if (Lex.getKind() == lltok::LocalVar) { Name = Lex.getStrVal(); @@ -2736,7 +2736,7 @@ } else { if (Lex.getKind() == lltok::LocalVarID) { if (Lex.getUIntVal() != CurValID) - return Error(TypeLoc, "argument expected to be numbered '%" + + return error(TypeLoc, "argument expected to be numbered '%" + Twine(CurValID) + "'"); Lex.Lex(); } @@ -2745,7 +2745,7 @@ } if (!ArgTy->isFirstClassType()) - return Error(TypeLoc, "invalid type for function argument"); + return error(TypeLoc, "invalid type for function argument"); ArgList.emplace_back(TypeLoc, ArgTy, AttributeSet::get(ArgTy->getContext(), Attrs), @@ -2753,28 +2753,28 @@ } } - return ParseToken(lltok::rparen, "expected ')' at end of argument list"); + return parseToken(lltok::rparen, "expected ')' at end of argument list"); } -/// ParseFunctionType +/// parseFunctionType /// ::= Type ArgumentList OptionalAttrs -bool LLParser::ParseFunctionType(Type *&Result) { +bool LLParser::parseFunctionType(Type *&Result) { assert(Lex.getKind() == lltok::lparen); if (!FunctionType::isValidReturnType(Result)) - return TokError("invalid function return type"); + return tokError("invalid function return type"); SmallVector ArgList; bool isVarArg; - if (ParseArgumentList(ArgList, isVarArg)) + if (parseArgumentList(ArgList, isVarArg)) return true; // Reject names on the arguments lists. for (unsigned i = 0, e = ArgList.size(); i != e; ++i) { if (!ArgList[i].Name.empty()) - return Error(ArgList[i].Loc, "argument name invalid in function type"); + return error(ArgList[i].Loc, "argument name invalid in function type"); if (ArgList[i].Attrs.hasAttributes()) - return Error(ArgList[i].Loc, + return error(ArgList[i].Loc, "argument attributes invalid in function type"); } @@ -2786,23 +2786,23 @@ return false; } -/// ParseAnonStructType - Parse an anonymous struct type, which is inlined into +/// parseAnonStructType - parse an anonymous struct type, which is inlined into /// other structs. -bool LLParser::ParseAnonStructType(Type *&Result, bool Packed) { +bool LLParser::parseAnonStructType(Type *&Result, bool Packed) { SmallVector Elts; - if (ParseStructBody(Elts)) return true; + if (parseStructBody(Elts)) return true; Result = StructType::get(Context, Elts, Packed); return false; } -/// ParseStructDefinition - Parse a struct in a 'type' definition. -bool LLParser::ParseStructDefinition(SMLoc TypeLoc, StringRef Name, +/// parseStructDefinition - parse a struct in a 'type' definition. +bool LLParser::parseStructDefinition(SMLoc TypeLoc, StringRef Name, std::pair &Entry, Type *&ResultTy) { // If the type was already defined, diagnose the redefinition. if (Entry.first && !Entry.second.isValid()) - return Error(TypeLoc, "redefinition of type"); + return error(TypeLoc, "redefinition of type"); // If we have opaque, just return without filling in the definition for the // struct. This counts as a definition as far as the .ll file goes. @@ -2825,12 +2825,12 @@ // forward referenced and not allowed to be recursive. if (Lex.getKind() != lltok::lbrace) { if (Entry.first) - return Error(TypeLoc, "forward references to non-struct type"); + return error(TypeLoc, "forward references to non-struct type"); ResultTy = nullptr; if (isPacked) - return ParseArrayVectorType(ResultTy, true); - return ParseType(ResultTy); + return parseArrayVectorType(ResultTy, true); + return parseType(ResultTy); } // This type is being defined, so clear the location to indicate this. @@ -2843,8 +2843,8 @@ StructType *STy = cast(Entry.first); SmallVector Body; - if (ParseStructBody(Body) || - (isPacked && ParseToken(lltok::greater, "expected '>' in packed struct"))) + if (parseStructBody(Body) || + (isPacked && parseToken(lltok::greater, "expected '>' in packed struct"))) return true; STy->setBody(Body, isPacked); @@ -2852,13 +2852,13 @@ return false; } -/// ParseStructType: Handles packed and unpacked types. parsed elsewhere. +/// parseStructType: Handles packed and unpacked types. parsed elsewhere. /// StructType /// ::= '{' '}' /// ::= '{' Type (',' Type)* '}' /// ::= '<' '{' '}' '>' /// ::= '<' '{' Type (',' Type)* '}' '>' -bool LLParser::ParseStructBody(SmallVectorImpl &Body) { +bool LLParser::parseStructBody(SmallVectorImpl &Body) { assert(Lex.getKind() == lltok::lbrace); Lex.Lex(); // Consume the '{' @@ -2868,37 +2868,37 @@ LocTy EltTyLoc = Lex.getLoc(); Type *Ty = nullptr; - if (ParseType(Ty)) return true; + if (parseType(Ty)) return true; Body.push_back(Ty); if (!StructType::isValidElementType(Ty)) - return Error(EltTyLoc, "invalid element type for struct"); + return error(EltTyLoc, "invalid element type for struct"); while (EatIfPresent(lltok::comma)) { EltTyLoc = Lex.getLoc(); - if (ParseType(Ty)) return true; + if (parseType(Ty)) return true; if (!StructType::isValidElementType(Ty)) - return Error(EltTyLoc, "invalid element type for struct"); + return error(EltTyLoc, "invalid element type for struct"); Body.push_back(Ty); } - return ParseToken(lltok::rbrace, "expected '}' at end of struct"); + return parseToken(lltok::rbrace, "expected '}' at end of struct"); } -/// ParseArrayVectorType - Parse an array or vector type, assuming the first +/// parseArrayVectorType - parse an array or vector type, assuming the first /// token has already been consumed. /// Type /// ::= '[' APSINTVAL 'x' Types ']' /// ::= '<' APSINTVAL 'x' Types '>' /// ::= '<' 'vscale' 'x' APSINTVAL 'x' Types '>' -bool LLParser::ParseArrayVectorType(Type *&Result, bool isVector) { +bool LLParser::parseArrayVectorType(Type *&Result, bool isVector) { bool Scalable = false; if (isVector && Lex.getKind() == lltok::kw_vscale) { Lex.Lex(); // consume the 'vscale' - if (ParseToken(lltok::kw_x, "expected 'x' after vscale")) + if (parseToken(lltok::kw_x, "expected 'x' after vscale")) return true; Scalable = true; @@ -2906,34 +2906,34 @@ if (Lex.getKind() != lltok::APSInt || Lex.getAPSIntVal().isSigned() || Lex.getAPSIntVal().getBitWidth() > 64) - return TokError("expected number in address space"); + return tokError("expected number in address space"); LocTy SizeLoc = Lex.getLoc(); uint64_t Size = Lex.getAPSIntVal().getZExtValue(); Lex.Lex(); - if (ParseToken(lltok::kw_x, "expected 'x' after element count")) + if (parseToken(lltok::kw_x, "expected 'x' after element count")) return true; LocTy TypeLoc = Lex.getLoc(); Type *EltTy = nullptr; - if (ParseType(EltTy)) return true; + if (parseType(EltTy)) return true; - if (ParseToken(isVector ? lltok::greater : lltok::rsquare, + if (parseToken(isVector ? lltok::greater : lltok::rsquare, "expected end of sequential type")) return true; if (isVector) { if (Size == 0) - return Error(SizeLoc, "zero element vector is illegal"); + return error(SizeLoc, "zero element vector is illegal"); if ((unsigned)Size != Size) - return Error(SizeLoc, "size too large for vector"); + return error(SizeLoc, "size too large for vector"); if (!VectorType::isValidElementType(EltTy)) - return Error(TypeLoc, "invalid vector element type"); + return error(TypeLoc, "invalid vector element type"); Result = VectorType::get(EltTy, unsigned(Size), Scalable); } else { if (!ArrayType::isValidElementType(EltTy)) - return Error(TypeLoc, "invalid array element type"); + return error(TypeLoc, "invalid array element type"); Result = ArrayType::get(EltTy, Size); } return false; @@ -2973,22 +2973,22 @@ } } -bool LLParser::PerFunctionState::FinishFunction() { +bool LLParser::PerFunctionState::finishFunction() { if (!ForwardRefVals.empty()) - return P.Error(ForwardRefVals.begin()->second.second, + return P.error(ForwardRefVals.begin()->second.second, "use of undefined value '%" + ForwardRefVals.begin()->first + "'"); if (!ForwardRefValIDs.empty()) - return P.Error(ForwardRefValIDs.begin()->second.second, + return P.error(ForwardRefValIDs.begin()->second.second, "use of undefined value '%" + Twine(ForwardRefValIDs.begin()->first) + "'"); return false; } -/// GetVal - Get a value with the specified name or ID, creating a +/// getVal - Get a value with the specified name or ID, creating a /// forward reference record if needed. This can return null if the value /// exists but does not have the right type. -Value *LLParser::PerFunctionState::GetVal(const std::string &Name, Type *Ty, +Value *LLParser::PerFunctionState::getVal(const std::string &Name, Type *Ty, LocTy Loc, bool IsCall) { // Look this name up in the normal function symbol table. Value *Val = F.getValueSymbolTable()->lookup(Name); @@ -3007,7 +3007,7 @@ // Don't make placeholders with invalid type. if (!Ty->isFirstClassType()) { - P.Error(Loc, "invalid use of a non-first-class type"); + P.error(Loc, "invalid use of a non-first-class type"); return nullptr; } @@ -3023,7 +3023,7 @@ return FwdVal; } -Value *LLParser::PerFunctionState::GetVal(unsigned ID, Type *Ty, LocTy Loc, +Value *LLParser::PerFunctionState::getVal(unsigned ID, Type *Ty, LocTy Loc, bool IsCall) { // Look this name up in the normal function symbol table. Value *Val = ID < NumberedVals.size() ? NumberedVals[ID] : nullptr; @@ -3041,7 +3041,7 @@ return P.checkValidVariableType(Loc, "%" + Twine(ID), Ty, Val, IsCall); if (!Ty->isFirstClassType()) { - P.Error(Loc, "invalid use of a non-first-class type"); + P.error(Loc, "invalid use of a non-first-class type"); return nullptr; } @@ -3057,15 +3057,15 @@ return FwdVal; } -/// SetInstName - After an instruction is parsed and inserted into its +/// setInstName - After an instruction is parsed and inserted into its /// basic block, this installs its name. -bool LLParser::PerFunctionState::SetInstName(int NameID, +bool LLParser::PerFunctionState::setInstName(int NameID, const std::string &NameStr, LocTy NameLoc, Instruction *Inst) { // If this instruction has void type, it cannot have a name or ID specified. if (Inst->getType()->isVoidTy()) { if (NameID != -1 || !NameStr.empty()) - return P.Error(NameLoc, "instructions returning void cannot have a name"); + return P.error(NameLoc, "instructions returning void cannot have a name"); return false; } @@ -3077,14 +3077,14 @@ NameID = NumberedVals.size(); if (unsigned(NameID) != NumberedVals.size()) - return P.Error(NameLoc, "instruction expected to be numbered '%" + + return P.error(NameLoc, "instruction expected to be numbered '%" + Twine(NumberedVals.size()) + "'"); auto FI = ForwardRefValIDs.find(NameID); if (FI != ForwardRefValIDs.end()) { Value *Sentinel = FI->second.first; if (Sentinel->getType() != Inst->getType()) - return P.Error(NameLoc, "instruction forward referenced with type '" + + return P.error(NameLoc, "instruction forward referenced with type '" + getTypeString(FI->second.first->getType()) + "'"); Sentinel->replaceAllUsesWith(Inst); @@ -3101,7 +3101,7 @@ if (FI != ForwardRefVals.end()) { Value *Sentinel = FI->second.first; if (Sentinel->getType() != Inst->getType()) - return P.Error(NameLoc, "instruction forward referenced with type '" + + return P.error(NameLoc, "instruction forward referenced with type '" + getTypeString(FI->second.first->getType()) + "'"); Sentinel->replaceAllUsesWith(Inst); @@ -3113,46 +3113,46 @@ Inst->setName(NameStr); if (Inst->getName() != NameStr) - return P.Error(NameLoc, "multiple definition of local value named '" + + return P.error(NameLoc, "multiple definition of local value named '" + NameStr + "'"); return false; } -/// GetBB - Get a basic block with the specified name or ID, creating a +/// getBB - Get a basic block with the specified name or ID, creating a /// forward reference record if needed. -BasicBlock *LLParser::PerFunctionState::GetBB(const std::string &Name, +BasicBlock *LLParser::PerFunctionState::getBB(const std::string &Name, LocTy Loc) { return dyn_cast_or_null( - GetVal(Name, Type::getLabelTy(F.getContext()), Loc, /*IsCall=*/false)); + getVal(Name, Type::getLabelTy(F.getContext()), Loc, /*IsCall=*/false)); } -BasicBlock *LLParser::PerFunctionState::GetBB(unsigned ID, LocTy Loc) { +BasicBlock *LLParser::PerFunctionState::getBB(unsigned ID, LocTy Loc) { return dyn_cast_or_null( - GetVal(ID, Type::getLabelTy(F.getContext()), Loc, /*IsCall=*/false)); + getVal(ID, Type::getLabelTy(F.getContext()), Loc, /*IsCall=*/false)); } -/// DefineBB - Define the specified basic block, which is either named or +/// defineBB - Define the specified basic block, which is either named or /// unnamed. If there is an error, this returns null otherwise it returns /// the block being defined. -BasicBlock *LLParser::PerFunctionState::DefineBB(const std::string &Name, +BasicBlock *LLParser::PerFunctionState::defineBB(const std::string &Name, int NameID, LocTy Loc) { BasicBlock *BB; if (Name.empty()) { if (NameID != -1 && unsigned(NameID) != NumberedVals.size()) { - P.Error(Loc, "label expected to be numbered '" + + P.error(Loc, "label expected to be numbered '" + Twine(NumberedVals.size()) + "'"); return nullptr; } - BB = GetBB(NumberedVals.size(), Loc); + BB = getBB(NumberedVals.size(), Loc); if (!BB) { - P.Error(Loc, "unable to create block numbered '" + + P.error(Loc, "unable to create block numbered '" + Twine(NumberedVals.size()) + "'"); return nullptr; } } else { - BB = GetBB(Name, Loc); + BB = getBB(Name, Loc); if (!BB) { - P.Error(Loc, "unable to create block named '" + Name + "'"); + P.error(Loc, "unable to create block named '" + Name + "'"); return nullptr; } } @@ -3177,16 +3177,16 @@ // Constants. //===----------------------------------------------------------------------===// -/// ParseValID - Parse an abstract value that doesn't necessarily have a +/// parseValID - parse an abstract value that doesn't necessarily have a /// type implied. For example, if we parse "4" we don't know what integer type /// it has. The value will later be combined with its type and checked for /// sanity. PFS is used to convert function-local operands of metadata (since /// metadata operands are not just parsed here but also converted to values). /// PFS can be null when we are not parsing metadata values inside a function. -bool LLParser::ParseValID(ValID &ID, PerFunctionState *PFS) { +bool LLParser::parseValID(ValID &ID, PerFunctionState *PFS) { ID.Loc = Lex.getLoc(); switch (Lex.getKind()) { - default: return TokError("expected value token"); + default: return tokError("expected value token"); case lltok::GlobalID: // @42 ID.UIntVal = Lex.getUIntVal(); ID.Kind = ValID::t_GlobalID; @@ -3228,8 +3228,8 @@ // ValID ::= '{' ConstVector '}' Lex.Lex(); SmallVector Elts; - if (ParseGlobalValueVector(Elts) || - ParseToken(lltok::rbrace, "expected end of struct constant")) + if (parseGlobalValueVector(Elts) || + parseToken(lltok::rbrace, "expected end of struct constant")) return true; ID.ConstantStructElts = std::make_unique(Elts.size()); @@ -3247,10 +3247,10 @@ SmallVector Elts; LocTy FirstEltLoc = Lex.getLoc(); - if (ParseGlobalValueVector(Elts) || + if (parseGlobalValueVector(Elts) || (isPackedStruct && - ParseToken(lltok::rbrace, "expected end of packed struct")) || - ParseToken(lltok::greater, "expected end of constant")) + parseToken(lltok::rbrace, "expected end of packed struct")) || + parseToken(lltok::greater, "expected end of constant")) return true; if (isPackedStruct) { @@ -3263,18 +3263,18 @@ } if (Elts.empty()) - return Error(ID.Loc, "constant vector must not be empty"); + return error(ID.Loc, "constant vector must not be empty"); if (!Elts[0]->getType()->isIntegerTy() && !Elts[0]->getType()->isFloatingPointTy() && !Elts[0]->getType()->isPointerTy()) - return Error(FirstEltLoc, + return error(FirstEltLoc, "vector elements must have integer, pointer or floating point type"); // Verify that all the vector elements have the same type. for (unsigned i = 1, e = Elts.size(); i != e; ++i) if (Elts[i]->getType() != Elts[0]->getType()) - return Error(FirstEltLoc, + return error(FirstEltLoc, "vector element #" + Twine(i) + " is not of type '" + getTypeString(Elts[0]->getType())); @@ -3286,8 +3286,8 @@ Lex.Lex(); SmallVector Elts; LocTy FirstEltLoc = Lex.getLoc(); - if (ParseGlobalValueVector(Elts) || - ParseToken(lltok::rsquare, "expected end of array constant")) + if (parseGlobalValueVector(Elts) || + parseToken(lltok::rsquare, "expected end of array constant")) return true; // Handle empty element. @@ -3299,7 +3299,7 @@ } if (!Elts[0]->getType()->isFirstClassType()) - return Error(FirstEltLoc, "invalid array element type: " + + return error(FirstEltLoc, "invalid array element type: " + getTypeString(Elts[0]->getType())); ArrayType *ATy = ArrayType::get(Elts[0]->getType(), Elts.size()); @@ -3307,7 +3307,7 @@ // Verify all elements are correct type! for (unsigned i = 0, e = Elts.size(); i != e; ++i) { if (Elts[i]->getType() != Elts[0]->getType()) - return Error(FirstEltLoc, + return error(FirstEltLoc, "array element #" + Twine(i) + " is not of type '" + getTypeString(Elts[0]->getType())); } @@ -3320,7 +3320,7 @@ Lex.Lex(); ID.ConstantVal = ConstantDataArray::getString(Context, Lex.getStrVal(), false); - if (ParseToken(lltok::StringConstant, "expected string")) return true; + if (parseToken(lltok::StringConstant, "expected string")) return true; ID.Kind = ValID::t_Constant; return false; @@ -3329,12 +3329,12 @@ // STRINGCONSTANT bool HasSideEffect, AlignStack, AsmDialect; Lex.Lex(); - if (ParseOptionalToken(lltok::kw_sideeffect, HasSideEffect) || - ParseOptionalToken(lltok::kw_alignstack, AlignStack) || - ParseOptionalToken(lltok::kw_inteldialect, AsmDialect) || - ParseStringConstant(ID.StrVal) || - ParseToken(lltok::comma, "expected comma in inline asm expression") || - ParseToken(lltok::StringConstant, "expected constraint string")) + if (parseOptionalToken(lltok::kw_sideeffect, HasSideEffect) || + parseOptionalToken(lltok::kw_alignstack, AlignStack) || + parseOptionalToken(lltok::kw_inteldialect, AsmDialect) || + parseStringConstant(ID.StrVal) || + parseToken(lltok::comma, "expected comma in inline asm expression") || + parseToken(lltok::StringConstant, "expected constraint string")) return true; ID.StrVal2 = Lex.getStrVal(); ID.UIntVal = unsigned(HasSideEffect) | (unsigned(AlignStack)<<1) | @@ -3349,17 +3349,17 @@ ValID Fn, Label; - if (ParseToken(lltok::lparen, "expected '(' in block address expression") || - ParseValID(Fn) || - ParseToken(lltok::comma, "expected comma in block address expression")|| - ParseValID(Label) || - ParseToken(lltok::rparen, "expected ')' in block address expression")) + if (parseToken(lltok::lparen, "expected '(' in block address expression") || + parseValID(Fn) || + parseToken(lltok::comma, "expected comma in block address expression")|| + parseValID(Label) || + parseToken(lltok::rparen, "expected ')' in block address expression")) return true; if (Fn.Kind != ValID::t_GlobalID && Fn.Kind != ValID::t_GlobalName) - return Error(Fn.Loc, "expected function name in blockaddress"); + return error(Fn.Loc, "expected function name in blockaddress"); if (Label.Kind != ValID::t_LocalID && Label.Kind != ValID::t_LocalName) - return Error(Label.Loc, "expected basic block name in blockaddress"); + return error(Label.Loc, "expected basic block name in blockaddress"); // Try to find the function (but skip it if it's forward-referenced). GlobalValue *GV = nullptr; @@ -3373,10 +3373,10 @@ if (GV) { // Confirm that it's actually a function with a definition. if (!isa(GV)) - return Error(Fn.Loc, "expected function name in blockaddress"); + return error(Fn.Loc, "expected function name in blockaddress"); F = cast(GV); if (F->isDeclaration()) - return Error(Fn.Loc, "cannot take blockaddress inside a declaration"); + return error(Fn.Loc, "cannot take blockaddress inside a declaration"); } if (!F) { @@ -3400,19 +3400,19 @@ BasicBlock *BB; if (BlockAddressPFS && F == &BlockAddressPFS->getFunction()) { if (Label.Kind == ValID::t_LocalID) - BB = BlockAddressPFS->GetBB(Label.UIntVal, Label.Loc); + BB = BlockAddressPFS->getBB(Label.UIntVal, Label.Loc); else - BB = BlockAddressPFS->GetBB(Label.StrVal, Label.Loc); + BB = BlockAddressPFS->getBB(Label.StrVal, Label.Loc); if (!BB) - return Error(Label.Loc, "referenced value is not a basic block"); + return error(Label.Loc, "referenced value is not a basic block"); } else { if (Label.Kind == ValID::t_LocalID) - return Error(Label.Loc, "cannot take address of numeric label after " + return error(Label.Loc, "cannot take address of numeric label after " "the function is defined"); BB = dyn_cast_or_null( F->getValueSymbolTable()->lookup(Label.StrVal)); if (!BB) - return Error(Label.Loc, "referenced value is not a basic block"); + return error(Label.Loc, "referenced value is not a basic block"); } ID.ConstantVal = BlockAddress::get(F, BB); @@ -3437,14 +3437,14 @@ Type *DestTy = nullptr; Constant *SrcVal; Lex.Lex(); - if (ParseToken(lltok::lparen, "expected '(' after constantexpr cast") || - ParseGlobalTypeAndValue(SrcVal) || - ParseToken(lltok::kw_to, "expected 'to' in constantexpr cast") || - ParseType(DestTy) || - ParseToken(lltok::rparen, "expected ')' at end of constantexpr cast")) + if (parseToken(lltok::lparen, "expected '(' after constantexpr cast") || + parseGlobalTypeAndValue(SrcVal) || + parseToken(lltok::kw_to, "expected 'to' in constantexpr cast") || + parseType(DestTy) || + parseToken(lltok::rparen, "expected ')' at end of constantexpr cast")) return true; if (!CastInst::castIsValid((Instruction::CastOps)Opc, SrcVal, DestTy)) - return Error(ID.Loc, "invalid cast opcode for cast from '" + + return error(ID.Loc, "invalid cast opcode for cast from '" + getTypeString(SrcVal->getType()) + "' to '" + getTypeString(DestTy) + "'"); ID.ConstantVal = ConstantExpr::getCast((Instruction::CastOps)Opc, @@ -3456,16 +3456,16 @@ Lex.Lex(); Constant *Val; SmallVector Indices; - if (ParseToken(lltok::lparen, "expected '(' in extractvalue constantexpr")|| - ParseGlobalTypeAndValue(Val) || - ParseIndexList(Indices) || - ParseToken(lltok::rparen, "expected ')' in extractvalue constantexpr")) + if (parseToken(lltok::lparen, "expected '(' in extractvalue constantexpr")|| + parseGlobalTypeAndValue(Val) || + parseIndexList(Indices) || + parseToken(lltok::rparen, "expected ')' in extractvalue constantexpr")) return true; if (!Val->getType()->isAggregateType()) - return Error(ID.Loc, "extractvalue operand must be aggregate type"); + return error(ID.Loc, "extractvalue operand must be aggregate type"); if (!ExtractValueInst::getIndexedType(Val->getType(), Indices)) - return Error(ID.Loc, "invalid indices for extractvalue"); + return error(ID.Loc, "invalid indices for extractvalue"); ID.ConstantVal = ConstantExpr::getExtractValue(Val, Indices); ID.Kind = ValID::t_Constant; return false; @@ -3474,21 +3474,21 @@ Lex.Lex(); Constant *Val0, *Val1; SmallVector Indices; - if (ParseToken(lltok::lparen, "expected '(' in insertvalue constantexpr")|| - ParseGlobalTypeAndValue(Val0) || - ParseToken(lltok::comma, "expected comma in insertvalue constantexpr")|| - ParseGlobalTypeAndValue(Val1) || - ParseIndexList(Indices) || - ParseToken(lltok::rparen, "expected ')' in insertvalue constantexpr")) + if (parseToken(lltok::lparen, "expected '(' in insertvalue constantexpr")|| + parseGlobalTypeAndValue(Val0) || + parseToken(lltok::comma, "expected comma in insertvalue constantexpr")|| + parseGlobalTypeAndValue(Val1) || + parseIndexList(Indices) || + parseToken(lltok::rparen, "expected ')' in insertvalue constantexpr")) return true; if (!Val0->getType()->isAggregateType()) - return Error(ID.Loc, "insertvalue operand must be aggregate type"); + return error(ID.Loc, "insertvalue operand must be aggregate type"); Type *IndexedType = ExtractValueInst::getIndexedType(Val0->getType(), Indices); if (!IndexedType) - return Error(ID.Loc, "invalid indices for insertvalue"); + return error(ID.Loc, "invalid indices for insertvalue"); if (IndexedType != Val1->getType()) - return Error(ID.Loc, "insertvalue operand and field disagree in type: '" + + return error(ID.Loc, "insertvalue operand and field disagree in type: '" + getTypeString(Val1->getType()) + "' instead of '" + getTypeString(IndexedType) + "'"); @@ -3501,28 +3501,28 @@ unsigned PredVal, Opc = Lex.getUIntVal(); Constant *Val0, *Val1; Lex.Lex(); - if (ParseCmpPredicate(PredVal, Opc) || - ParseToken(lltok::lparen, "expected '(' in compare constantexpr") || - ParseGlobalTypeAndValue(Val0) || - ParseToken(lltok::comma, "expected comma in compare constantexpr") || - ParseGlobalTypeAndValue(Val1) || - ParseToken(lltok::rparen, "expected ')' in compare constantexpr")) + if (parseCmpPredicate(PredVal, Opc) || + parseToken(lltok::lparen, "expected '(' in compare constantexpr") || + parseGlobalTypeAndValue(Val0) || + parseToken(lltok::comma, "expected comma in compare constantexpr") || + parseGlobalTypeAndValue(Val1) || + parseToken(lltok::rparen, "expected ')' in compare constantexpr")) return true; if (Val0->getType() != Val1->getType()) - return Error(ID.Loc, "compare operands must have the same type"); + return error(ID.Loc, "compare operands must have the same type"); CmpInst::Predicate Pred = (CmpInst::Predicate)PredVal; if (Opc == Instruction::FCmp) { if (!Val0->getType()->isFPOrFPVectorTy()) - return Error(ID.Loc, "fcmp requires floating point operands"); + return error(ID.Loc, "fcmp requires floating point operands"); ID.ConstantVal = ConstantExpr::getFCmp(Pred, Val0, Val1); } else { assert(Opc == Instruction::ICmp && "Unexpected opcode for CmpInst!"); if (!Val0->getType()->isIntOrIntVectorTy() && !Val0->getType()->isPtrOrPtrVectorTy()) - return Error(ID.Loc, "icmp requires pointer or integer operands"); + return error(ID.Loc, "icmp requires pointer or integer operands"); ID.ConstantVal = ConstantExpr::getICmp(Pred, Val0, Val1); } ID.Kind = ValID::t_Constant; @@ -3534,16 +3534,16 @@ unsigned Opc = Lex.getUIntVal(); Constant *Val; Lex.Lex(); - if (ParseToken(lltok::lparen, "expected '(' in unary constantexpr") || - ParseGlobalTypeAndValue(Val) || - ParseToken(lltok::rparen, "expected ')' in unary constantexpr")) + if (parseToken(lltok::lparen, "expected '(' in unary constantexpr") || + parseGlobalTypeAndValue(Val) || + parseToken(lltok::rparen, "expected ')' in unary constantexpr")) return true; // Check that the type is valid for the operator. switch (Opc) { case Instruction::FNeg: if (!Val->getType()->isFPOrFPVectorTy()) - return Error(ID.Loc, "constexpr requires fp operands"); + return error(ID.Loc, "constexpr requires fp operands"); break; default: llvm_unreachable("Unknown unary operator!"); } @@ -3589,14 +3589,14 @@ if (EatIfPresent(lltok::kw_exact)) Exact = true; } - if (ParseToken(lltok::lparen, "expected '(' in binary constantexpr") || - ParseGlobalTypeAndValue(Val0) || - ParseToken(lltok::comma, "expected comma in binary constantexpr") || - ParseGlobalTypeAndValue(Val1) || - ParseToken(lltok::rparen, "expected ')' in binary constantexpr")) + if (parseToken(lltok::lparen, "expected '(' in binary constantexpr") || + parseGlobalTypeAndValue(Val0) || + parseToken(lltok::comma, "expected comma in binary constantexpr") || + parseGlobalTypeAndValue(Val1) || + parseToken(lltok::rparen, "expected ')' in binary constantexpr")) return true; if (Val0->getType() != Val1->getType()) - return Error(ID.Loc, "operands of constexpr must have same type"); + return error(ID.Loc, "operands of constexpr must have same type"); // Check that the type is valid for the operator. switch (Opc) { case Instruction::Add: @@ -3610,7 +3610,7 @@ case Instruction::AShr: case Instruction::LShr: if (!Val0->getType()->isIntOrIntVectorTy()) - return Error(ID.Loc, "constexpr requires integer operands"); + return error(ID.Loc, "constexpr requires integer operands"); break; case Instruction::FAdd: case Instruction::FSub: @@ -3618,7 +3618,7 @@ case Instruction::FDiv: case Instruction::FRem: if (!Val0->getType()->isFPOrFPVectorTy()) - return Error(ID.Loc, "constexpr requires fp operands"); + return error(ID.Loc, "constexpr requires fp operands"); break; default: llvm_unreachable("Unknown binary operator!"); } @@ -3639,16 +3639,16 @@ unsigned Opc = Lex.getUIntVal(); Constant *Val0, *Val1; Lex.Lex(); - if (ParseToken(lltok::lparen, "expected '(' in logical constantexpr") || - ParseGlobalTypeAndValue(Val0) || - ParseToken(lltok::comma, "expected comma in logical constantexpr") || - ParseGlobalTypeAndValue(Val1) || - ParseToken(lltok::rparen, "expected ')' in logical constantexpr")) + if (parseToken(lltok::lparen, "expected '(' in logical constantexpr") || + parseGlobalTypeAndValue(Val0) || + parseToken(lltok::comma, "expected comma in logical constantexpr") || + parseGlobalTypeAndValue(Val1) || + parseToken(lltok::rparen, "expected ')' in logical constantexpr")) return true; if (Val0->getType() != Val1->getType()) - return Error(ID.Loc, "operands of constexpr must have same type"); + return error(ID.Loc, "operands of constexpr must have same type"); if (!Val0->getType()->isIntOrIntVectorTy()) - return Error(ID.Loc, + return error(ID.Loc, "constexpr requires integer or integer vector operands"); ID.ConstantVal = ConstantExpr::get(Opc, Val0, Val1); ID.Kind = ValID::t_Constant; @@ -3669,31 +3669,31 @@ if (Opc == Instruction::GetElementPtr) InBounds = EatIfPresent(lltok::kw_inbounds); - if (ParseToken(lltok::lparen, "expected '(' in constantexpr")) + if (parseToken(lltok::lparen, "expected '(' in constantexpr")) return true; LocTy ExplicitTypeLoc = Lex.getLoc(); if (Opc == Instruction::GetElementPtr) { - if (ParseType(Ty) || - ParseToken(lltok::comma, "expected comma after getelementptr's type")) + if (parseType(Ty) || + parseToken(lltok::comma, "expected comma after getelementptr's type")) return true; } Optional InRangeOp; - if (ParseGlobalValueVector( + if (parseGlobalValueVector( Elts, Opc == Instruction::GetElementPtr ? &InRangeOp : nullptr) || - ParseToken(lltok::rparen, "expected ')' in constantexpr")) + parseToken(lltok::rparen, "expected ')' in constantexpr")) return true; if (Opc == Instruction::GetElementPtr) { if (Elts.size() == 0 || !Elts[0]->getType()->isPtrOrPtrVectorTy()) - return Error(ID.Loc, "base of getelementptr must be a pointer"); + return error(ID.Loc, "base of getelementptr must be a pointer"); Type *BaseType = Elts[0]->getType(); auto *BasePointerType = cast(BaseType->getScalarType()); if (Ty != BasePointerType->getElementType()) - return Error( + return error( ExplicitTypeLoc, "explicit pointee type doesn't match operand's pointee type"); @@ -3706,11 +3706,11 @@ for (Constant *Val : Indices) { Type *ValTy = Val->getType(); if (!ValTy->isIntOrIntVectorTy()) - return Error(ID.Loc, "getelementptr index must be an integer"); + return error(ID.Loc, "getelementptr index must be an integer"); if (auto *ValVTy = dyn_cast(ValTy)) { unsigned ValNumEl = cast(ValVTy)->getNumElements(); if (GEPWidth && (ValNumEl != GEPWidth)) - return Error( + return error( ID.Loc, "getelementptr vector index has a wrong number of elements"); // GEPWidth may have been unknown because the base is a scalar, @@ -3721,14 +3721,14 @@ SmallPtrSet Visited; if (!Indices.empty() && !Ty->isSized(&Visited)) - return Error(ID.Loc, "base element of getelementptr must be sized"); + return error(ID.Loc, "base element of getelementptr must be sized"); if (!GetElementPtrInst::getIndexedType(Ty, Indices)) - return Error(ID.Loc, "invalid getelementptr indices"); + return error(ID.Loc, "invalid getelementptr indices"); if (InRangeOp) { if (*InRangeOp == 0) - return Error(ID.Loc, + return error(ID.Loc, "inrange keyword may not appear on pointer operand"); --*InRangeOp; } @@ -3737,31 +3737,31 @@ InBounds, InRangeOp); } else if (Opc == Instruction::Select) { if (Elts.size() != 3) - return Error(ID.Loc, "expected three operands to select"); + return error(ID.Loc, "expected three operands to select"); if (const char *Reason = SelectInst::areInvalidOperands(Elts[0], Elts[1], Elts[2])) - return Error(ID.Loc, Reason); + return error(ID.Loc, Reason); ID.ConstantVal = ConstantExpr::getSelect(Elts[0], Elts[1], Elts[2]); } else if (Opc == Instruction::ShuffleVector) { if (Elts.size() != 3) - return Error(ID.Loc, "expected three operands to shufflevector"); + return error(ID.Loc, "expected three operands to shufflevector"); if (!ShuffleVectorInst::isValidOperands(Elts[0], Elts[1], Elts[2])) - return Error(ID.Loc, "invalid operands to shufflevector"); + return error(ID.Loc, "invalid operands to shufflevector"); SmallVector Mask; ShuffleVectorInst::getShuffleMask(cast(Elts[2]), Mask); ID.ConstantVal = ConstantExpr::getShuffleVector(Elts[0], Elts[1], Mask); } else if (Opc == Instruction::ExtractElement) { if (Elts.size() != 2) - return Error(ID.Loc, "expected two operands to extractelement"); + return error(ID.Loc, "expected two operands to extractelement"); if (!ExtractElementInst::isValidOperands(Elts[0], Elts[1])) - return Error(ID.Loc, "invalid extractelement operands"); + return error(ID.Loc, "invalid extractelement operands"); ID.ConstantVal = ConstantExpr::getExtractElement(Elts[0], Elts[1]); } else { assert(Opc == Instruction::InsertElement && "Unknown opcode"); if (Elts.size() != 3) - return Error(ID.Loc, "expected three operands to insertelement"); + return error(ID.Loc, "expected three operands to insertelement"); if (!InsertElementInst::isValidOperands(Elts[0], Elts[1], Elts[2])) - return Error(ID.Loc, "invalid insertelement operands"); + return error(ID.Loc, "invalid insertelement operands"); ID.ConstantVal = ConstantExpr::getInsertElement(Elts[0], Elts[1],Elts[2]); } @@ -3775,22 +3775,22 @@ return false; } -/// ParseGlobalValue - Parse a global value with the specified type. -bool LLParser::ParseGlobalValue(Type *Ty, Constant *&C) { +/// parseGlobalValue - parse a global value with the specified type. +bool LLParser::parseGlobalValue(Type *Ty, Constant *&C) { C = nullptr; ValID ID; Value *V = nullptr; - bool Parsed = ParseValID(ID) || - ConvertValIDToValue(Ty, ID, V, nullptr, /*IsCall=*/false); + bool parsed = parseValID(ID) || + convertValIDToValue(Ty, ID, V, nullptr, /*IsCall=*/false); if (V && !(C = dyn_cast(V))) - return Error(ID.Loc, "global values must be constants"); - return Parsed; + return error(ID.Loc, "global values must be constants"); + return parsed; } -bool LLParser::ParseGlobalTypeAndValue(Constant *&V) { +bool LLParser::parseGlobalTypeAndValue(Constant *&V) { Type *Ty = nullptr; - return ParseType(Ty) || - ParseGlobalValue(Ty, V); + return parseType(Ty) || + parseGlobalValue(Ty, V); } bool LLParser::parseOptionalComdat(StringRef GlobalName, Comdat *&C) { @@ -3802,24 +3802,24 @@ if (EatIfPresent(lltok::lparen)) { if (Lex.getKind() != lltok::ComdatVar) - return TokError("expected comdat variable"); + return tokError("expected comdat variable"); C = getComdat(Lex.getStrVal(), Lex.getLoc()); Lex.Lex(); - if (ParseToken(lltok::rparen, "expected ')' after comdat var")) + if (parseToken(lltok::rparen, "expected ')' after comdat var")) return true; } else { if (GlobalName.empty()) - return TokError("comdat cannot be unnamed"); + return tokError("comdat cannot be unnamed"); C = getComdat(std::string(GlobalName), KwLoc); } return false; } -/// ParseGlobalValueVector +/// parseGlobalValueVector /// ::= /*empty*/ /// ::= [inrange] TypeAndValue (',' [inrange] TypeAndValue)* -bool LLParser::ParseGlobalValueVector(SmallVectorImpl &Elts, +bool LLParser::parseGlobalValueVector(SmallVectorImpl &Elts, Optional *InRangeOp) { // Empty list. if (Lex.getKind() == lltok::rbrace || @@ -3833,16 +3833,16 @@ *InRangeOp = Elts.size(); Constant *C; - if (ParseGlobalTypeAndValue(C)) return true; + if (parseGlobalTypeAndValue(C)) return true; Elts.push_back(C); } while (EatIfPresent(lltok::comma)); return false; } -bool LLParser::ParseMDTuple(MDNode *&MD, bool IsDistinct) { +bool LLParser::parseMDTuple(MDNode *&MD, bool IsDistinct) { SmallVector Elts; - if (ParseMDNodeVector(Elts)) + if (parseMDNodeVector(Elts)) return true; MD = (IsDistinct ? MDTuple::getDistinct : MDTuple::get)(Context, Elts); @@ -3853,21 +3853,21 @@ /// ::= !{ ... } /// ::= !7 /// ::= !DILocation(...) -bool LLParser::ParseMDNode(MDNode *&N) { +bool LLParser::parseMDNode(MDNode *&N) { if (Lex.getKind() == lltok::MetadataVar) - return ParseSpecializedMDNode(N); + return parseSpecializedMDNode(N); - return ParseToken(lltok::exclaim, "expected '!' here") || - ParseMDNodeTail(N); + return parseToken(lltok::exclaim, "expected '!' here") || + parseMDNodeTail(N); } -bool LLParser::ParseMDNodeTail(MDNode *&N) { +bool LLParser::parseMDNodeTail(MDNode *&N) { // !{ ... } if (Lex.getKind() == lltok::lbrace) - return ParseMDTuple(N); + return parseMDTuple(N); // !42 - return ParseMDNodeID(N); + return parseMDNodeID(N); } namespace { @@ -4065,9 +4065,9 @@ namespace llvm { template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, MDAPSIntField &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, MDAPSIntField &Result) { if (Lex.getKind() != lltok::APSInt) - return TokError("expected integer"); + return tokError("expected integer"); Result.assign(Lex.getAPSIntVal()); Lex.Lex(); @@ -4075,14 +4075,14 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, +bool LLParser::parseMDField(LocTy Loc, StringRef Name, MDUnsignedField &Result) { if (Lex.getKind() != lltok::APSInt || Lex.getAPSIntVal().isSigned()) - return TokError("expected unsigned integer"); + return tokError("expected unsigned integer"); auto &U = Lex.getAPSIntVal(); if (U.ugt(Result.Max)) - return TokError("value for '" + Name + "' too large, limit is " + + return tokError("value for '" + Name + "' too large, limit is " + Twine(Result.Max)); Result.assign(U.getZExtValue()); assert(Result.Val <= Result.Max && "Expected value in range"); @@ -4091,25 +4091,25 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, LineField &Result) { - return ParseMDField(Loc, Name, static_cast(Result)); +bool LLParser::parseMDField(LocTy Loc, StringRef Name, LineField &Result) { + return parseMDField(Loc, Name, static_cast(Result)); } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, ColumnField &Result) { - return ParseMDField(Loc, Name, static_cast(Result)); +bool LLParser::parseMDField(LocTy Loc, StringRef Name, ColumnField &Result) { + return parseMDField(Loc, Name, static_cast(Result)); } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, DwarfTagField &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, DwarfTagField &Result) { if (Lex.getKind() == lltok::APSInt) - return ParseMDField(Loc, Name, static_cast(Result)); + return parseMDField(Loc, Name, static_cast(Result)); if (Lex.getKind() != lltok::DwarfTag) - return TokError("expected DWARF tag"); + return tokError("expected DWARF tag"); unsigned Tag = dwarf::getTag(Lex.getStrVal()); if (Tag == dwarf::DW_TAG_invalid) - return TokError("invalid DWARF tag" + Twine(" '") + Lex.getStrVal() + "'"); + return tokError("invalid DWARF tag" + Twine(" '") + Lex.getStrVal() + "'"); assert(Tag <= Result.Max && "Expected valid DWARF tag"); Result.assign(Tag); @@ -4118,17 +4118,17 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, +bool LLParser::parseMDField(LocTy Loc, StringRef Name, DwarfMacinfoTypeField &Result) { if (Lex.getKind() == lltok::APSInt) - return ParseMDField(Loc, Name, static_cast(Result)); + return parseMDField(Loc, Name, static_cast(Result)); if (Lex.getKind() != lltok::DwarfMacinfo) - return TokError("expected DWARF macinfo type"); + return tokError("expected DWARF macinfo type"); unsigned Macinfo = dwarf::getMacinfo(Lex.getStrVal()); if (Macinfo == dwarf::DW_MACINFO_invalid) - return TokError( + return tokError( "invalid DWARF macinfo type" + Twine(" '") + Lex.getStrVal() + "'"); assert(Macinfo <= Result.Max && "Expected valid DWARF macinfo type"); @@ -4138,17 +4138,17 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, +bool LLParser::parseMDField(LocTy Loc, StringRef Name, DwarfVirtualityField &Result) { if (Lex.getKind() == lltok::APSInt) - return ParseMDField(Loc, Name, static_cast(Result)); + return parseMDField(Loc, Name, static_cast(Result)); if (Lex.getKind() != lltok::DwarfVirtuality) - return TokError("expected DWARF virtuality code"); + return tokError("expected DWARF virtuality code"); unsigned Virtuality = dwarf::getVirtuality(Lex.getStrVal()); if (Virtuality == dwarf::DW_VIRTUALITY_invalid) - return TokError("invalid DWARF virtuality code" + Twine(" '") + + return tokError("invalid DWARF virtuality code" + Twine(" '") + Lex.getStrVal() + "'"); assert(Virtuality <= Result.Max && "Expected valid DWARF virtuality code"); Result.assign(Virtuality); @@ -4157,16 +4157,16 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, DwarfLangField &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, DwarfLangField &Result) { if (Lex.getKind() == lltok::APSInt) - return ParseMDField(Loc, Name, static_cast(Result)); + return parseMDField(Loc, Name, static_cast(Result)); if (Lex.getKind() != lltok::DwarfLang) - return TokError("expected DWARF language"); + return tokError("expected DWARF language"); unsigned Lang = dwarf::getLanguage(Lex.getStrVal()); if (!Lang) - return TokError("invalid DWARF language" + Twine(" '") + Lex.getStrVal() + + return tokError("invalid DWARF language" + Twine(" '") + Lex.getStrVal() + "'"); assert(Lang <= Result.Max && "Expected valid DWARF language"); Result.assign(Lang); @@ -4175,16 +4175,16 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, DwarfCCField &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, DwarfCCField &Result) { if (Lex.getKind() == lltok::APSInt) - return ParseMDField(Loc, Name, static_cast(Result)); + return parseMDField(Loc, Name, static_cast(Result)); if (Lex.getKind() != lltok::DwarfCC) - return TokError("expected DWARF calling convention"); + return tokError("expected DWARF calling convention"); unsigned CC = dwarf::getCallingConvention(Lex.getStrVal()); if (!CC) - return TokError("invalid DWARF calling convention" + Twine(" '") + Lex.getStrVal() + + return tokError("invalid DWARF calling convention" + Twine(" '") + Lex.getStrVal() + "'"); assert(CC <= Result.Max && "Expected valid DWARF calling convention"); Result.assign(CC); @@ -4193,16 +4193,16 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, EmissionKindField &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, EmissionKindField &Result) { if (Lex.getKind() == lltok::APSInt) - return ParseMDField(Loc, Name, static_cast(Result)); + return parseMDField(Loc, Name, static_cast(Result)); if (Lex.getKind() != lltok::EmissionKind) - return TokError("expected emission kind"); + return tokError("expected emission kind"); auto Kind = DICompileUnit::getEmissionKind(Lex.getStrVal()); if (!Kind) - return TokError("invalid emission kind" + Twine(" '") + Lex.getStrVal() + + return tokError("invalid emission kind" + Twine(" '") + Lex.getStrVal() + "'"); assert(*Kind <= Result.Max && "Expected valid emission kind"); Result.assign(*Kind); @@ -4211,17 +4211,17 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, +bool LLParser::parseMDField(LocTy Loc, StringRef Name, NameTableKindField &Result) { if (Lex.getKind() == lltok::APSInt) - return ParseMDField(Loc, Name, static_cast(Result)); + return parseMDField(Loc, Name, static_cast(Result)); if (Lex.getKind() != lltok::NameTableKind) - return TokError("expected nameTable kind"); + return tokError("expected nameTable kind"); auto Kind = DICompileUnit::getNameTableKind(Lex.getStrVal()); if (!Kind) - return TokError("invalid nameTable kind" + Twine(" '") + Lex.getStrVal() + + return tokError("invalid nameTable kind" + Twine(" '") + Lex.getStrVal() + "'"); assert(((unsigned)*Kind) <= Result.Max && "Expected valid nameTable kind"); Result.assign((unsigned)*Kind); @@ -4230,17 +4230,17 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, +bool LLParser::parseMDField(LocTy Loc, StringRef Name, DwarfAttEncodingField &Result) { if (Lex.getKind() == lltok::APSInt) - return ParseMDField(Loc, Name, static_cast(Result)); + return parseMDField(Loc, Name, static_cast(Result)); if (Lex.getKind() != lltok::DwarfAttEncoding) - return TokError("expected DWARF type attribute encoding"); + return tokError("expected DWARF type attribute encoding"); unsigned Encoding = dwarf::getAttributeEncoding(Lex.getStrVal()); if (!Encoding) - return TokError("invalid DWARF type attribute encoding" + Twine(" '") + + return tokError("invalid DWARF type attribute encoding" + Twine(" '") + Lex.getStrVal() + "'"); assert(Encoding <= Result.Max && "Expected valid DWARF language"); Result.assign(Encoding); @@ -4253,29 +4253,29 @@ /// ::= DIFlagVector /// ::= DIFlagVector '|' DIFlagFwdDecl '|' uint32 '|' DIFlagPublic template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, DIFlagField &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, DIFlagField &Result) { - // Parser for a single flag. + // parser for a single flag. auto parseFlag = [&](DINode::DIFlags &Val) { if (Lex.getKind() == lltok::APSInt && !Lex.getAPSIntVal().isSigned()) { uint32_t TempVal = static_cast(Val); - bool Res = ParseUInt32(TempVal); + bool Res = parseUInt32(TempVal); Val = static_cast(TempVal); return Res; } if (Lex.getKind() != lltok::DIFlag) - return TokError("expected debug info flag"); + return tokError("expected debug info flag"); Val = DINode::getFlag(Lex.getStrVal()); if (!Val) - return TokError(Twine("invalid debug info flag flag '") + + return tokError(Twine("invalid debug info flag flag '") + Lex.getStrVal() + "'"); Lex.Lex(); return false; }; - // Parse the flags and combine them together. + // parse the flags and combine them together. DINode::DIFlags Combined = DINode::FlagZero; do { DINode::DIFlags Val; @@ -4293,29 +4293,29 @@ /// ::= DISPFlagVector /// ::= DISPFlagVector '|' DISPFlag* '|' uint32 template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, DISPFlagField &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, DISPFlagField &Result) { - // Parser for a single flag. + // parser for a single flag. auto parseFlag = [&](DISubprogram::DISPFlags &Val) { if (Lex.getKind() == lltok::APSInt && !Lex.getAPSIntVal().isSigned()) { uint32_t TempVal = static_cast(Val); - bool Res = ParseUInt32(TempVal); + bool Res = parseUInt32(TempVal); Val = static_cast(TempVal); return Res; } if (Lex.getKind() != lltok::DISPFlag) - return TokError("expected debug info flag"); + return tokError("expected debug info flag"); Val = DISubprogram::getFlag(Lex.getStrVal()); if (!Val) - return TokError(Twine("invalid subprogram debug info flag '") + + return tokError(Twine("invalid subprogram debug info flag '") + Lex.getStrVal() + "'"); Lex.Lex(); return false; }; - // Parse the flags and combine them together. + // parse the flags and combine them together. DISubprogram::DISPFlags Combined = DISubprogram::SPFlagZero; do { DISubprogram::DISPFlags Val; @@ -4329,17 +4329,17 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, +bool LLParser::parseMDField(LocTy Loc, StringRef Name, MDSignedField &Result) { if (Lex.getKind() != lltok::APSInt) - return TokError("expected signed integer"); + return tokError("expected signed integer"); auto &S = Lex.getAPSIntVal(); if (S < Result.Min) - return TokError("value for '" + Name + "' too small, limit is " + + return tokError("value for '" + Name + "' too small, limit is " + Twine(Result.Min)); if (S > Result.Max) - return TokError("value for '" + Name + "' too large, limit is " + + return tokError("value for '" + Name + "' too large, limit is " + Twine(Result.Max)); Result.assign(S.getExtValue()); assert(Result.Val >= Result.Min && "Expected value in range"); @@ -4349,10 +4349,10 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, MDBoolField &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, MDBoolField &Result) { switch (Lex.getKind()) { default: - return TokError("expected 'true' or 'false'"); + return tokError("expected 'true' or 'false'"); case lltok::kw_true: Result.assign(true); break; @@ -4365,17 +4365,17 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, MDField &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, MDField &Result) { if (Lex.getKind() == lltok::kw_null) { if (!Result.AllowNull) - return TokError("'" + Name + "' cannot be null"); + return tokError("'" + Name + "' cannot be null"); Lex.Lex(); Result.assign(nullptr); return false; } Metadata *MD; - if (ParseMetadata(MD, nullptr)) + if (parseMetadata(MD, nullptr)) return true; Result.assign(MD); @@ -4383,12 +4383,12 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, +bool LLParser::parseMDField(LocTy Loc, StringRef Name, MDSignedOrMDField &Result) { // Try to parse a signed int. if (Lex.getKind() == lltok::APSInt) { MDSignedField Res = Result.A; - if (!ParseMDField(Loc, Name, Res)) { + if (!parseMDField(Loc, Name, Res)) { Result.assign(Res); return false; } @@ -4397,7 +4397,7 @@ // Otherwise, try to parse as an MDField. MDField Res = Result.B; - if (!ParseMDField(Loc, Name, Res)) { + if (!parseMDField(Loc, Name, Res)) { Result.assign(Res); return false; } @@ -4406,23 +4406,23 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, MDStringField &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, MDStringField &Result) { LocTy ValueLoc = Lex.getLoc(); std::string S; - if (ParseStringConstant(S)) + if (parseStringConstant(S)) return true; if (!Result.AllowEmpty && S.empty()) - return Error(ValueLoc, "'" + Name + "' cannot be empty"); + return error(ValueLoc, "'" + Name + "' cannot be empty"); Result.assign(S.empty() ? nullptr : MDString::get(Context, S)); return false; } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, MDFieldList &Result) { +bool LLParser::parseMDField(LocTy Loc, StringRef Name, MDFieldList &Result) { SmallVector MDs; - if (ParseMDNodeVector(MDs)) + if (parseMDNodeVector(MDs)) return true; Result.assign(std::move(MDs)); @@ -4430,13 +4430,13 @@ } template <> -bool LLParser::ParseMDField(LocTy Loc, StringRef Name, +bool LLParser::parseMDField(LocTy Loc, StringRef Name, ChecksumKindField &Result) { Optional CSKind = DIFile::getChecksumKind(Lex.getStrVal()); if (Lex.getKind() != lltok::ChecksumKind || !CSKind) - return TokError( + return tokError( "invalid checksum kind" + Twine(" '") + Lex.getStrVal() + "'"); Result.assign(*CSKind); @@ -4447,10 +4447,10 @@ } // end namespace llvm template -bool LLParser::ParseMDFieldsImplBody(ParserTy parseField) { +bool LLParser::parseMDFieldsImplBody(ParserTy parseField) { do { if (Lex.getKind() != lltok::LabelStr) - return TokError("expected field label here"); + return tokError("expected field label here"); if (parseField()) return true; @@ -4460,56 +4460,56 @@ } template -bool LLParser::ParseMDFieldsImpl(ParserTy parseField, LocTy &ClosingLoc) { +bool LLParser::parseMDFieldsImpl(ParserTy parseField, LocTy &ClosingLoc) { assert(Lex.getKind() == lltok::MetadataVar && "Expected metadata type name"); Lex.Lex(); - if (ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::lparen, "expected '(' here")) return true; if (Lex.getKind() != lltok::rparen) - if (ParseMDFieldsImplBody(parseField)) + if (parseMDFieldsImplBody(parseField)) return true; ClosingLoc = Lex.getLoc(); - return ParseToken(lltok::rparen, "expected ')' here"); + return parseToken(lltok::rparen, "expected ')' here"); } template -bool LLParser::ParseMDField(StringRef Name, FieldTy &Result) { +bool LLParser::parseMDField(StringRef Name, FieldTy &Result) { if (Result.Seen) - return TokError("field '" + Name + "' cannot be specified more than once"); + return tokError("field '" + Name + "' cannot be specified more than once"); LocTy Loc = Lex.getLoc(); Lex.Lex(); - return ParseMDField(Loc, Name, Result); + return parseMDField(Loc, Name, Result); } -bool LLParser::ParseSpecializedMDNode(MDNode *&N, bool IsDistinct) { +bool LLParser::parseSpecializedMDNode(MDNode *&N, bool IsDistinct) { assert(Lex.getKind() == lltok::MetadataVar && "Expected metadata type name"); #define HANDLE_SPECIALIZED_MDNODE_LEAF(CLASS) \ if (Lex.getStrVal() == #CLASS) \ - return Parse##CLASS(N, IsDistinct); + return parse##CLASS(N, IsDistinct); #include "llvm/IR/Metadata.def" - return TokError("expected metadata type"); + return tokError("expected metadata type"); } #define DECLARE_FIELD(NAME, TYPE, INIT) TYPE NAME INIT #define NOP_FIELD(NAME, TYPE, INIT) #define REQUIRE_FIELD(NAME, TYPE, INIT) \ if (!NAME.Seen) \ - return Error(ClosingLoc, "missing required field '" #NAME "'"); + return error(ClosingLoc, "missing required field '" #NAME "'"); #define PARSE_MD_FIELD(NAME, TYPE, DEFAULT) \ if (Lex.getStrVal() == #NAME) \ - return ParseMDField(#NAME, NAME); + return parseMDField(#NAME, NAME); #define PARSE_MD_FIELDS() \ VISIT_MD_FIELDS(DECLARE_FIELD, DECLARE_FIELD) \ do { \ LocTy ClosingLoc; \ - if (ParseMDFieldsImpl([&]() -> bool { \ + if (parseMDFieldsImpl([&]() -> bool { \ VISIT_MD_FIELDS(PARSE_MD_FIELD, PARSE_MD_FIELD) \ - return TokError(Twine("invalid field '") + Lex.getStrVal() + "'"); \ + return tokError(Twine("invalid field '") + Lex.getStrVal() + "'"); \ }, ClosingLoc)) \ return true; \ VISIT_MD_FIELDS(NOP_FIELD, REQUIRE_FIELD) \ @@ -4517,10 +4517,10 @@ #define GET_OR_DISTINCT(CLASS, ARGS) \ (IsDistinct ? CLASS::getDistinct ARGS : CLASS::get ARGS) -/// ParseDILocationFields: +/// parseDILocationFields: /// ::= !DILocation(line: 43, column: 8, scope: !5, inlinedAt: !6, /// isImplicitCode: true) -bool LLParser::ParseDILocation(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDILocation(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ OPTIONAL(line, LineField, ); \ OPTIONAL(column, ColumnField, ); \ @@ -4536,9 +4536,9 @@ return false; } -/// ParseGenericDINode: +/// parseGenericDINode: /// ::= !GenericDINode(tag: 15, header: "...", operands: {...}) -bool LLParser::ParseGenericDINode(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseGenericDINode(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(tag, DwarfTagField, ); \ OPTIONAL(header, MDStringField, ); \ @@ -4551,11 +4551,11 @@ return false; } -/// ParseDISubrange: +/// parseDISubrange: /// ::= !DISubrange(count: 30, lowerBound: 2) /// ::= !DISubrange(count: !node, lowerBound: 2) /// ::= !DISubrange(lowerBound: !node1, upperBound: !node2, stride: !node3) -bool LLParser::ParseDISubrange(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDISubrange(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ OPTIONAL(count, MDSignedOrMDField, (-1, -1, INT64_MAX, false)); \ OPTIONAL(lowerBound, MDSignedOrMDField, ); \ @@ -4593,9 +4593,46 @@ return false; } -/// ParseDIEnumerator: +/// parseDIGenericSubrange: +/// ::= !DIGenericSubrange(lowerBound: !node1, upperBound: !node2, stride: +/// !node3) +bool LLParser::parseDIGenericSubrange(MDNode *&Result, bool IsDistinct) { +#define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ + OPTIONAL(count, MDSignedOrMDField, (-1, -1, INT64_MAX, false)); \ + OPTIONAL(lowerBound, MDSignedOrMDField, ); \ + OPTIONAL(upperBound, MDSignedOrMDField, ); \ + OPTIONAL(stride, MDSignedOrMDField, ); + PARSE_MD_FIELDS(); +#undef VISIT_MD_FIELDS + + Metadata *Count = nullptr; + Metadata *LowerBound = nullptr; + Metadata *UpperBound = nullptr; + Metadata *Stride = nullptr; + + auto ConvToMetadata = [&](MDSignedOrMDField Bound) -> Metadata * { + if (Bound.isMDSignedField()) + return ConstantAsMetadata::get(ConstantInt::getSigned( + Type::getInt64Ty(Context), Bound.getMDSignedValue())); + if (Bound.isMDField()) + return Bound.getMDFieldValue(); + return nullptr; + }; + + Count = ConvToMetadata(count); + LowerBound = ConvToMetadata(lowerBound); + UpperBound = ConvToMetadata(upperBound); + Stride = ConvToMetadata(stride); + + Result = GET_OR_DISTINCT(DIGenericSubrange, + (Context, Count, LowerBound, UpperBound, Stride)); + + return false; +} + +/// parseDIEnumerator: /// ::= !DIEnumerator(value: 30, isUnsigned: true, name: "SomeKind") -bool LLParser::ParseDIEnumerator(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIEnumerator(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(name, MDStringField, ); \ REQUIRED(value, MDAPSIntField, ); \ @@ -4604,7 +4641,7 @@ #undef VISIT_MD_FIELDS if (isUnsigned.Val && value.Val.isNegative()) - return TokError("unsigned enumerator with negative value"); + return tokError("unsigned enumerator with negative value"); APSInt Value(value.Val); // Add a leading zero so that unsigned values with the msb set are not @@ -4618,10 +4655,10 @@ return false; } -/// ParseDIBasicType: +/// parseDIBasicType: /// ::= !DIBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, /// encoding: DW_ATE_encoding, flags: 0) -bool LLParser::ParseDIBasicType(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIBasicType(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ OPTIONAL(tag, DwarfTagField, (dwarf::DW_TAG_base_type)); \ OPTIONAL(name, MDStringField, ); \ @@ -4637,9 +4674,9 @@ return false; } -/// ParseDIStringType: +/// parseDIStringType: /// ::= !DIStringType(name: "character(4)", size: 32, align: 32) -bool LLParser::ParseDIStringType(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIStringType(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ OPTIONAL(tag, DwarfTagField, (dwarf::DW_TAG_string_type)); \ OPTIONAL(name, MDStringField, ); \ @@ -4658,12 +4695,12 @@ return false; } -/// ParseDIDerivedType: +/// parseDIDerivedType: /// ::= !DIDerivedType(tag: DW_TAG_pointer_type, name: "int", file: !0, /// line: 7, scope: !1, baseType: !2, size: 32, /// align: 32, offset: 0, flags: 0, extraData: !3, /// dwarfAddressSpace: 3) -bool LLParser::ParseDIDerivedType(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIDerivedType(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(tag, DwarfTagField, ); \ OPTIONAL(name, MDStringField, ); \ @@ -4692,7 +4729,7 @@ return false; } -bool LLParser::ParseDICompositeType(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDICompositeType(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(tag, DwarfTagField, ); \ OPTIONAL(name, MDStringField, ); \ @@ -4748,7 +4785,7 @@ return false; } -bool LLParser::ParseDISubroutineType(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDISubroutineType(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ OPTIONAL(flags, DIFlagField, ); \ OPTIONAL(cc, DwarfCCField, ); \ @@ -4761,12 +4798,12 @@ return false; } -/// ParseDIFileType: +/// parseDIFileType: /// ::= !DIFileType(filename: "path/to/file", directory: "/path/to/dir", /// checksumkind: CSK_MD5, /// checksum: "000102030405060708090a0b0c0d0e0f", /// source: "source file contents") -bool LLParser::ParseDIFile(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIFile(MDNode *&Result, bool IsDistinct) { // The default constructed value for checksumkind is required, but will never // be used, as the parser checks if the field was actually Seen before using // the Val. @@ -4793,14 +4830,14 @@ return false; } -/// ParseDICompileUnit: +/// parseDICompileUnit: /// ::= !DICompileUnit(language: DW_LANG_C99, file: !0, producer: "clang", /// isOptimized: true, flags: "-O2", runtimeVersion: 1, /// splitDebugFilename: "abc.debug", /// emissionKind: FullDebug, enums: !1, retainedTypes: !2, /// globals: !4, imports: !5, macros: !6, dwoId: 0x0abcd, /// sysroot: "/", sdk: "MacOSX.sdk") -bool LLParser::ParseDICompileUnit(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDICompileUnit(MDNode *&Result, bool IsDistinct) { if (!IsDistinct) return Lex.Error("missing 'distinct', required for !DICompileUnit"); @@ -4837,7 +4874,7 @@ return false; } -/// ParseDISubprogram: +/// parseDISubprogram: /// ::= !DISubprogram(scope: !0, name: "foo", linkageName: "_Zfoo", /// file: !1, line: 7, type: !2, isLocal: false, /// isDefinition: true, scopeLine: 8, containingType: !3, @@ -4845,7 +4882,7 @@ /// virtualIndex: 10, thisAdjustment: 4, flags: 11, /// spFlags: 10, isOptimized: false, templateParams: !4, /// declaration: !5, retainedNodes: !6, thrownTypes: !7) -bool LLParser::ParseDISubprogram(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDISubprogram(MDNode *&Result, bool IsDistinct) { auto Loc = Lex.getLoc(); #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ OPTIONAL(scope, MDField, ); \ @@ -4891,9 +4928,9 @@ return false; } -/// ParseDILexicalBlock: +/// parseDILexicalBlock: /// ::= !DILexicalBlock(scope: !0, file: !2, line: 7, column: 9) -bool LLParser::ParseDILexicalBlock(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDILexicalBlock(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(scope, MDField, (/* AllowNull */ false)); \ OPTIONAL(file, MDField, ); \ @@ -4907,9 +4944,9 @@ return false; } -/// ParseDILexicalBlockFile: +/// parseDILexicalBlockFile: /// ::= !DILexicalBlockFile(scope: !0, file: !2, discriminator: 9) -bool LLParser::ParseDILexicalBlockFile(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDILexicalBlockFile(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(scope, MDField, (/* AllowNull */ false)); \ OPTIONAL(file, MDField, ); \ @@ -4922,9 +4959,9 @@ return false; } -/// ParseDICommonBlock: +/// parseDICommonBlock: /// ::= !DICommonBlock(scope: !0, file: !2, name: "COMMON name", line: 9) -bool LLParser::ParseDICommonBlock(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDICommonBlock(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(scope, MDField, ); \ OPTIONAL(declaration, MDField, ); \ @@ -4940,9 +4977,9 @@ return false; } -/// ParseDINamespace: +/// parseDINamespace: /// ::= !DINamespace(scope: !0, file: !2, name: "SomeNamespace", line: 9) -bool LLParser::ParseDINamespace(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDINamespace(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(scope, MDField, ); \ OPTIONAL(name, MDStringField, ); \ @@ -4955,9 +4992,9 @@ return false; } -/// ParseDIMacro: +/// parseDIMacro: /// ::= !DIMacro(macinfo: type, line: 9, name: "SomeMacro", value: "SomeValue") -bool LLParser::ParseDIMacro(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIMacro(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(type, DwarfMacinfoTypeField, ); \ OPTIONAL(line, LineField, ); \ @@ -4971,9 +5008,9 @@ return false; } -/// ParseDIMacroFile: +/// parseDIMacroFile: /// ::= !DIMacroFile(line: 9, file: !2, nodes: !3) -bool LLParser::ParseDIMacroFile(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIMacroFile(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ OPTIONAL(type, DwarfMacinfoTypeField, (dwarf::DW_MACINFO_start_file)); \ OPTIONAL(line, LineField, ); \ @@ -4987,11 +5024,11 @@ return false; } -/// ParseDIModule: +/// parseDIModule: /// ::= !DIModule(scope: !0, name: "SomeModule", configMacros: /// "-DNDEBUG", includePath: "/usr/include", apinotes: "module.apinotes", /// file: !1, line: 4) -bool LLParser::ParseDIModule(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIModule(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(scope, MDField, ); \ REQUIRED(name, MDStringField, ); \ @@ -5009,9 +5046,9 @@ return false; } -/// ParseDITemplateTypeParameter: +/// parseDITemplateTypeParameter: /// ::= !DITemplateTypeParameter(name: "Ty", type: !1, defaulted: false) -bool LLParser::ParseDITemplateTypeParameter(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDITemplateTypeParameter(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ OPTIONAL(name, MDStringField, ); \ REQUIRED(type, MDField, ); \ @@ -5024,11 +5061,11 @@ return false; } -/// ParseDITemplateValueParameter: +/// parseDITemplateValueParameter: /// ::= !DITemplateValueParameter(tag: DW_TAG_template_value_parameter, /// name: "V", type: !1, defaulted: false, /// value: i32 7) -bool LLParser::ParseDITemplateValueParameter(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDITemplateValueParameter(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ OPTIONAL(tag, DwarfTagField, (dwarf::DW_TAG_template_value_parameter)); \ OPTIONAL(name, MDStringField, ); \ @@ -5045,12 +5082,12 @@ return false; } -/// ParseDIGlobalVariable: +/// parseDIGlobalVariable: /// ::= !DIGlobalVariable(scope: !0, name: "foo", linkageName: "foo", /// file: !1, line: 7, type: !2, isLocal: false, /// isDefinition: true, templateParams: !3, /// declaration: !4, align: 8) -bool LLParser::ParseDIGlobalVariable(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIGlobalVariable(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(name, MDStringField, (/* AllowEmpty */ false)); \ OPTIONAL(scope, MDField, ); \ @@ -5074,14 +5111,14 @@ return false; } -/// ParseDILocalVariable: +/// parseDILocalVariable: /// ::= !DILocalVariable(arg: 7, scope: !0, name: "foo", /// file: !1, line: 7, type: !2, arg: 2, flags: 7, /// align: 8) /// ::= !DILocalVariable(scope: !0, name: "foo", /// file: !1, line: 7, type: !2, arg: 2, flags: 7, /// align: 8) -bool LLParser::ParseDILocalVariable(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDILocalVariable(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(scope, MDField, (/* AllowNull */ false)); \ OPTIONAL(name, MDStringField, ); \ @@ -5100,9 +5137,9 @@ return false; } -/// ParseDILabel: +/// parseDILabel: /// ::= !DILabel(scope: !0, name: "foo", file: !1, line: 7) -bool LLParser::ParseDILabel(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDILabel(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(scope, MDField, (/* AllowNull */ false)); \ REQUIRED(name, MDStringField, ); \ @@ -5116,13 +5153,13 @@ return false; } -/// ParseDIExpression: +/// parseDIExpression: /// ::= !DIExpression(0, 7, -1) -bool LLParser::ParseDIExpression(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIExpression(MDNode *&Result, bool IsDistinct) { assert(Lex.getKind() == lltok::MetadataVar && "Expected metadata type name"); Lex.Lex(); - if (ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::lparen, "expected '(' here")) return true; SmallVector Elements; @@ -5134,7 +5171,7 @@ Elements.push_back(Op); continue; } - return TokError(Twine("invalid DWARF op '") + Lex.getStrVal() + "'"); + return tokError(Twine("invalid DWARF op '") + Lex.getStrVal() + "'"); } if (Lex.getKind() == lltok::DwarfAttEncoding) { @@ -5143,29 +5180,29 @@ Elements.push_back(Op); continue; } - return TokError(Twine("invalid DWARF attribute encoding '") + Lex.getStrVal() + "'"); + return tokError(Twine("invalid DWARF attribute encoding '") + Lex.getStrVal() + "'"); } if (Lex.getKind() != lltok::APSInt || Lex.getAPSIntVal().isSigned()) - return TokError("expected unsigned integer"); + return tokError("expected unsigned integer"); auto &U = Lex.getAPSIntVal(); if (U.ugt(UINT64_MAX)) - return TokError("element too large, limit is " + Twine(UINT64_MAX)); + return tokError("element too large, limit is " + Twine(UINT64_MAX)); Elements.push_back(U.getZExtValue()); Lex.Lex(); } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; Result = GET_OR_DISTINCT(DIExpression, (Context, Elements)); return false; } -/// ParseDIGlobalVariableExpression: +/// parseDIGlobalVariableExpression: /// ::= !DIGlobalVariableExpression(var: !0, expr: !1) -bool LLParser::ParseDIGlobalVariableExpression(MDNode *&Result, +bool LLParser::parseDIGlobalVariableExpression(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(var, MDField, ); \ @@ -5178,10 +5215,10 @@ return false; } -/// ParseDIObjCProperty: +/// parseDIObjCProperty: /// ::= !DIObjCProperty(name: "foo", file: !1, line: 7, setter: "setFoo", /// getter: "getFoo", attributes: 7, type: !2) -bool LLParser::ParseDIObjCProperty(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIObjCProperty(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ OPTIONAL(name, MDStringField, ); \ OPTIONAL(file, MDField, ); \ @@ -5199,10 +5236,10 @@ return false; } -/// ParseDIImportedEntity: +/// parseDIImportedEntity: /// ::= !DIImportedEntity(tag: DW_TAG_imported_module, scope: !0, entity: !1, /// line: 7, name: "foo") -bool LLParser::ParseDIImportedEntity(MDNode *&Result, bool IsDistinct) { +bool LLParser::parseDIImportedEntity(MDNode *&Result, bool IsDistinct) { #define VISIT_MD_FIELDS(OPTIONAL, REQUIRED) \ REQUIRED(tag, DwarfTagField, ); \ REQUIRED(scope, MDField, ); \ @@ -5224,45 +5261,45 @@ #undef REQUIRE_FIELD #undef DECLARE_FIELD -/// ParseMetadataAsValue +/// parseMetadataAsValue /// ::= metadata i32 %local /// ::= metadata i32 @global /// ::= metadata i32 7 /// ::= metadata !0 /// ::= metadata !{...} /// ::= metadata !"string" -bool LLParser::ParseMetadataAsValue(Value *&V, PerFunctionState &PFS) { +bool LLParser::parseMetadataAsValue(Value *&V, PerFunctionState &PFS) { // Note: the type 'metadata' has already been parsed. Metadata *MD; - if (ParseMetadata(MD, &PFS)) + if (parseMetadata(MD, &PFS)) return true; V = MetadataAsValue::get(Context, MD); return false; } -/// ParseValueAsMetadata +/// parseValueAsMetadata /// ::= i32 %local /// ::= i32 @global /// ::= i32 7 -bool LLParser::ParseValueAsMetadata(Metadata *&MD, const Twine &TypeMsg, +bool LLParser::parseValueAsMetadata(Metadata *&MD, const Twine &TypeMsg, PerFunctionState *PFS) { Type *Ty; LocTy Loc; - if (ParseType(Ty, TypeMsg, Loc)) + if (parseType(Ty, TypeMsg, Loc)) return true; if (Ty->isMetadataTy()) - return Error(Loc, "invalid metadata-value-metadata roundtrip"); + return error(Loc, "invalid metadata-value-metadata roundtrip"); Value *V; - if (ParseValue(Ty, V, PFS)) + if (parseValue(Ty, V, PFS)) return true; MD = ValueAsMetadata::get(V); return false; } -/// ParseMetadata +/// parseMetadata /// ::= i32 %local /// ::= i32 @global /// ::= i32 7 @@ -5270,10 +5307,10 @@ /// ::= !{...} /// ::= !"string" /// ::= !DILocation(...) -bool LLParser::ParseMetadata(Metadata *&MD, PerFunctionState *PFS) { +bool LLParser::parseMetadata(Metadata *&MD, PerFunctionState *PFS) { if (Lex.getKind() == lltok::MetadataVar) { MDNode *N; - if (ParseSpecializedMDNode(N)) + if (parseSpecializedMDNode(N)) return true; MD = N; return false; @@ -5282,7 +5319,7 @@ // ValueAsMetadata: // if (Lex.getKind() != lltok::exclaim) - return ParseValueAsMetadata(MD, "expected metadata operand", PFS); + return parseValueAsMetadata(MD, "expected metadata operand", PFS); // '!'. assert(Lex.getKind() == lltok::exclaim && "Expected '!' here"); @@ -5292,7 +5329,7 @@ // ::= '!' STRINGCONSTANT if (Lex.getKind() == lltok::StringConstant) { MDString *S; - if (ParseMDString(S)) + if (parseMDString(S)) return true; MD = S; return false; @@ -5302,7 +5339,7 @@ // !{ ... } // !7 MDNode *N; - if (ParseMDNodeTail(N)) + if (parseMDNodeTail(N)) return true; MD = N; return false; @@ -5312,44 +5349,44 @@ // Function Parsing. //===----------------------------------------------------------------------===// -bool LLParser::ConvertValIDToValue(Type *Ty, ValID &ID, Value *&V, +bool LLParser::convertValIDToValue(Type *Ty, ValID &ID, Value *&V, PerFunctionState *PFS, bool IsCall) { if (Ty->isFunctionTy()) - return Error(ID.Loc, "functions are not values, refer to them as pointers"); + return error(ID.Loc, "functions are not values, refer to them as pointers"); switch (ID.Kind) { case ValID::t_LocalID: - if (!PFS) return Error(ID.Loc, "invalid use of function-local name"); - V = PFS->GetVal(ID.UIntVal, Ty, ID.Loc, IsCall); + if (!PFS) return error(ID.Loc, "invalid use of function-local name"); + V = PFS->getVal(ID.UIntVal, Ty, ID.Loc, IsCall); return V == nullptr; case ValID::t_LocalName: - if (!PFS) return Error(ID.Loc, "invalid use of function-local name"); - V = PFS->GetVal(ID.StrVal, Ty, ID.Loc, IsCall); + if (!PFS) return error(ID.Loc, "invalid use of function-local name"); + V = PFS->getVal(ID.StrVal, Ty, ID.Loc, IsCall); return V == nullptr; case ValID::t_InlineAsm: { if (!ID.FTy || !InlineAsm::Verify(ID.FTy, ID.StrVal2)) - return Error(ID.Loc, "invalid type for inline asm constraint string"); + return error(ID.Loc, "invalid type for inline asm constraint string"); V = InlineAsm::get(ID.FTy, ID.StrVal, ID.StrVal2, ID.UIntVal & 1, (ID.UIntVal >> 1) & 1, (InlineAsm::AsmDialect(ID.UIntVal >> 2))); return false; } case ValID::t_GlobalName: - V = GetGlobalVal(ID.StrVal, Ty, ID.Loc, IsCall); + V = getGlobalVal(ID.StrVal, Ty, ID.Loc, IsCall); return V == nullptr; case ValID::t_GlobalID: - V = GetGlobalVal(ID.UIntVal, Ty, ID.Loc, IsCall); + V = getGlobalVal(ID.UIntVal, Ty, ID.Loc, IsCall); return V == nullptr; case ValID::t_APSInt: if (!Ty->isIntegerTy()) - return Error(ID.Loc, "integer constant must have integer type"); + return error(ID.Loc, "integer constant must have integer type"); ID.APSIntVal = ID.APSIntVal.extOrTrunc(Ty->getPrimitiveSizeInBits()); V = ConstantInt::get(Context, ID.APSIntVal); return false; case ValID::t_APFloat: if (!Ty->isFloatingPointTy() || !ConstantFP::isValueValidForType(Ty, ID.APFloatVal)) - return Error(ID.Loc, "floating point constant invalid for type"); + return error(ID.Loc, "floating point constant invalid for type"); // The lexer has no type info, so builds all half, bfloat, float, and double // FP constants as double. Fix this here. Long double does not need this. @@ -5378,40 +5415,40 @@ V = ConstantFP::get(Context, ID.APFloatVal); if (V->getType() != Ty) - return Error(ID.Loc, "floating point constant does not have type '" + + return error(ID.Loc, "floating point constant does not have type '" + getTypeString(Ty) + "'"); return false; case ValID::t_Null: if (!Ty->isPointerTy()) - return Error(ID.Loc, "null must be a pointer type"); + return error(ID.Loc, "null must be a pointer type"); V = ConstantPointerNull::get(cast(Ty)); return false; case ValID::t_Undef: // FIXME: LabelTy should not be a first-class type. if (!Ty->isFirstClassType() || Ty->isLabelTy()) - return Error(ID.Loc, "invalid type for undef constant"); + return error(ID.Loc, "invalid type for undef constant"); V = UndefValue::get(Ty); return false; case ValID::t_EmptyArray: if (!Ty->isArrayTy() || cast(Ty)->getNumElements() != 0) - return Error(ID.Loc, "invalid empty array initializer"); + return error(ID.Loc, "invalid empty array initializer"); V = UndefValue::get(Ty); return false; case ValID::t_Zero: // FIXME: LabelTy should not be a first-class type. if (!Ty->isFirstClassType() || Ty->isLabelTy()) - return Error(ID.Loc, "invalid type for null constant"); + return error(ID.Loc, "invalid type for null constant"); V = Constant::getNullValue(Ty); return false; case ValID::t_None: if (!Ty->isTokenTy()) - return Error(ID.Loc, "invalid type for none constant"); + return error(ID.Loc, "invalid type for none constant"); V = Constant::getNullValue(Ty); return false; case ValID::t_Constant: if (ID.ConstantVal->getType() != Ty) - return Error(ID.Loc, "constant expression type mismatch"); + return error(ID.Loc, "constant expression type mismatch"); V = ID.ConstantVal; return false; @@ -5419,21 +5456,21 @@ case ValID::t_PackedConstantStruct: if (StructType *ST = dyn_cast(Ty)) { if (ST->getNumElements() != ID.UIntVal) - return Error(ID.Loc, + return error(ID.Loc, "initializer with struct type has wrong # elements"); if (ST->isPacked() != (ID.Kind == ValID::t_PackedConstantStruct)) - return Error(ID.Loc, "packed'ness of initializer and type don't match"); + return error(ID.Loc, "packed'ness of initializer and type don't match"); // Verify that the elements are compatible with the structtype. for (unsigned i = 0, e = ID.UIntVal; i != e; ++i) if (ID.ConstantStructElts[i]->getType() != ST->getElementType(i)) - return Error(ID.Loc, "element " + Twine(i) + + return error(ID.Loc, "element " + Twine(i) + " of struct initializer doesn't match struct element type"); V = ConstantStruct::get( ST, makeArrayRef(ID.ConstantStructElts.get(), ID.UIntVal)); } else - return Error(ID.Loc, "constant expression type mismatch"); + return error(ID.Loc, "constant expression type mismatch"); return false; } llvm_unreachable("Invalid ValID"); @@ -5443,7 +5480,7 @@ C = nullptr; ValID ID; auto Loc = Lex.getLoc(); - if (ParseValID(ID, /*PFS=*/nullptr)) + if (parseValID(ID, /*PFS=*/nullptr)) return true; switch (ID.Kind) { case ValID::t_APSInt: @@ -5453,7 +5490,7 @@ case ValID::t_ConstantStruct: case ValID::t_PackedConstantStruct: { Value *V; - if (ConvertValIDToValue(Ty, ID, V, /*PFS=*/nullptr, /*IsCall=*/false)) + if (convertValIDToValue(Ty, ID, V, /*PFS=*/nullptr, /*IsCall=*/false)) return true; assert(isa(V) && "Expected a constant value"); C = cast(V); @@ -5463,30 +5500,30 @@ C = Constant::getNullValue(Ty); return false; default: - return Error(Loc, "expected a constant value"); + return error(Loc, "expected a constant value"); } } -bool LLParser::ParseValue(Type *Ty, Value *&V, PerFunctionState *PFS) { +bool LLParser::parseValue(Type *Ty, Value *&V, PerFunctionState *PFS) { V = nullptr; ValID ID; - return ParseValID(ID, PFS) || - ConvertValIDToValue(Ty, ID, V, PFS, /*IsCall=*/false); + return parseValID(ID, PFS) || + convertValIDToValue(Ty, ID, V, PFS, /*IsCall=*/false); } -bool LLParser::ParseTypeAndValue(Value *&V, PerFunctionState *PFS) { +bool LLParser::parseTypeAndValue(Value *&V, PerFunctionState *PFS) { Type *Ty = nullptr; - return ParseType(Ty) || - ParseValue(Ty, V, PFS); + return parseType(Ty) || + parseValue(Ty, V, PFS); } -bool LLParser::ParseTypeAndBasicBlock(BasicBlock *&BB, LocTy &Loc, +bool LLParser::parseTypeAndBasicBlock(BasicBlock *&BB, LocTy &Loc, PerFunctionState &PFS) { Value *V; Loc = Lex.getLoc(); - if (ParseTypeAndValue(V, PFS)) return true; + if (parseTypeAndValue(V, PFS)) return true; if (!isa(V)) - return Error(Loc, "expected a basic block"); + return error(Loc, "expected a basic block"); BB = cast(V); return false; } @@ -5496,8 +5533,8 @@ /// OptionalCallingConv OptRetAttrs OptUnnamedAddr Type GlobalName /// '(' ArgList ')' OptAddrSpace OptFuncAttrs OptSection OptionalAlign /// OptGC OptionalPrefix OptionalPrologue OptPersonalityFn -bool LLParser::ParseFunctionHeader(Function *&Fn, bool isDefine) { - // Parse the linkage. +bool LLParser::parseFunctionHeader(Function *&Fn, bool isDefine) { + // parse the linkage. LocTy LinkageLoc = Lex.getLoc(); unsigned Linkage; unsigned Visibility; @@ -5508,10 +5545,10 @@ bool HasLinkage; Type *RetType = nullptr; LocTy RetTypeLoc = Lex.getLoc(); - if (ParseOptionalLinkage(Linkage, HasLinkage, Visibility, DLLStorageClass, + if (parseOptionalLinkage(Linkage, HasLinkage, Visibility, DLLStorageClass, DSOLocal) || - ParseOptionalCallingConv(CC) || ParseOptionalReturnAttrs(RetAttrs) || - ParseType(RetType, RetTypeLoc, true /*void allowed*/)) + parseOptionalCallingConv(CC) || parseOptionalReturnAttrs(RetAttrs) || + parseType(RetType, RetTypeLoc, true /*void allowed*/)) return true; // Verify that the linkage is ok. @@ -5520,7 +5557,7 @@ break; // always ok. case GlobalValue::ExternalWeakLinkage: if (isDefine) - return Error(LinkageLoc, "invalid linkage for function definition"); + return error(LinkageLoc, "invalid linkage for function definition"); break; case GlobalValue::PrivateLinkage: case GlobalValue::InternalLinkage: @@ -5530,19 +5567,19 @@ case GlobalValue::WeakAnyLinkage: case GlobalValue::WeakODRLinkage: if (!isDefine) - return Error(LinkageLoc, "invalid linkage for function declaration"); + return error(LinkageLoc, "invalid linkage for function declaration"); break; case GlobalValue::AppendingLinkage: case GlobalValue::CommonLinkage: - return Error(LinkageLoc, "invalid function linkage type"); + return error(LinkageLoc, "invalid function linkage type"); } if (!isValidVisibilityForLinkage(Visibility, Linkage)) - return Error(LinkageLoc, + return error(LinkageLoc, "symbol with local linkage must have default visibility"); if (!FunctionType::isValidReturnType(RetType)) - return Error(RetTypeLoc, "invalid function return type"); + return error(RetTypeLoc, "invalid function return type"); LocTy NameLoc = Lex.getLoc(); @@ -5553,16 +5590,16 @@ unsigned NameID = Lex.getUIntVal(); if (NameID != NumberedVals.size()) - return TokError("function expected to be numbered '%" + + return tokError("function expected to be numbered '%" + Twine(NumberedVals.size()) + "'"); } else { - return TokError("expected function name"); + return tokError("expected function name"); } Lex.Lex(); if (Lex.getKind() != lltok::lparen) - return TokError("expected '(' in function argument list"); + return tokError("expected '(' in function argument list"); SmallVector ArgList; bool isVarArg; @@ -5580,29 +5617,29 @@ Constant *PersonalityFn = nullptr; Comdat *C; - if (ParseArgumentList(ArgList, isVarArg) || - ParseOptionalUnnamedAddr(UnnamedAddr) || - ParseOptionalProgramAddrSpace(AddrSpace) || - ParseFnAttributeValuePairs(FuncAttrs, FwdRefAttrGrps, false, + if (parseArgumentList(ArgList, isVarArg) || + parseOptionalUnnamedAddr(UnnamedAddr) || + parseOptionalProgramAddrSpace(AddrSpace) || + parseFnAttributeValuePairs(FuncAttrs, FwdRefAttrGrps, false, BuiltinLoc) || (EatIfPresent(lltok::kw_section) && - ParseStringConstant(Section)) || + parseStringConstant(Section)) || (EatIfPresent(lltok::kw_partition) && - ParseStringConstant(Partition)) || + parseStringConstant(Partition)) || parseOptionalComdat(FunctionName, C) || - ParseOptionalAlignment(Alignment) || + parseOptionalAlignment(Alignment) || (EatIfPresent(lltok::kw_gc) && - ParseStringConstant(GC)) || + parseStringConstant(GC)) || (EatIfPresent(lltok::kw_prefix) && - ParseGlobalTypeAndValue(Prefix)) || + parseGlobalTypeAndValue(Prefix)) || (EatIfPresent(lltok::kw_prologue) && - ParseGlobalTypeAndValue(Prologue)) || + parseGlobalTypeAndValue(Prologue)) || (EatIfPresent(lltok::kw_personality) && - ParseGlobalTypeAndValue(PersonalityFn))) + parseGlobalTypeAndValue(PersonalityFn))) return true; if (FuncAttrs.contains(Attribute::Builtin)) - return Error(BuiltinLoc, "'builtin' attribute not valid on function"); + return error(BuiltinLoc, "'builtin' attribute not valid on function"); // If the alignment was parsed as an attribute, move to the alignment field. if (FuncAttrs.hasAlignmentAttr()) { @@ -5625,7 +5662,7 @@ AttributeSet::get(Context, RetAttrs), Attrs); if (PAL.hasAttribute(1, Attribute::StructRet) && !RetType->isVoidTy()) - return Error(RetTypeLoc, "functions with 'sret' argument must return void"); + return error(RetTypeLoc, "functions with 'sret' argument must return void"); FunctionType *FT = FunctionType::get(RetType, ParamTypeList, isVarArg); @@ -5639,20 +5676,20 @@ if (FRVI != ForwardRefVals.end()) { Fn = M->getFunction(FunctionName); if (!Fn) - return Error(FRVI->second.second, "invalid forward reference to " + return error(FRVI->second.second, "invalid forward reference to " "function as global value!"); if (Fn->getType() != PFT) - return Error(FRVI->second.second, "invalid forward reference to " + return error(FRVI->second.second, "invalid forward reference to " "function '" + FunctionName + "' with wrong type: " "expected '" + getTypeString(PFT) + "' but was '" + getTypeString(Fn->getType()) + "'"); ForwardRefVals.erase(FRVI); } else if ((Fn = M->getFunction(FunctionName))) { // Reject redefinitions. - return Error(NameLoc, "invalid redefinition of function '" + + return error(NameLoc, "invalid redefinition of function '" + FunctionName + "'"); } else if (M->getNamedValue(FunctionName)) { - return Error(NameLoc, "redefinition of function '@" + FunctionName + "'"); + return error(NameLoc, "redefinition of function '@" + FunctionName + "'"); } } else { @@ -5662,7 +5699,7 @@ if (I != ForwardRefValIDs.end()) { Fn = cast(I->second.first); if (Fn->getType() != PFT) - return Error(NameLoc, "type of definition and forward reference of '@" + + return error(NameLoc, "type of definition and forward reference of '@" + Twine(NumberedVals.size()) + "' disagree: " "expected '" + getTypeString(PFT) + "' but was '" + getTypeString(Fn->getType()) + "'"); @@ -5708,7 +5745,7 @@ ArgIt->setName(ArgList[i].Name); if (ArgIt->getName() != ArgList[i].Name) - return Error(ArgList[i].Loc, "redefinition of argument '%" + + return error(ArgList[i].Loc, "redefinition of argument '%" + ArgList[i].Name + "'"); } @@ -5726,7 +5763,7 @@ } auto Blocks = ForwardRefBlockAddresses.find(ID); if (Blocks != ForwardRefBlockAddresses.end()) - return Error(Blocks->first.Loc, + return error(Blocks->first.Loc, "cannot take blockaddress inside a declaration"); return false; } @@ -5753,11 +5790,11 @@ "Expected local id or name"); BasicBlock *BB; if (BBID.Kind == ValID::t_LocalName) - BB = GetBB(BBID.StrVal, BBID.Loc); + BB = getBB(BBID.StrVal, BBID.Loc); else - BB = GetBB(BBID.UIntVal, BBID.Loc); + BB = getBB(BBID.UIntVal, BBID.Loc); if (!BB) - return P.Error(BBID.Loc, "referenced value is not a basic block"); + return P.error(BBID.Loc, "referenced value is not a basic block"); GV->replaceAllUsesWith(BlockAddress::get(&F, BB)); GV->eraseFromParent(); @@ -5767,11 +5804,11 @@ return false; } -/// ParseFunctionBody +/// parseFunctionBody /// ::= '{' BasicBlock+ UseListOrderDirective* '}' -bool LLParser::ParseFunctionBody(Function &Fn) { +bool LLParser::parseFunctionBody(Function &Fn) { if (Lex.getKind() != lltok::lbrace) - return TokError("expected '{' in function body"); + return tokError("expected '{' in function body"); Lex.Lex(); // eat the {. int FunctionNumber = -1; @@ -5787,26 +5824,26 @@ // We need at least one basic block. if (Lex.getKind() == lltok::rbrace || Lex.getKind() == lltok::kw_uselistorder) - return TokError("function body requires at least one basic block"); + return tokError("function body requires at least one basic block"); while (Lex.getKind() != lltok::rbrace && Lex.getKind() != lltok::kw_uselistorder) - if (ParseBasicBlock(PFS)) return true; + if (parseBasicBlock(PFS)) return true; while (Lex.getKind() != lltok::rbrace) - if (ParseUseListOrder(&PFS)) + if (parseUseListOrder(&PFS)) return true; // Eat the }. Lex.Lex(); // Verify function is ok. - return PFS.FinishFunction(); + return PFS.finishFunction(); } -/// ParseBasicBlock +/// parseBasicBlock /// ::= (LabelStr|LabelID)? Instruction* -bool LLParser::ParseBasicBlock(PerFunctionState &PFS) { +bool LLParser::parseBasicBlock(PerFunctionState &PFS) { // If this basic block starts out with a name, remember it. std::string Name; int NameID = -1; @@ -5819,13 +5856,13 @@ Lex.Lex(); } - BasicBlock *BB = PFS.DefineBB(Name, NameID, NameLoc); + BasicBlock *BB = PFS.defineBB(Name, NameID, NameLoc); if (!BB) return true; std::string NameStr; - // Parse the instructions in this block until we get a terminator. + // parse the instructions in this block until we get a terminator. Instruction *Inst; do { // This instruction may have three possibilities for a name: a) none @@ -5837,17 +5874,17 @@ if (Lex.getKind() == lltok::LocalVarID) { NameID = Lex.getUIntVal(); Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' after instruction id")) + if (parseToken(lltok::equal, "expected '=' after instruction id")) return true; } else if (Lex.getKind() == lltok::LocalVar) { NameStr = Lex.getStrVal(); Lex.Lex(); - if (ParseToken(lltok::equal, "expected '=' after instruction name")) + if (parseToken(lltok::equal, "expected '=' after instruction name")) return true; } - switch (ParseInstruction(Inst, BB, PFS)) { - default: llvm_unreachable("Unknown ParseInstruction result!"); + switch (parseInstruction(Inst, BB, PFS)) { + default: llvm_unreachable("Unknown parseInstruction result!"); case InstError: return true; case InstNormal: BB->getInstList().push_back(Inst); @@ -5855,7 +5892,7 @@ // With a normal result, we check to see if the instruction is followed by // a comma and metadata. if (EatIfPresent(lltok::comma)) - if (ParseInstructionMetadata(*Inst)) + if (parseInstructionMetadata(*Inst)) return true; break; case InstExtraComma: @@ -5863,13 +5900,13 @@ // If the instruction parser ate an extra comma at the end of it, it // *must* be followed by metadata. - if (ParseInstructionMetadata(*Inst)) + if (parseInstructionMetadata(*Inst)) return true; break; } // Set the name on the instruction. - if (PFS.SetInstName(NameID, NameStr, NameLoc, Inst)) return true; + if (PFS.setInstName(NameID, NameStr, NameLoc, Inst)) return true; } while (!Inst->isTerminator()); return false; @@ -5879,37 +5916,37 @@ // Instruction Parsing. //===----------------------------------------------------------------------===// -/// ParseInstruction - Parse one of the many different instructions. +/// parseInstruction - parse one of the many different instructions. /// -int LLParser::ParseInstruction(Instruction *&Inst, BasicBlock *BB, +int LLParser::parseInstruction(Instruction *&Inst, BasicBlock *BB, PerFunctionState &PFS) { lltok::Kind Token = Lex.getKind(); if (Token == lltok::Eof) - return TokError("found end of file when expecting more instructions"); + return tokError("found end of file when expecting more instructions"); LocTy Loc = Lex.getLoc(); unsigned KeywordVal = Lex.getUIntVal(); Lex.Lex(); // Eat the keyword. switch (Token) { - default: return Error(Loc, "expected instruction opcode"); + default: return error(Loc, "expected instruction opcode"); // Terminator Instructions. case lltok::kw_unreachable: Inst = new UnreachableInst(Context); return false; - case lltok::kw_ret: return ParseRet(Inst, BB, PFS); - case lltok::kw_br: return ParseBr(Inst, PFS); - case lltok::kw_switch: return ParseSwitch(Inst, PFS); - case lltok::kw_indirectbr: return ParseIndirectBr(Inst, PFS); - case lltok::kw_invoke: return ParseInvoke(Inst, PFS); - case lltok::kw_resume: return ParseResume(Inst, PFS); - case lltok::kw_cleanupret: return ParseCleanupRet(Inst, PFS); - case lltok::kw_catchret: return ParseCatchRet(Inst, PFS); - case lltok::kw_catchswitch: return ParseCatchSwitch(Inst, PFS); - case lltok::kw_catchpad: return ParseCatchPad(Inst, PFS); - case lltok::kw_cleanuppad: return ParseCleanupPad(Inst, PFS); - case lltok::kw_callbr: return ParseCallBr(Inst, PFS); + case lltok::kw_ret: return parseRet(Inst, BB, PFS); + case lltok::kw_br: return parseBr(Inst, PFS); + case lltok::kw_switch: return parseSwitch(Inst, PFS); + case lltok::kw_indirectbr: return parseIndirectBr(Inst, PFS); + case lltok::kw_invoke: return parseInvoke(Inst, PFS); + case lltok::kw_resume: return parseResume(Inst, PFS); + case lltok::kw_cleanupret: return parseCleanupRet(Inst, PFS); + case lltok::kw_catchret: return parseCatchRet(Inst, PFS); + case lltok::kw_catchswitch: return parseCatchSwitch(Inst, PFS); + case lltok::kw_catchpad: return parseCatchPad(Inst, PFS); + case lltok::kw_cleanuppad: return parseCleanupPad(Inst, PFS); + case lltok::kw_callbr: return parseCallBr(Inst, PFS); // Unary Operators. case lltok::kw_fneg: { FastMathFlags FMF = EatFastMathFlagsIfPresent(); - int Res = ParseUnaryOp(Inst, PFS, KeywordVal, /*IsFP*/true); + int Res = parseUnaryOp(Inst, PFS, KeywordVal, /*IsFP*/true); if (Res != 0) return Res; if (FMF.any()) @@ -5925,7 +5962,7 @@ bool NSW = EatIfPresent(lltok::kw_nsw); if (!NUW) NUW = EatIfPresent(lltok::kw_nuw); - if (ParseArithmetic(Inst, PFS, KeywordVal, /*IsFP*/false)) return true; + if (parseArithmetic(Inst, PFS, KeywordVal, /*IsFP*/false)) return true; if (NUW) cast(Inst)->setHasNoUnsignedWrap(true); if (NSW) cast(Inst)->setHasNoSignedWrap(true); @@ -5937,7 +5974,7 @@ case lltok::kw_fdiv: case lltok::kw_frem: { FastMathFlags FMF = EatFastMathFlagsIfPresent(); - int Res = ParseArithmetic(Inst, PFS, KeywordVal, /*IsFP*/true); + int Res = parseArithmetic(Inst, PFS, KeywordVal, /*IsFP*/true); if (Res != 0) return Res; if (FMF.any()) @@ -5951,21 +5988,21 @@ case lltok::kw_ashr: { bool Exact = EatIfPresent(lltok::kw_exact); - if (ParseArithmetic(Inst, PFS, KeywordVal, /*IsFP*/false)) return true; + if (parseArithmetic(Inst, PFS, KeywordVal, /*IsFP*/false)) return true; if (Exact) cast(Inst)->setIsExact(true); return false; } case lltok::kw_urem: - case lltok::kw_srem: return ParseArithmetic(Inst, PFS, KeywordVal, + case lltok::kw_srem: return parseArithmetic(Inst, PFS, KeywordVal, /*IsFP*/false); case lltok::kw_and: case lltok::kw_or: - case lltok::kw_xor: return ParseLogical(Inst, PFS, KeywordVal); - case lltok::kw_icmp: return ParseCompare(Inst, PFS, KeywordVal); + case lltok::kw_xor: return parseLogical(Inst, PFS, KeywordVal); + case lltok::kw_icmp: return parseCompare(Inst, PFS, KeywordVal); case lltok::kw_fcmp: { FastMathFlags FMF = EatFastMathFlagsIfPresent(); - int Res = ParseCompare(Inst, PFS, KeywordVal); + int Res = parseCompare(Inst, PFS, KeywordVal); if (Res != 0) return Res; if (FMF.any()) @@ -5986,63 +6023,63 @@ case lltok::kw_fptoui: case lltok::kw_fptosi: case lltok::kw_inttoptr: - case lltok::kw_ptrtoint: return ParseCast(Inst, PFS, KeywordVal); + case lltok::kw_ptrtoint: return parseCast(Inst, PFS, KeywordVal); // Other. case lltok::kw_select: { FastMathFlags FMF = EatFastMathFlagsIfPresent(); - int Res = ParseSelect(Inst, PFS); + int Res = parseSelect(Inst, PFS); if (Res != 0) return Res; if (FMF.any()) { if (!isa(Inst)) - return Error(Loc, "fast-math-flags specified for select without " + return error(Loc, "fast-math-flags specified for select without " "floating-point scalar or vector return type"); Inst->setFastMathFlags(FMF); } return 0; } - case lltok::kw_va_arg: return ParseVA_Arg(Inst, PFS); - case lltok::kw_extractelement: return ParseExtractElement(Inst, PFS); - case lltok::kw_insertelement: return ParseInsertElement(Inst, PFS); - case lltok::kw_shufflevector: return ParseShuffleVector(Inst, PFS); + case lltok::kw_va_arg: return parseVA_Arg(Inst, PFS); + case lltok::kw_extractelement: return parseExtractElement(Inst, PFS); + case lltok::kw_insertelement: return parseInsertElement(Inst, PFS); + case lltok::kw_shufflevector: return parseShuffleVector(Inst, PFS); case lltok::kw_phi: { FastMathFlags FMF = EatFastMathFlagsIfPresent(); - int Res = ParsePHI(Inst, PFS); + int Res = parsePHI(Inst, PFS); if (Res != 0) return Res; if (FMF.any()) { if (!isa(Inst)) - return Error(Loc, "fast-math-flags specified for phi without " + return error(Loc, "fast-math-flags specified for phi without " "floating-point scalar or vector return type"); Inst->setFastMathFlags(FMF); } return 0; } - case lltok::kw_landingpad: return ParseLandingPad(Inst, PFS); - case lltok::kw_freeze: return ParseFreeze(Inst, PFS); + case lltok::kw_landingpad: return parseLandingPad(Inst, PFS); + case lltok::kw_freeze: return parseFreeze(Inst, PFS); // Call. - case lltok::kw_call: return ParseCall(Inst, PFS, CallInst::TCK_None); - case lltok::kw_tail: return ParseCall(Inst, PFS, CallInst::TCK_Tail); - case lltok::kw_musttail: return ParseCall(Inst, PFS, CallInst::TCK_MustTail); - case lltok::kw_notail: return ParseCall(Inst, PFS, CallInst::TCK_NoTail); + case lltok::kw_call: return parseCall(Inst, PFS, CallInst::TCK_None); + case lltok::kw_tail: return parseCall(Inst, PFS, CallInst::TCK_Tail); + case lltok::kw_musttail: return parseCall(Inst, PFS, CallInst::TCK_MustTail); + case lltok::kw_notail: return parseCall(Inst, PFS, CallInst::TCK_NoTail); // Memory. - case lltok::kw_alloca: return ParseAlloc(Inst, PFS); - case lltok::kw_load: return ParseLoad(Inst, PFS); - case lltok::kw_store: return ParseStore(Inst, PFS); - case lltok::kw_cmpxchg: return ParseCmpXchg(Inst, PFS); - case lltok::kw_atomicrmw: return ParseAtomicRMW(Inst, PFS); - case lltok::kw_fence: return ParseFence(Inst, PFS); - case lltok::kw_getelementptr: return ParseGetElementPtr(Inst, PFS); - case lltok::kw_extractvalue: return ParseExtractValue(Inst, PFS); - case lltok::kw_insertvalue: return ParseInsertValue(Inst, PFS); + case lltok::kw_alloca: return parseAlloc(Inst, PFS); + case lltok::kw_load: return parseLoad(Inst, PFS); + case lltok::kw_store: return parseStore(Inst, PFS); + case lltok::kw_cmpxchg: return parseCmpXchg(Inst, PFS); + case lltok::kw_atomicrmw: return parseAtomicRMW(Inst, PFS); + case lltok::kw_fence: return parseFence(Inst, PFS); + case lltok::kw_getelementptr: return parseGetElementPtr(Inst, PFS); + case lltok::kw_extractvalue: return parseExtractValue(Inst, PFS); + case lltok::kw_insertvalue: return parseInsertValue(Inst, PFS); } } -/// ParseCmpPredicate - Parse an integer or fp predicate, based on Kind. -bool LLParser::ParseCmpPredicate(unsigned &P, unsigned Opc) { +/// parseCmpPredicate - parse an integer or fp predicate, based on Kind. +bool LLParser::parseCmpPredicate(unsigned &P, unsigned Opc) { if (Opc == Instruction::FCmp) { switch (Lex.getKind()) { - default: return TokError("expected fcmp predicate (e.g. 'oeq')"); + default: return tokError("expected fcmp predicate (e.g. 'oeq')"); case lltok::kw_oeq: P = CmpInst::FCMP_OEQ; break; case lltok::kw_one: P = CmpInst::FCMP_ONE; break; case lltok::kw_olt: P = CmpInst::FCMP_OLT; break; @@ -6062,7 +6099,7 @@ } } else { switch (Lex.getKind()) { - default: return TokError("expected icmp predicate (e.g. 'eq')"); + default: return tokError("expected icmp predicate (e.g. 'eq')"); case lltok::kw_eq: P = CmpInst::ICMP_EQ; break; case lltok::kw_ne: P = CmpInst::ICMP_NE; break; case lltok::kw_slt: P = CmpInst::ICMP_SLT; break; @@ -6083,20 +6120,20 @@ // Terminator Instructions. //===----------------------------------------------------------------------===// -/// ParseRet - Parse a return instruction. +/// parseRet - parse a return instruction. /// ::= 'ret' void (',' !dbg, !1)* /// ::= 'ret' TypeAndValue (',' !dbg, !1)* -bool LLParser::ParseRet(Instruction *&Inst, BasicBlock *BB, +bool LLParser::parseRet(Instruction *&Inst, BasicBlock *BB, PerFunctionState &PFS) { SMLoc TypeLoc = Lex.getLoc(); Type *Ty = nullptr; - if (ParseType(Ty, true /*void allowed*/)) return true; + if (parseType(Ty, true /*void allowed*/)) return true; Type *ResType = PFS.getFunction().getReturnType(); if (Ty->isVoidTy()) { if (!ResType->isVoidTy()) - return Error(TypeLoc, "value doesn't match function result type '" + + return error(TypeLoc, "value doesn't match function result type '" + getTypeString(ResType) + "'"); Inst = ReturnInst::Create(Context); @@ -6104,24 +6141,24 @@ } Value *RV; - if (ParseValue(Ty, RV, PFS)) return true; + if (parseValue(Ty, RV, PFS)) return true; if (ResType != RV->getType()) - return Error(TypeLoc, "value doesn't match function result type '" + + return error(TypeLoc, "value doesn't match function result type '" + getTypeString(ResType) + "'"); Inst = ReturnInst::Create(Context, RV); return false; } -/// ParseBr +/// parseBr /// ::= 'br' TypeAndValue /// ::= 'br' TypeAndValue ',' TypeAndValue ',' TypeAndValue -bool LLParser::ParseBr(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseBr(Instruction *&Inst, PerFunctionState &PFS) { LocTy Loc, Loc2; Value *Op0; BasicBlock *Op1, *Op2; - if (ParseTypeAndValue(Op0, Loc, PFS)) return true; + if (parseTypeAndValue(Op0, Loc, PFS)) return true; if (BasicBlock *BB = dyn_cast(Op0)) { Inst = BranchInst::Create(BB); @@ -6129,52 +6166,52 @@ } if (Op0->getType() != Type::getInt1Ty(Context)) - return Error(Loc, "branch condition must have 'i1' type"); + return error(Loc, "branch condition must have 'i1' type"); - if (ParseToken(lltok::comma, "expected ',' after branch condition") || - ParseTypeAndBasicBlock(Op1, Loc, PFS) || - ParseToken(lltok::comma, "expected ',' after true destination") || - ParseTypeAndBasicBlock(Op2, Loc2, PFS)) + if (parseToken(lltok::comma, "expected ',' after branch condition") || + parseTypeAndBasicBlock(Op1, Loc, PFS) || + parseToken(lltok::comma, "expected ',' after true destination") || + parseTypeAndBasicBlock(Op2, Loc2, PFS)) return true; Inst = BranchInst::Create(Op1, Op2, Op0); return false; } -/// ParseSwitch +/// parseSwitch /// Instruction /// ::= 'switch' TypeAndValue ',' TypeAndValue '[' JumpTable ']' /// JumpTable /// ::= (TypeAndValue ',' TypeAndValue)* -bool LLParser::ParseSwitch(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseSwitch(Instruction *&Inst, PerFunctionState &PFS) { LocTy CondLoc, BBLoc; Value *Cond; BasicBlock *DefaultBB; - if (ParseTypeAndValue(Cond, CondLoc, PFS) || - ParseToken(lltok::comma, "expected ',' after switch condition") || - ParseTypeAndBasicBlock(DefaultBB, BBLoc, PFS) || - ParseToken(lltok::lsquare, "expected '[' with switch table")) + if (parseTypeAndValue(Cond, CondLoc, PFS) || + parseToken(lltok::comma, "expected ',' after switch condition") || + parseTypeAndBasicBlock(DefaultBB, BBLoc, PFS) || + parseToken(lltok::lsquare, "expected '[' with switch table")) return true; if (!Cond->getType()->isIntegerTy()) - return Error(CondLoc, "switch condition must have integer type"); + return error(CondLoc, "switch condition must have integer type"); - // Parse the jump table pairs. + // parse the jump table pairs. SmallPtrSet SeenCases; SmallVector, 32> Table; while (Lex.getKind() != lltok::rsquare) { Value *Constant; BasicBlock *DestBB; - if (ParseTypeAndValue(Constant, CondLoc, PFS) || - ParseToken(lltok::comma, "expected ',' after case value") || - ParseTypeAndBasicBlock(DestBB, PFS)) + if (parseTypeAndValue(Constant, CondLoc, PFS) || + parseToken(lltok::comma, "expected ',' after case value") || + parseTypeAndBasicBlock(DestBB, PFS)) return true; if (!SeenCases.insert(Constant).second) - return Error(CondLoc, "duplicate case value in switch"); + return error(CondLoc, "duplicate case value in switch"); if (!isa(Constant)) - return Error(CondLoc, "case value is not a constant integer"); + return error(CondLoc, "case value is not a constant integer"); Table.push_back(std::make_pair(cast(Constant), DestBB)); } @@ -6188,37 +6225,37 @@ return false; } -/// ParseIndirectBr +/// parseIndirectBr /// Instruction /// ::= 'indirectbr' TypeAndValue ',' '[' LabelList ']' -bool LLParser::ParseIndirectBr(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseIndirectBr(Instruction *&Inst, PerFunctionState &PFS) { LocTy AddrLoc; Value *Address; - if (ParseTypeAndValue(Address, AddrLoc, PFS) || - ParseToken(lltok::comma, "expected ',' after indirectbr address") || - ParseToken(lltok::lsquare, "expected '[' with indirectbr")) + if (parseTypeAndValue(Address, AddrLoc, PFS) || + parseToken(lltok::comma, "expected ',' after indirectbr address") || + parseToken(lltok::lsquare, "expected '[' with indirectbr")) return true; if (!Address->getType()->isPointerTy()) - return Error(AddrLoc, "indirectbr address must have pointer type"); + return error(AddrLoc, "indirectbr address must have pointer type"); - // Parse the destination list. + // parse the destination list. SmallVector DestList; if (Lex.getKind() != lltok::rsquare) { BasicBlock *DestBB; - if (ParseTypeAndBasicBlock(DestBB, PFS)) + if (parseTypeAndBasicBlock(DestBB, PFS)) return true; DestList.push_back(DestBB); while (EatIfPresent(lltok::comma)) { - if (ParseTypeAndBasicBlock(DestBB, PFS)) + if (parseTypeAndBasicBlock(DestBB, PFS)) return true; DestList.push_back(DestBB); } } - if (ParseToken(lltok::rsquare, "expected ']' at end of block list")) + if (parseToken(lltok::rsquare, "expected ']' at end of block list")) return true; IndirectBrInst *IBI = IndirectBrInst::Create(Address, DestList.size()); @@ -6228,10 +6265,10 @@ return false; } -/// ParseInvoke +/// parseInvoke /// ::= 'invoke' OptionalCallingConv OptionalAttrs Type Value ParamList /// OptionalAttrs 'to' TypeAndValue 'unwind' TypeAndValue -bool LLParser::ParseInvoke(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseInvoke(Instruction *&Inst, PerFunctionState &PFS) { LocTy CallLoc = Lex.getLoc(); AttrBuilder RetAttrs, FnAttrs; std::vector FwdRefAttrGrps; @@ -6245,17 +6282,17 @@ SmallVector BundleList; BasicBlock *NormalBB, *UnwindBB; - if (ParseOptionalCallingConv(CC) || ParseOptionalReturnAttrs(RetAttrs) || - ParseOptionalProgramAddrSpace(InvokeAddrSpace) || - ParseType(RetType, RetTypeLoc, true /*void allowed*/) || - ParseValID(CalleeID) || ParseParameterList(ArgList, PFS) || - ParseFnAttributeValuePairs(FnAttrs, FwdRefAttrGrps, false, + if (parseOptionalCallingConv(CC) || parseOptionalReturnAttrs(RetAttrs) || + parseOptionalProgramAddrSpace(InvokeAddrSpace) || + parseType(RetType, RetTypeLoc, true /*void allowed*/) || + parseValID(CalleeID) || parseParameterList(ArgList, PFS) || + parseFnAttributeValuePairs(FnAttrs, FwdRefAttrGrps, false, NoBuiltinLoc) || - ParseOptionalOperandBundles(BundleList, PFS) || - ParseToken(lltok::kw_to, "expected 'to' in invoke") || - ParseTypeAndBasicBlock(NormalBB, PFS) || - ParseToken(lltok::kw_unwind, "expected 'unwind' in invoke") || - ParseTypeAndBasicBlock(UnwindBB, PFS)) + parseOptionalOperandBundles(BundleList, PFS) || + parseToken(lltok::kw_to, "expected 'to' in invoke") || + parseTypeAndBasicBlock(NormalBB, PFS) || + parseToken(lltok::kw_unwind, "expected 'unwind' in invoke") || + parseTypeAndBasicBlock(UnwindBB, PFS)) return true; // If RetType is a non-function pointer type, then this is the short syntax @@ -6269,7 +6306,7 @@ ParamTypes.push_back(ArgList[i].V->getType()); if (!FunctionType::isValidReturnType(RetType)) - return Error(RetTypeLoc, "Invalid result type for LLVM function"); + return error(RetTypeLoc, "Invalid result type for LLVM function"); Ty = FunctionType::get(RetType, ParamTypes, false); } @@ -6278,7 +6315,7 @@ // Look up the callee. Value *Callee; - if (ConvertValIDToValue(PointerType::get(Ty, InvokeAddrSpace), CalleeID, + if (convertValIDToValue(PointerType::get(Ty, InvokeAddrSpace), CalleeID, Callee, &PFS, /*IsCall=*/true)) return true; @@ -6295,21 +6332,21 @@ if (I != E) { ExpectedTy = *I++; } else if (!Ty->isVarArg()) { - return Error(ArgList[i].Loc, "too many arguments specified"); + return error(ArgList[i].Loc, "too many arguments specified"); } if (ExpectedTy && ExpectedTy != ArgList[i].V->getType()) - return Error(ArgList[i].Loc, "argument is not of expected type '" + + return error(ArgList[i].Loc, "argument is not of expected type '" + getTypeString(ExpectedTy) + "'"); Args.push_back(ArgList[i].V); ArgAttrs.push_back(ArgList[i].Attrs); } if (I != E) - return Error(CallLoc, "not enough parameters specified for call"); + return error(CallLoc, "not enough parameters specified for call"); if (FnAttrs.hasAlignmentAttr()) - return Error(CallLoc, "invoke instructions may not have an alignment"); + return error(CallLoc, "invoke instructions may not have an alignment"); // Finish off the Attribute and check them AttributeList PAL = @@ -6325,11 +6362,11 @@ return false; } -/// ParseResume +/// parseResume /// ::= 'resume' TypeAndValue -bool LLParser::ParseResume(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseResume(Instruction *&Inst, PerFunctionState &PFS) { Value *Exn; LocTy ExnLoc; - if (ParseTypeAndValue(Exn, ExnLoc, PFS)) + if (parseTypeAndValue(Exn, ExnLoc, PFS)) return true; ResumeInst *RI = ResumeInst::Create(Exn); @@ -6337,29 +6374,29 @@ return false; } -bool LLParser::ParseExceptionArgs(SmallVectorImpl &Args, +bool LLParser::parseExceptionArgs(SmallVectorImpl &Args, PerFunctionState &PFS) { - if (ParseToken(lltok::lsquare, "expected '[' in catchpad/cleanuppad")) + if (parseToken(lltok::lsquare, "expected '[' in catchpad/cleanuppad")) return true; while (Lex.getKind() != lltok::rsquare) { // If this isn't the first argument, we need a comma. if (!Args.empty() && - ParseToken(lltok::comma, "expected ',' in argument list")) + parseToken(lltok::comma, "expected ',' in argument list")) return true; - // Parse the argument. + // parse the argument. LocTy ArgLoc; Type *ArgTy = nullptr; - if (ParseType(ArgTy, ArgLoc)) + if (parseType(ArgTy, ArgLoc)) return true; Value *V; if (ArgTy->isMetadataTy()) { - if (ParseMetadataAsValue(V, PFS)) + if (parseMetadataAsValue(V, PFS)) return true; } else { - if (ParseValue(ArgTy, V, PFS)) + if (parseValue(ArgTy, V, PFS)) return true; } Args.push_back(V); @@ -6369,27 +6406,27 @@ return false; } -/// ParseCleanupRet +/// parseCleanupRet /// ::= 'cleanupret' from Value unwind ('to' 'caller' | TypeAndValue) -bool LLParser::ParseCleanupRet(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseCleanupRet(Instruction *&Inst, PerFunctionState &PFS) { Value *CleanupPad = nullptr; - if (ParseToken(lltok::kw_from, "expected 'from' after cleanupret")) + if (parseToken(lltok::kw_from, "expected 'from' after cleanupret")) return true; - if (ParseValue(Type::getTokenTy(Context), CleanupPad, PFS)) + if (parseValue(Type::getTokenTy(Context), CleanupPad, PFS)) return true; - if (ParseToken(lltok::kw_unwind, "expected 'unwind' in cleanupret")) + if (parseToken(lltok::kw_unwind, "expected 'unwind' in cleanupret")) return true; BasicBlock *UnwindBB = nullptr; if (Lex.getKind() == lltok::kw_to) { Lex.Lex(); - if (ParseToken(lltok::kw_caller, "expected 'caller' in cleanupret")) + if (parseToken(lltok::kw_caller, "expected 'caller' in cleanupret")) return true; } else { - if (ParseTypeAndBasicBlock(UnwindBB, PFS)) { + if (parseTypeAndBasicBlock(UnwindBB, PFS)) { return true; } } @@ -6398,65 +6435,65 @@ return false; } -/// ParseCatchRet +/// parseCatchRet /// ::= 'catchret' from Parent Value 'to' TypeAndValue -bool LLParser::ParseCatchRet(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseCatchRet(Instruction *&Inst, PerFunctionState &PFS) { Value *CatchPad = nullptr; - if (ParseToken(lltok::kw_from, "expected 'from' after catchret")) + if (parseToken(lltok::kw_from, "expected 'from' after catchret")) return true; - if (ParseValue(Type::getTokenTy(Context), CatchPad, PFS)) + if (parseValue(Type::getTokenTy(Context), CatchPad, PFS)) return true; BasicBlock *BB; - if (ParseToken(lltok::kw_to, "expected 'to' in catchret") || - ParseTypeAndBasicBlock(BB, PFS)) + if (parseToken(lltok::kw_to, "expected 'to' in catchret") || + parseTypeAndBasicBlock(BB, PFS)) return true; Inst = CatchReturnInst::Create(CatchPad, BB); return false; } -/// ParseCatchSwitch +/// parseCatchSwitch /// ::= 'catchswitch' within Parent -bool LLParser::ParseCatchSwitch(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseCatchSwitch(Instruction *&Inst, PerFunctionState &PFS) { Value *ParentPad; - if (ParseToken(lltok::kw_within, "expected 'within' after catchswitch")) + if (parseToken(lltok::kw_within, "expected 'within' after catchswitch")) return true; if (Lex.getKind() != lltok::kw_none && Lex.getKind() != lltok::LocalVar && Lex.getKind() != lltok::LocalVarID) - return TokError("expected scope value for catchswitch"); + return tokError("expected scope value for catchswitch"); - if (ParseValue(Type::getTokenTy(Context), ParentPad, PFS)) + if (parseValue(Type::getTokenTy(Context), ParentPad, PFS)) return true; - if (ParseToken(lltok::lsquare, "expected '[' with catchswitch labels")) + if (parseToken(lltok::lsquare, "expected '[' with catchswitch labels")) return true; SmallVector Table; do { BasicBlock *DestBB; - if (ParseTypeAndBasicBlock(DestBB, PFS)) + if (parseTypeAndBasicBlock(DestBB, PFS)) return true; Table.push_back(DestBB); } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rsquare, "expected ']' after catchswitch labels")) + if (parseToken(lltok::rsquare, "expected ']' after catchswitch labels")) return true; - if (ParseToken(lltok::kw_unwind, + if (parseToken(lltok::kw_unwind, "expected 'unwind' after catchswitch scope")) return true; BasicBlock *UnwindBB = nullptr; if (EatIfPresent(lltok::kw_to)) { - if (ParseToken(lltok::kw_caller, "expected 'caller' in catchswitch")) + if (parseToken(lltok::kw_caller, "expected 'caller' in catchswitch")) return true; } else { - if (ParseTypeAndBasicBlock(UnwindBB, PFS)) + if (parseTypeAndBasicBlock(UnwindBB, PFS)) return true; } @@ -6468,45 +6505,45 @@ return false; } -/// ParseCatchPad +/// parseCatchPad /// ::= 'catchpad' ParamList 'to' TypeAndValue 'unwind' TypeAndValue -bool LLParser::ParseCatchPad(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseCatchPad(Instruction *&Inst, PerFunctionState &PFS) { Value *CatchSwitch = nullptr; - if (ParseToken(lltok::kw_within, "expected 'within' after catchpad")) + if (parseToken(lltok::kw_within, "expected 'within' after catchpad")) return true; if (Lex.getKind() != lltok::LocalVar && Lex.getKind() != lltok::LocalVarID) - return TokError("expected scope value for catchpad"); + return tokError("expected scope value for catchpad"); - if (ParseValue(Type::getTokenTy(Context), CatchSwitch, PFS)) + if (parseValue(Type::getTokenTy(Context), CatchSwitch, PFS)) return true; SmallVector Args; - if (ParseExceptionArgs(Args, PFS)) + if (parseExceptionArgs(Args, PFS)) return true; Inst = CatchPadInst::Create(CatchSwitch, Args); return false; } -/// ParseCleanupPad +/// parseCleanupPad /// ::= 'cleanuppad' within Parent ParamList -bool LLParser::ParseCleanupPad(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseCleanupPad(Instruction *&Inst, PerFunctionState &PFS) { Value *ParentPad = nullptr; - if (ParseToken(lltok::kw_within, "expected 'within' after cleanuppad")) + if (parseToken(lltok::kw_within, "expected 'within' after cleanuppad")) return true; if (Lex.getKind() != lltok::kw_none && Lex.getKind() != lltok::LocalVar && Lex.getKind() != lltok::LocalVarID) - return TokError("expected scope value for cleanuppad"); + return tokError("expected scope value for cleanuppad"); - if (ParseValue(Type::getTokenTy(Context), ParentPad, PFS)) + if (parseValue(Type::getTokenTy(Context), ParentPad, PFS)) return true; SmallVector Args; - if (ParseExceptionArgs(Args, PFS)) + if (parseExceptionArgs(Args, PFS)) return true; Inst = CleanupPadInst::Create(ParentPad, Args); @@ -6517,32 +6554,32 @@ // Unary Operators. //===----------------------------------------------------------------------===// -/// ParseUnaryOp +/// parseUnaryOp /// ::= UnaryOp TypeAndValue ',' Value /// /// If IsFP is false, then any integer operand is allowed, if it is true, any fp /// operand is allowed. -bool LLParser::ParseUnaryOp(Instruction *&Inst, PerFunctionState &PFS, +bool LLParser::parseUnaryOp(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc, bool IsFP) { LocTy Loc; Value *LHS; - if (ParseTypeAndValue(LHS, Loc, PFS)) + if (parseTypeAndValue(LHS, Loc, PFS)) return true; bool Valid = IsFP ? LHS->getType()->isFPOrFPVectorTy() : LHS->getType()->isIntOrIntVectorTy(); if (!Valid) - return Error(Loc, "invalid operand type for instruction"); + return error(Loc, "invalid operand type for instruction"); Inst = UnaryOperator::Create((Instruction::UnaryOps)Opc, LHS); return false; } -/// ParseCallBr +/// parseCallBr /// ::= 'callbr' OptionalCallingConv OptionalAttrs Type Value ParamList /// OptionalAttrs OptionalOperandBundles 'to' TypeAndValue /// '[' LabelList ']' -bool LLParser::ParseCallBr(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseCallBr(Instruction *&Inst, PerFunctionState &PFS) { LocTy CallLoc = Lex.getLoc(); AttrBuilder RetAttrs, FnAttrs; std::vector FwdRefAttrGrps; @@ -6555,34 +6592,34 @@ SmallVector BundleList; BasicBlock *DefaultDest; - if (ParseOptionalCallingConv(CC) || ParseOptionalReturnAttrs(RetAttrs) || - ParseType(RetType, RetTypeLoc, true /*void allowed*/) || - ParseValID(CalleeID) || ParseParameterList(ArgList, PFS) || - ParseFnAttributeValuePairs(FnAttrs, FwdRefAttrGrps, false, + if (parseOptionalCallingConv(CC) || parseOptionalReturnAttrs(RetAttrs) || + parseType(RetType, RetTypeLoc, true /*void allowed*/) || + parseValID(CalleeID) || parseParameterList(ArgList, PFS) || + parseFnAttributeValuePairs(FnAttrs, FwdRefAttrGrps, false, NoBuiltinLoc) || - ParseOptionalOperandBundles(BundleList, PFS) || - ParseToken(lltok::kw_to, "expected 'to' in callbr") || - ParseTypeAndBasicBlock(DefaultDest, PFS) || - ParseToken(lltok::lsquare, "expected '[' in callbr")) + parseOptionalOperandBundles(BundleList, PFS) || + parseToken(lltok::kw_to, "expected 'to' in callbr") || + parseTypeAndBasicBlock(DefaultDest, PFS) || + parseToken(lltok::lsquare, "expected '[' in callbr")) return true; - // Parse the destination list. + // parse the destination list. SmallVector IndirectDests; if (Lex.getKind() != lltok::rsquare) { BasicBlock *DestBB; - if (ParseTypeAndBasicBlock(DestBB, PFS)) + if (parseTypeAndBasicBlock(DestBB, PFS)) return true; IndirectDests.push_back(DestBB); while (EatIfPresent(lltok::comma)) { - if (ParseTypeAndBasicBlock(DestBB, PFS)) + if (parseTypeAndBasicBlock(DestBB, PFS)) return true; IndirectDests.push_back(DestBB); } } - if (ParseToken(lltok::rsquare, "expected ']' at end of block list")) + if (parseToken(lltok::rsquare, "expected ']' at end of block list")) return true; // If RetType is a non-function pointer type, then this is the short syntax @@ -6596,7 +6633,7 @@ ParamTypes.push_back(ArgList[i].V->getType()); if (!FunctionType::isValidReturnType(RetType)) - return Error(RetTypeLoc, "Invalid result type for LLVM function"); + return error(RetTypeLoc, "Invalid result type for LLVM function"); Ty = FunctionType::get(RetType, ParamTypes, false); } @@ -6605,7 +6642,7 @@ // Look up the callee. Value *Callee; - if (ConvertValIDToValue(PointerType::getUnqual(Ty), CalleeID, Callee, &PFS, + if (convertValIDToValue(PointerType::getUnqual(Ty), CalleeID, Callee, &PFS, /*IsCall=*/true)) return true; @@ -6622,21 +6659,21 @@ if (I != E) { ExpectedTy = *I++; } else if (!Ty->isVarArg()) { - return Error(ArgList[i].Loc, "too many arguments specified"); + return error(ArgList[i].Loc, "too many arguments specified"); } if (ExpectedTy && ExpectedTy != ArgList[i].V->getType()) - return Error(ArgList[i].Loc, "argument is not of expected type '" + + return error(ArgList[i].Loc, "argument is not of expected type '" + getTypeString(ExpectedTy) + "'"); Args.push_back(ArgList[i].V); ArgAttrs.push_back(ArgList[i].Attrs); } if (I != E) - return Error(CallLoc, "not enough parameters specified for call"); + return error(CallLoc, "not enough parameters specified for call"); if (FnAttrs.hasAlignmentAttr()) - return Error(CallLoc, "callbr instructions may not have an alignment"); + return error(CallLoc, "callbr instructions may not have an alignment"); // Finish off the Attribute and check them AttributeList PAL = @@ -6657,70 +6694,70 @@ // Binary Operators. //===----------------------------------------------------------------------===// -/// ParseArithmetic +/// parseArithmetic /// ::= ArithmeticOps TypeAndValue ',' Value /// /// If IsFP is false, then any integer operand is allowed, if it is true, any fp /// operand is allowed. -bool LLParser::ParseArithmetic(Instruction *&Inst, PerFunctionState &PFS, +bool LLParser::parseArithmetic(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc, bool IsFP) { LocTy Loc; Value *LHS, *RHS; - if (ParseTypeAndValue(LHS, Loc, PFS) || - ParseToken(lltok::comma, "expected ',' in arithmetic operation") || - ParseValue(LHS->getType(), RHS, PFS)) + if (parseTypeAndValue(LHS, Loc, PFS) || + parseToken(lltok::comma, "expected ',' in arithmetic operation") || + parseValue(LHS->getType(), RHS, PFS)) return true; bool Valid = IsFP ? LHS->getType()->isFPOrFPVectorTy() : LHS->getType()->isIntOrIntVectorTy(); if (!Valid) - return Error(Loc, "invalid operand type for instruction"); + return error(Loc, "invalid operand type for instruction"); Inst = BinaryOperator::Create((Instruction::BinaryOps)Opc, LHS, RHS); return false; } -/// ParseLogical +/// parseLogical /// ::= ArithmeticOps TypeAndValue ',' Value { -bool LLParser::ParseLogical(Instruction *&Inst, PerFunctionState &PFS, +bool LLParser::parseLogical(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc) { LocTy Loc; Value *LHS, *RHS; - if (ParseTypeAndValue(LHS, Loc, PFS) || - ParseToken(lltok::comma, "expected ',' in logical operation") || - ParseValue(LHS->getType(), RHS, PFS)) + if (parseTypeAndValue(LHS, Loc, PFS) || + parseToken(lltok::comma, "expected ',' in logical operation") || + parseValue(LHS->getType(), RHS, PFS)) return true; if (!LHS->getType()->isIntOrIntVectorTy()) - return Error(Loc,"instruction requires integer or integer vector operands"); + return error(Loc,"instruction requires integer or integer vector operands"); Inst = BinaryOperator::Create((Instruction::BinaryOps)Opc, LHS, RHS); return false; } -/// ParseCompare +/// parseCompare /// ::= 'icmp' IPredicates TypeAndValue ',' Value /// ::= 'fcmp' FPredicates TypeAndValue ',' Value -bool LLParser::ParseCompare(Instruction *&Inst, PerFunctionState &PFS, +bool LLParser::parseCompare(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc) { - // Parse the integer/fp comparison predicate. + // parse the integer/fp comparison predicate. LocTy Loc; unsigned Pred; Value *LHS, *RHS; - if (ParseCmpPredicate(Pred, Opc) || - ParseTypeAndValue(LHS, Loc, PFS) || - ParseToken(lltok::comma, "expected ',' after compare value") || - ParseValue(LHS->getType(), RHS, PFS)) + if (parseCmpPredicate(Pred, Opc) || + parseTypeAndValue(LHS, Loc, PFS) || + parseToken(lltok::comma, "expected ',' after compare value") || + parseValue(LHS->getType(), RHS, PFS)) return true; if (Opc == Instruction::FCmp) { if (!LHS->getType()->isFPOrFPVectorTy()) - return Error(Loc, "fcmp requires floating point operands"); + return error(Loc, "fcmp requires floating point operands"); Inst = new FCmpInst(CmpInst::Predicate(Pred), LHS, RHS); } else { assert(Opc == Instruction::ICmp && "Unknown opcode for CmpInst!"); if (!LHS->getType()->isIntOrIntVectorTy() && !LHS->getType()->isPtrOrPtrVectorTy()) - return Error(Loc, "icmp requires integer operands"); + return error(Loc, "icmp requires integer operands"); Inst = new ICmpInst(CmpInst::Predicate(Pred), LHS, RHS); } return false; @@ -6731,21 +6768,21 @@ //===----------------------------------------------------------------------===// -/// ParseCast +/// parseCast /// ::= CastOpc TypeAndValue 'to' Type -bool LLParser::ParseCast(Instruction *&Inst, PerFunctionState &PFS, +bool LLParser::parseCast(Instruction *&Inst, PerFunctionState &PFS, unsigned Opc) { LocTy Loc; Value *Op; Type *DestTy = nullptr; - if (ParseTypeAndValue(Op, Loc, PFS) || - ParseToken(lltok::kw_to, "expected 'to' after cast value") || - ParseType(DestTy)) + if (parseTypeAndValue(Op, Loc, PFS) || + parseToken(lltok::kw_to, "expected 'to' after cast value") || + parseType(DestTy)) return true; if (!CastInst::castIsValid((Instruction::CastOps)Opc, Op, DestTy)) { CastInst::castIsValid((Instruction::CastOps)Opc, Op, DestTy); - return Error(Loc, "invalid cast opcode for cast from '" + + return error(Loc, "invalid cast opcode for cast from '" + getTypeString(Op->getType()) + "' to '" + getTypeString(DestTy) + "'"); } @@ -6753,110 +6790,110 @@ return false; } -/// ParseSelect +/// parseSelect /// ::= 'select' TypeAndValue ',' TypeAndValue ',' TypeAndValue -bool LLParser::ParseSelect(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseSelect(Instruction *&Inst, PerFunctionState &PFS) { LocTy Loc; Value *Op0, *Op1, *Op2; - if (ParseTypeAndValue(Op0, Loc, PFS) || - ParseToken(lltok::comma, "expected ',' after select condition") || - ParseTypeAndValue(Op1, PFS) || - ParseToken(lltok::comma, "expected ',' after select value") || - ParseTypeAndValue(Op2, PFS)) + if (parseTypeAndValue(Op0, Loc, PFS) || + parseToken(lltok::comma, "expected ',' after select condition") || + parseTypeAndValue(Op1, PFS) || + parseToken(lltok::comma, "expected ',' after select value") || + parseTypeAndValue(Op2, PFS)) return true; if (const char *Reason = SelectInst::areInvalidOperands(Op0, Op1, Op2)) - return Error(Loc, Reason); + return error(Loc, Reason); Inst = SelectInst::Create(Op0, Op1, Op2); return false; } -/// ParseVA_Arg +/// parseVA_Arg /// ::= 'va_arg' TypeAndValue ',' Type -bool LLParser::ParseVA_Arg(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseVA_Arg(Instruction *&Inst, PerFunctionState &PFS) { Value *Op; Type *EltTy = nullptr; LocTy TypeLoc; - if (ParseTypeAndValue(Op, PFS) || - ParseToken(lltok::comma, "expected ',' after vaarg operand") || - ParseType(EltTy, TypeLoc)) + if (parseTypeAndValue(Op, PFS) || + parseToken(lltok::comma, "expected ',' after vaarg operand") || + parseType(EltTy, TypeLoc)) return true; if (!EltTy->isFirstClassType()) - return Error(TypeLoc, "va_arg requires operand with first class type"); + return error(TypeLoc, "va_arg requires operand with first class type"); Inst = new VAArgInst(Op, EltTy); return false; } -/// ParseExtractElement +/// parseExtractElement /// ::= 'extractelement' TypeAndValue ',' TypeAndValue -bool LLParser::ParseExtractElement(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseExtractElement(Instruction *&Inst, PerFunctionState &PFS) { LocTy Loc; Value *Op0, *Op1; - if (ParseTypeAndValue(Op0, Loc, PFS) || - ParseToken(lltok::comma, "expected ',' after extract value") || - ParseTypeAndValue(Op1, PFS)) + if (parseTypeAndValue(Op0, Loc, PFS) || + parseToken(lltok::comma, "expected ',' after extract value") || + parseTypeAndValue(Op1, PFS)) return true; if (!ExtractElementInst::isValidOperands(Op0, Op1)) - return Error(Loc, "invalid extractelement operands"); + return error(Loc, "invalid extractelement operands"); Inst = ExtractElementInst::Create(Op0, Op1); return false; } -/// ParseInsertElement +/// parseInsertElement /// ::= 'insertelement' TypeAndValue ',' TypeAndValue ',' TypeAndValue -bool LLParser::ParseInsertElement(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseInsertElement(Instruction *&Inst, PerFunctionState &PFS) { LocTy Loc; Value *Op0, *Op1, *Op2; - if (ParseTypeAndValue(Op0, Loc, PFS) || - ParseToken(lltok::comma, "expected ',' after insertelement value") || - ParseTypeAndValue(Op1, PFS) || - ParseToken(lltok::comma, "expected ',' after insertelement value") || - ParseTypeAndValue(Op2, PFS)) + if (parseTypeAndValue(Op0, Loc, PFS) || + parseToken(lltok::comma, "expected ',' after insertelement value") || + parseTypeAndValue(Op1, PFS) || + parseToken(lltok::comma, "expected ',' after insertelement value") || + parseTypeAndValue(Op2, PFS)) return true; if (!InsertElementInst::isValidOperands(Op0, Op1, Op2)) - return Error(Loc, "invalid insertelement operands"); + return error(Loc, "invalid insertelement operands"); Inst = InsertElementInst::Create(Op0, Op1, Op2); return false; } -/// ParseShuffleVector +/// parseShuffleVector /// ::= 'shufflevector' TypeAndValue ',' TypeAndValue ',' TypeAndValue -bool LLParser::ParseShuffleVector(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseShuffleVector(Instruction *&Inst, PerFunctionState &PFS) { LocTy Loc; Value *Op0, *Op1, *Op2; - if (ParseTypeAndValue(Op0, Loc, PFS) || - ParseToken(lltok::comma, "expected ',' after shuffle mask") || - ParseTypeAndValue(Op1, PFS) || - ParseToken(lltok::comma, "expected ',' after shuffle value") || - ParseTypeAndValue(Op2, PFS)) + if (parseTypeAndValue(Op0, Loc, PFS) || + parseToken(lltok::comma, "expected ',' after shuffle mask") || + parseTypeAndValue(Op1, PFS) || + parseToken(lltok::comma, "expected ',' after shuffle value") || + parseTypeAndValue(Op2, PFS)) return true; if (!ShuffleVectorInst::isValidOperands(Op0, Op1, Op2)) - return Error(Loc, "invalid shufflevector operands"); + return error(Loc, "invalid shufflevector operands"); Inst = new ShuffleVectorInst(Op0, Op1, Op2); return false; } -/// ParsePHI +/// parsePHI /// ::= 'phi' Type '[' Value ',' Value ']' (',' '[' Value ',' Value ']')* -int LLParser::ParsePHI(Instruction *&Inst, PerFunctionState &PFS) { +int LLParser::parsePHI(Instruction *&Inst, PerFunctionState &PFS) { Type *Ty = nullptr; LocTy TypeLoc; Value *Op0, *Op1; - if (ParseType(Ty, TypeLoc) || - ParseToken(lltok::lsquare, "expected '[' in phi value list") || - ParseValue(Ty, Op0, PFS) || - ParseToken(lltok::comma, "expected ',' after insertelement value") || - ParseValue(Type::getLabelTy(Context), Op1, PFS) || - ParseToken(lltok::rsquare, "expected ']' in phi value list")) + if (parseType(Ty, TypeLoc) || + parseToken(lltok::lsquare, "expected '[' in phi value list") || + parseValue(Ty, Op0, PFS) || + parseToken(lltok::comma, "expected ',' after insertelement value") || + parseValue(Type::getLabelTy(Context), Op1, PFS) || + parseToken(lltok::rsquare, "expected ']' in phi value list")) return true; bool AteExtraComma = false; @@ -6873,16 +6910,16 @@ break; } - if (ParseToken(lltok::lsquare, "expected '[' in phi value list") || - ParseValue(Ty, Op0, PFS) || - ParseToken(lltok::comma, "expected ',' after insertelement value") || - ParseValue(Type::getLabelTy(Context), Op1, PFS) || - ParseToken(lltok::rsquare, "expected ']' in phi value list")) + if (parseToken(lltok::lsquare, "expected '[' in phi value list") || + parseValue(Ty, Op0, PFS) || + parseToken(lltok::comma, "expected ',' after insertelement value") || + parseValue(Type::getLabelTy(Context), Op1, PFS) || + parseToken(lltok::rsquare, "expected ']' in phi value list")) return true; } if (!Ty->isFirstClassType()) - return Error(TypeLoc, "phi node must have first class type"); + return error(TypeLoc, "phi node must have first class type"); PHINode *PN = PHINode::Create(Ty, PHIVals.size()); for (unsigned i = 0, e = PHIVals.size(); i != e; ++i) @@ -6891,16 +6928,16 @@ return AteExtraComma ? InstExtraComma : InstNormal; } -/// ParseLandingPad +/// parseLandingPad /// ::= 'landingpad' Type 'personality' TypeAndValue 'cleanup'? Clause+ /// Clause /// ::= 'catch' TypeAndValue /// ::= 'filter' /// ::= 'filter' TypeAndValue ( ',' TypeAndValue )* -bool LLParser::ParseLandingPad(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseLandingPad(Instruction *&Inst, PerFunctionState &PFS) { Type *Ty = nullptr; LocTy TyLoc; - if (ParseType(Ty, TyLoc)) + if (parseType(Ty, TyLoc)) return true; std::unique_ptr LP(LandingPadInst::Create(Ty, 0)); @@ -6913,26 +6950,26 @@ else if (EatIfPresent(lltok::kw_filter)) CT = LandingPadInst::Filter; else - return TokError("expected 'catch' or 'filter' clause type"); + return tokError("expected 'catch' or 'filter' clause type"); Value *V; LocTy VLoc; - if (ParseTypeAndValue(V, VLoc, PFS)) + if (parseTypeAndValue(V, VLoc, PFS)) return true; // A 'catch' type expects a non-array constant. A filter clause expects an // array constant. if (CT == LandingPadInst::Catch) { if (isa(V->getType())) - Error(VLoc, "'catch' clause has an invalid type"); + error(VLoc, "'catch' clause has an invalid type"); } else { if (!isa(V->getType())) - Error(VLoc, "'filter' clause has an invalid type"); + error(VLoc, "'filter' clause has an invalid type"); } Constant *CV = dyn_cast(V); if (!CV) - return Error(VLoc, "clause argument must be a constant"); + return error(VLoc, "clause argument must be a constant"); LP->addClause(CV); } @@ -6940,19 +6977,19 @@ return false; } -/// ParseFreeze +/// parseFreeze /// ::= 'freeze' Type Value -bool LLParser::ParseFreeze(Instruction *&Inst, PerFunctionState &PFS) { +bool LLParser::parseFreeze(Instruction *&Inst, PerFunctionState &PFS) { LocTy Loc; Value *Op; - if (ParseTypeAndValue(Op, Loc, PFS)) + if (parseTypeAndValue(Op, Loc, PFS)) return true; Inst = new FreezeInst(Op); return false; } -/// ParseCall +/// parseCall /// ::= 'call' OptionalFastMathFlags OptionalCallingConv /// OptionalAttrs Type Value ParameterList OptionalAttrs /// ::= 'tail' 'call' OptionalFastMathFlags OptionalCallingConv @@ -6961,7 +6998,7 @@ /// OptionalAttrs Type Value ParameterList OptionalAttrs /// ::= 'notail' 'call' OptionalFastMathFlags OptionalCallingConv /// OptionalAttrs Type Value ParameterList OptionalAttrs -bool LLParser::ParseCall(Instruction *&Inst, PerFunctionState &PFS, +bool LLParser::parseCall(Instruction *&Inst, PerFunctionState &PFS, CallInst::TailCallKind TCK) { AttrBuilder RetAttrs, FnAttrs; std::vector FwdRefAttrGrps; @@ -6976,20 +7013,20 @@ LocTy CallLoc = Lex.getLoc(); if (TCK != CallInst::TCK_None && - ParseToken(lltok::kw_call, + parseToken(lltok::kw_call, "expected 'tail call', 'musttail call', or 'notail call'")) return true; FastMathFlags FMF = EatFastMathFlagsIfPresent(); - if (ParseOptionalCallingConv(CC) || ParseOptionalReturnAttrs(RetAttrs) || - ParseOptionalProgramAddrSpace(CallAddrSpace) || - ParseType(RetType, RetTypeLoc, true /*void allowed*/) || - ParseValID(CalleeID) || - ParseParameterList(ArgList, PFS, TCK == CallInst::TCK_MustTail, + if (parseOptionalCallingConv(CC) || parseOptionalReturnAttrs(RetAttrs) || + parseOptionalProgramAddrSpace(CallAddrSpace) || + parseType(RetType, RetTypeLoc, true /*void allowed*/) || + parseValID(CalleeID) || + parseParameterList(ArgList, PFS, TCK == CallInst::TCK_MustTail, PFS.getFunction().isVarArg()) || - ParseFnAttributeValuePairs(FnAttrs, FwdRefAttrGrps, false, BuiltinLoc) || - ParseOptionalOperandBundles(BundleList, PFS)) + parseFnAttributeValuePairs(FnAttrs, FwdRefAttrGrps, false, BuiltinLoc) || + parseOptionalOperandBundles(BundleList, PFS)) return true; // If RetType is a non-function pointer type, then this is the short syntax @@ -7003,7 +7040,7 @@ ParamTypes.push_back(ArgList[i].V->getType()); if (!FunctionType::isValidReturnType(RetType)) - return Error(RetTypeLoc, "Invalid result type for LLVM function"); + return error(RetTypeLoc, "Invalid result type for LLVM function"); Ty = FunctionType::get(RetType, ParamTypes, false); } @@ -7012,7 +7049,7 @@ // Look up the callee. Value *Callee; - if (ConvertValIDToValue(PointerType::get(Ty, CallAddrSpace), CalleeID, Callee, + if (convertValIDToValue(PointerType::get(Ty, CallAddrSpace), CalleeID, Callee, &PFS, /*IsCall=*/true)) return true; @@ -7030,21 +7067,21 @@ if (I != E) { ExpectedTy = *I++; } else if (!Ty->isVarArg()) { - return Error(ArgList[i].Loc, "too many arguments specified"); + return error(ArgList[i].Loc, "too many arguments specified"); } if (ExpectedTy && ExpectedTy != ArgList[i].V->getType()) - return Error(ArgList[i].Loc, "argument is not of expected type '" + + return error(ArgList[i].Loc, "argument is not of expected type '" + getTypeString(ExpectedTy) + "'"); Args.push_back(ArgList[i].V); Attrs.push_back(ArgList[i].Attrs); } if (I != E) - return Error(CallLoc, "not enough parameters specified for call"); + return error(CallLoc, "not enough parameters specified for call"); if (FnAttrs.hasAlignmentAttr()) - return Error(CallLoc, "call instructions may not have an alignment"); + return error(CallLoc, "call instructions may not have an alignment"); // Finish off the Attribute and check them AttributeList PAL = @@ -7057,7 +7094,7 @@ if (FMF.any()) { if (!isa(CI)) { CI->deleteValue(); - return Error(CallLoc, "fast-math-flags specified for call without " + return error(CallLoc, "fast-math-flags specified for call without " "floating-point scalar or vector return type"); } CI->setFastMathFlags(FMF); @@ -7072,10 +7109,10 @@ // Memory Instructions. //===----------------------------------------------------------------------===// -/// ParseAlloc +/// parseAlloc /// ::= 'alloca' 'inalloca'? 'swifterror'? Type (',' TypeAndValue)? /// (',' 'align' i32)? (',', 'addrspace(n))? -int LLParser::ParseAlloc(Instruction *&Inst, PerFunctionState &PFS) { +int LLParser::parseAlloc(Instruction *&Inst, PerFunctionState &PFS) { Value *Size = nullptr; LocTy SizeLoc, TyLoc, ASLoc; MaybeAlign Alignment; @@ -7085,36 +7122,36 @@ bool IsInAlloca = EatIfPresent(lltok::kw_inalloca); bool IsSwiftError = EatIfPresent(lltok::kw_swifterror); - if (ParseType(Ty, TyLoc)) return true; + if (parseType(Ty, TyLoc)) return true; if (Ty->isFunctionTy() || !PointerType::isValidElementType(Ty)) - return Error(TyLoc, "invalid type for alloca"); + return error(TyLoc, "invalid type for alloca"); bool AteExtraComma = false; if (EatIfPresent(lltok::comma)) { if (Lex.getKind() == lltok::kw_align) { - if (ParseOptionalAlignment(Alignment)) + if (parseOptionalAlignment(Alignment)) return true; - if (ParseOptionalCommaAddrSpace(AddrSpace, ASLoc, AteExtraComma)) + if (parseOptionalCommaAddrSpace(AddrSpace, ASLoc, AteExtraComma)) return true; } else if (Lex.getKind() == lltok::kw_addrspace) { ASLoc = Lex.getLoc(); - if (ParseOptionalAddrSpace(AddrSpace)) + if (parseOptionalAddrSpace(AddrSpace)) return true; } else if (Lex.getKind() == lltok::MetadataVar) { AteExtraComma = true; } else { - if (ParseTypeAndValue(Size, SizeLoc, PFS)) + if (parseTypeAndValue(Size, SizeLoc, PFS)) return true; if (EatIfPresent(lltok::comma)) { if (Lex.getKind() == lltok::kw_align) { - if (ParseOptionalAlignment(Alignment)) + if (parseOptionalAlignment(Alignment)) return true; - if (ParseOptionalCommaAddrSpace(AddrSpace, ASLoc, AteExtraComma)) + if (parseOptionalCommaAddrSpace(AddrSpace, ASLoc, AteExtraComma)) return true; } else if (Lex.getKind() == lltok::kw_addrspace) { ASLoc = Lex.getLoc(); - if (ParseOptionalAddrSpace(AddrSpace)) + if (parseOptionalAddrSpace(AddrSpace)) return true; } else if (Lex.getKind() == lltok::MetadataVar) { AteExtraComma = true; @@ -7124,11 +7161,11 @@ } if (Size && !Size->getType()->isIntegerTy()) - return Error(SizeLoc, "element count must have integer type"); + return error(SizeLoc, "element count must have integer type"); SmallPtrSet Visited; if (!Alignment && !Ty->isSized(&Visited)) - return Error(TyLoc, "Cannot allocate unsized type"); + return error(TyLoc, "Cannot allocate unsized type"); if (!Alignment) Alignment = M->getDataLayout().getPrefTypeAlign(Ty); AllocaInst *AI = new AllocaInst(Ty, AddrSpace, Size, *Alignment); @@ -7138,11 +7175,11 @@ return AteExtraComma ? InstExtraComma : InstNormal; } -/// ParseLoad +/// parseLoad /// ::= 'load' 'volatile'? TypeAndValue (',' 'align' i32)? /// ::= 'load' 'atomic' 'volatile'? TypeAndValue /// 'singlethread'? AtomicOrdering (',' 'align' i32)? -int LLParser::ParseLoad(Instruction *&Inst, PerFunctionState &PFS) { +int LLParser::parseLoad(Instruction *&Inst, PerFunctionState &PFS) { Value *Val; LocTy Loc; MaybeAlign Alignment; bool AteExtraComma = false; @@ -7163,39 +7200,39 @@ Type *Ty; LocTy ExplicitTypeLoc = Lex.getLoc(); - if (ParseType(Ty) || - ParseToken(lltok::comma, "expected comma after load's type") || - ParseTypeAndValue(Val, Loc, PFS) || - ParseScopeAndOrdering(isAtomic, SSID, Ordering) || - ParseOptionalCommaAlign(Alignment, AteExtraComma)) + if (parseType(Ty) || + parseToken(lltok::comma, "expected comma after load's type") || + parseTypeAndValue(Val, Loc, PFS) || + parseScopeAndOrdering(isAtomic, SSID, Ordering) || + parseOptionalCommaAlign(Alignment, AteExtraComma)) return true; if (!Val->getType()->isPointerTy() || !Ty->isFirstClassType()) - return Error(Loc, "load operand must be a pointer to a first class type"); + return error(Loc, "load operand must be a pointer to a first class type"); if (isAtomic && !Alignment) - return Error(Loc, "atomic load must have explicit non-zero alignment"); + return error(Loc, "atomic load must have explicit non-zero alignment"); if (Ordering == AtomicOrdering::Release || Ordering == AtomicOrdering::AcquireRelease) - return Error(Loc, "atomic load cannot use Release ordering"); + return error(Loc, "atomic load cannot use Release ordering"); if (Ty != cast(Val->getType())->getElementType()) - return Error(ExplicitTypeLoc, + return error(ExplicitTypeLoc, "explicit pointee type doesn't match operand's pointee type"); SmallPtrSet Visited; if (!Alignment && !Ty->isSized(&Visited)) - return Error(ExplicitTypeLoc, "loading unsized types is not allowed"); + return error(ExplicitTypeLoc, "loading unsized types is not allowed"); if (!Alignment) Alignment = M->getDataLayout().getABITypeAlign(Ty); Inst = new LoadInst(Ty, Val, "", isVolatile, *Alignment, Ordering, SSID); return AteExtraComma ? InstExtraComma : InstNormal; } -/// ParseStore +/// parseStore /// ::= 'store' 'volatile'? TypeAndValue ',' TypeAndValue (',' 'align' i32)? /// ::= 'store' 'atomic' 'volatile'? TypeAndValue ',' TypeAndValue /// 'singlethread'? AtomicOrdering (',' 'align' i32)? -int LLParser::ParseStore(Instruction *&Inst, PerFunctionState &PFS) { +int LLParser::parseStore(Instruction *&Inst, PerFunctionState &PFS) { Value *Val, *Ptr; LocTy Loc, PtrLoc; MaybeAlign Alignment; bool AteExtraComma = false; @@ -7214,27 +7251,27 @@ Lex.Lex(); } - if (ParseTypeAndValue(Val, Loc, PFS) || - ParseToken(lltok::comma, "expected ',' after store operand") || - ParseTypeAndValue(Ptr, PtrLoc, PFS) || - ParseScopeAndOrdering(isAtomic, SSID, Ordering) || - ParseOptionalCommaAlign(Alignment, AteExtraComma)) + if (parseTypeAndValue(Val, Loc, PFS) || + parseToken(lltok::comma, "expected ',' after store operand") || + parseTypeAndValue(Ptr, PtrLoc, PFS) || + parseScopeAndOrdering(isAtomic, SSID, Ordering) || + parseOptionalCommaAlign(Alignment, AteExtraComma)) return true; if (!Ptr->getType()->isPointerTy()) - return Error(PtrLoc, "store operand must be a pointer"); + return error(PtrLoc, "store operand must be a pointer"); if (!Val->getType()->isFirstClassType()) - return Error(Loc, "store operand must be a first class value"); + return error(Loc, "store operand must be a first class value"); if (cast(Ptr->getType())->getElementType() != Val->getType()) - return Error(Loc, "stored value and pointer type do not match"); + return error(Loc, "stored value and pointer type do not match"); if (isAtomic && !Alignment) - return Error(Loc, "atomic store must have explicit non-zero alignment"); + return error(Loc, "atomic store must have explicit non-zero alignment"); if (Ordering == AtomicOrdering::Acquire || Ordering == AtomicOrdering::AcquireRelease) - return Error(Loc, "atomic store cannot use Acquire ordering"); + return error(Loc, "atomic store cannot use Acquire ordering"); SmallPtrSet Visited; if (!Alignment && !Val->getType()->isSized(&Visited)) - return Error(Loc, "storing unsized types is not allowed"); + return error(Loc, "storing unsized types is not allowed"); if (!Alignment) Alignment = M->getDataLayout().getABITypeAlign(Val->getType()); @@ -7242,10 +7279,10 @@ return AteExtraComma ? InstExtraComma : InstNormal; } -/// ParseCmpXchg +/// parseCmpXchg /// ::= 'cmpxchg' 'weak'? 'volatile'? TypeAndValue ',' TypeAndValue ',' /// TypeAndValue 'singlethread'? AtomicOrdering AtomicOrdering -int LLParser::ParseCmpXchg(Instruction *&Inst, PerFunctionState &PFS) { +int LLParser::parseCmpXchg(Instruction *&Inst, PerFunctionState &PFS) { Value *Ptr, *Cmp, *New; LocTy PtrLoc, CmpLoc, NewLoc; bool AteExtraComma = false; AtomicOrdering SuccessOrdering = AtomicOrdering::NotAtomic; @@ -7260,33 +7297,33 @@ if (EatIfPresent(lltok::kw_volatile)) isVolatile = true; - if (ParseTypeAndValue(Ptr, PtrLoc, PFS) || - ParseToken(lltok::comma, "expected ',' after cmpxchg address") || - ParseTypeAndValue(Cmp, CmpLoc, PFS) || - ParseToken(lltok::comma, "expected ',' after cmpxchg cmp operand") || - ParseTypeAndValue(New, NewLoc, PFS) || - ParseScopeAndOrdering(true /*Always atomic*/, SSID, SuccessOrdering) || - ParseOrdering(FailureOrdering)) + if (parseTypeAndValue(Ptr, PtrLoc, PFS) || + parseToken(lltok::comma, "expected ',' after cmpxchg address") || + parseTypeAndValue(Cmp, CmpLoc, PFS) || + parseToken(lltok::comma, "expected ',' after cmpxchg cmp operand") || + parseTypeAndValue(New, NewLoc, PFS) || + parseScopeAndOrdering(true /*Always atomic*/, SSID, SuccessOrdering) || + parseOrdering(FailureOrdering)) return true; if (SuccessOrdering == AtomicOrdering::Unordered || FailureOrdering == AtomicOrdering::Unordered) - return TokError("cmpxchg cannot be unordered"); + return tokError("cmpxchg cannot be unordered"); if (isStrongerThan(FailureOrdering, SuccessOrdering)) - return TokError("cmpxchg failure argument shall be no stronger than the " + return tokError("cmpxchg failure argument shall be no stronger than the " "success argument"); if (FailureOrdering == AtomicOrdering::Release || FailureOrdering == AtomicOrdering::AcquireRelease) - return TokError( + return tokError( "cmpxchg failure ordering cannot include release semantics"); if (!Ptr->getType()->isPointerTy()) - return Error(PtrLoc, "cmpxchg operand must be a pointer"); + return error(PtrLoc, "cmpxchg operand must be a pointer"); if (cast(Ptr->getType())->getElementType() != Cmp->getType()) - return Error(CmpLoc, "compare value and pointer type do not match"); + return error(CmpLoc, "compare value and pointer type do not match"); if (cast(Ptr->getType())->getElementType() != New->getType()) - return Error(NewLoc, "new value and pointer type do not match"); + return error(NewLoc, "new value and pointer type do not match"); if (!New->getType()->isFirstClassType()) - return Error(NewLoc, "cmpxchg operand must be a first class value"); + return error(NewLoc, "cmpxchg operand must be a first class value"); Align Alignment( PFS.getFunction().getParent()->getDataLayout().getTypeStoreSize( @@ -7300,10 +7337,10 @@ return AteExtraComma ? InstExtraComma : InstNormal; } -/// ParseAtomicRMW +/// parseAtomicRMW /// ::= 'atomicrmw' 'volatile'? BinOp TypeAndValue ',' TypeAndValue /// 'singlethread'? AtomicOrdering -int LLParser::ParseAtomicRMW(Instruction *&Inst, PerFunctionState &PFS) { +int LLParser::parseAtomicRMW(Instruction *&Inst, PerFunctionState &PFS) { Value *Ptr, *Val; LocTy PtrLoc, ValLoc; bool AteExtraComma = false; AtomicOrdering Ordering = AtomicOrdering::NotAtomic; @@ -7316,7 +7353,7 @@ isVolatile = true; switch (Lex.getKind()) { - default: return TokError("expected binary operation in atomicrmw"); + default: return tokError("expected binary operation in atomicrmw"); case lltok::kw_xchg: Operation = AtomicRMWInst::Xchg; break; case lltok::kw_add: Operation = AtomicRMWInst::Add; break; case lltok::kw_sub: Operation = AtomicRMWInst::Sub; break; @@ -7339,35 +7376,35 @@ } Lex.Lex(); // Eat the operation. - if (ParseTypeAndValue(Ptr, PtrLoc, PFS) || - ParseToken(lltok::comma, "expected ',' after atomicrmw address") || - ParseTypeAndValue(Val, ValLoc, PFS) || - ParseScopeAndOrdering(true /*Always atomic*/, SSID, Ordering)) + if (parseTypeAndValue(Ptr, PtrLoc, PFS) || + parseToken(lltok::comma, "expected ',' after atomicrmw address") || + parseTypeAndValue(Val, ValLoc, PFS) || + parseScopeAndOrdering(true /*Always atomic*/, SSID, Ordering)) return true; if (Ordering == AtomicOrdering::Unordered) - return TokError("atomicrmw cannot be unordered"); + return tokError("atomicrmw cannot be unordered"); if (!Ptr->getType()->isPointerTy()) - return Error(PtrLoc, "atomicrmw operand must be a pointer"); + return error(PtrLoc, "atomicrmw operand must be a pointer"); if (cast(Ptr->getType())->getElementType() != Val->getType()) - return Error(ValLoc, "atomicrmw value and pointer type do not match"); + return error(ValLoc, "atomicrmw value and pointer type do not match"); if (Operation == AtomicRMWInst::Xchg) { if (!Val->getType()->isIntegerTy() && !Val->getType()->isFloatingPointTy()) { - return Error(ValLoc, "atomicrmw " + + return error(ValLoc, "atomicrmw " + AtomicRMWInst::getOperationName(Operation) + " operand must be an integer or floating point type"); } } else if (IsFP) { if (!Val->getType()->isFloatingPointTy()) { - return Error(ValLoc, "atomicrmw " + + return error(ValLoc, "atomicrmw " + AtomicRMWInst::getOperationName(Operation) + " operand must be a floating point type"); } } else { if (!Val->getType()->isIntegerTy()) { - return Error(ValLoc, "atomicrmw " + + return error(ValLoc, "atomicrmw " + AtomicRMWInst::getOperationName(Operation) + " operand must be an integer"); } @@ -7375,7 +7412,7 @@ unsigned Size = Val->getType()->getPrimitiveSizeInBits(); if (Size < 8 || (Size & (Size - 1))) - return Error(ValLoc, "atomicrmw operand must be power-of-two byte-sized" + return error(ValLoc, "atomicrmw operand must be power-of-two byte-sized" " integer"); Align Alignment( PFS.getFunction().getParent()->getDataLayout().getTypeStoreSize( @@ -7387,26 +7424,26 @@ return AteExtraComma ? InstExtraComma : InstNormal; } -/// ParseFence +/// parseFence /// ::= 'fence' 'singlethread'? AtomicOrdering -int LLParser::ParseFence(Instruction *&Inst, PerFunctionState &PFS) { +int LLParser::parseFence(Instruction *&Inst, PerFunctionState &PFS) { AtomicOrdering Ordering = AtomicOrdering::NotAtomic; SyncScope::ID SSID = SyncScope::System; - if (ParseScopeAndOrdering(true /*Always atomic*/, SSID, Ordering)) + if (parseScopeAndOrdering(true /*Always atomic*/, SSID, Ordering)) return true; if (Ordering == AtomicOrdering::Unordered) - return TokError("fence cannot be unordered"); + return tokError("fence cannot be unordered"); if (Ordering == AtomicOrdering::Monotonic) - return TokError("fence cannot be monotonic"); + return tokError("fence cannot be monotonic"); Inst = new FenceInst(Context, Ordering, SSID); return InstNormal; } -/// ParseGetElementPtr +/// parseGetElementPtr /// ::= 'getelementptr' 'inbounds'? TypeAndValue (',' TypeAndValue)* -int LLParser::ParseGetElementPtr(Instruction *&Inst, PerFunctionState &PFS) { +int LLParser::parseGetElementPtr(Instruction *&Inst, PerFunctionState &PFS) { Value *Ptr = nullptr; Value *Val = nullptr; LocTy Loc, EltLoc; @@ -7415,18 +7452,18 @@ Type *Ty = nullptr; LocTy ExplicitTypeLoc = Lex.getLoc(); - if (ParseType(Ty) || - ParseToken(lltok::comma, "expected comma after getelementptr's type") || - ParseTypeAndValue(Ptr, Loc, PFS)) + if (parseType(Ty) || + parseToken(lltok::comma, "expected comma after getelementptr's type") || + parseTypeAndValue(Ptr, Loc, PFS)) return true; Type *BaseType = Ptr->getType(); PointerType *BasePointerType = dyn_cast(BaseType->getScalarType()); if (!BasePointerType) - return Error(Loc, "base of getelementptr must be a pointer"); + return error(Loc, "base of getelementptr must be a pointer"); if (Ty != BasePointerType->getElementType()) - return Error(ExplicitTypeLoc, + return error(ExplicitTypeLoc, "explicit pointee type doesn't match operand's pointee type"); SmallVector Indices; @@ -7442,14 +7479,14 @@ AteExtraComma = true; break; } - if (ParseTypeAndValue(Val, EltLoc, PFS)) return true; + if (parseTypeAndValue(Val, EltLoc, PFS)) return true; if (!Val->getType()->isIntOrIntVectorTy()) - return Error(EltLoc, "getelementptr index must be an integer"); + return error(EltLoc, "getelementptr index must be an integer"); if (auto *ValVTy = dyn_cast(Val->getType())) { ElementCount ValNumEl = ValVTy->getElementCount(); if (GEPWidth != ElementCount::getFixed(0) && GEPWidth != ValNumEl) - return Error(EltLoc, + return error(EltLoc, "getelementptr vector index has a wrong number of elements"); GEPWidth = ValNumEl; } @@ -7458,55 +7495,55 @@ SmallPtrSet Visited; if (!Indices.empty() && !Ty->isSized(&Visited)) - return Error(Loc, "base element of getelementptr must be sized"); + return error(Loc, "base element of getelementptr must be sized"); if (!GetElementPtrInst::getIndexedType(Ty, Indices)) - return Error(Loc, "invalid getelementptr indices"); + return error(Loc, "invalid getelementptr indices"); Inst = GetElementPtrInst::Create(Ty, Ptr, Indices); if (InBounds) cast(Inst)->setIsInBounds(true); return AteExtraComma ? InstExtraComma : InstNormal; } -/// ParseExtractValue +/// parseExtractValue /// ::= 'extractvalue' TypeAndValue (',' uint32)+ -int LLParser::ParseExtractValue(Instruction *&Inst, PerFunctionState &PFS) { +int LLParser::parseExtractValue(Instruction *&Inst, PerFunctionState &PFS) { Value *Val; LocTy Loc; SmallVector Indices; bool AteExtraComma; - if (ParseTypeAndValue(Val, Loc, PFS) || - ParseIndexList(Indices, AteExtraComma)) + if (parseTypeAndValue(Val, Loc, PFS) || + parseIndexList(Indices, AteExtraComma)) return true; if (!Val->getType()->isAggregateType()) - return Error(Loc, "extractvalue operand must be aggregate type"); + return error(Loc, "extractvalue operand must be aggregate type"); if (!ExtractValueInst::getIndexedType(Val->getType(), Indices)) - return Error(Loc, "invalid indices for extractvalue"); + return error(Loc, "invalid indices for extractvalue"); Inst = ExtractValueInst::Create(Val, Indices); return AteExtraComma ? InstExtraComma : InstNormal; } -/// ParseInsertValue +/// parseInsertValue /// ::= 'insertvalue' TypeAndValue ',' TypeAndValue (',' uint32)+ -int LLParser::ParseInsertValue(Instruction *&Inst, PerFunctionState &PFS) { +int LLParser::parseInsertValue(Instruction *&Inst, PerFunctionState &PFS) { Value *Val0, *Val1; LocTy Loc0, Loc1; SmallVector Indices; bool AteExtraComma; - if (ParseTypeAndValue(Val0, Loc0, PFS) || - ParseToken(lltok::comma, "expected comma after insertvalue operand") || - ParseTypeAndValue(Val1, Loc1, PFS) || - ParseIndexList(Indices, AteExtraComma)) + if (parseTypeAndValue(Val0, Loc0, PFS) || + parseToken(lltok::comma, "expected comma after insertvalue operand") || + parseTypeAndValue(Val1, Loc1, PFS) || + parseIndexList(Indices, AteExtraComma)) return true; if (!Val0->getType()->isAggregateType()) - return Error(Loc0, "insertvalue operand must be aggregate type"); + return error(Loc0, "insertvalue operand must be aggregate type"); Type *IndexedType = ExtractValueInst::getIndexedType(Val0->getType(), Indices); if (!IndexedType) - return Error(Loc0, "invalid indices for insertvalue"); + return error(Loc0, "invalid indices for insertvalue"); if (IndexedType != Val1->getType()) - return Error(Loc1, "insertvalue operand and field disagree in type: '" + + return error(Loc1, "insertvalue operand and field disagree in type: '" + getTypeString(Val1->getType()) + "' instead of '" + getTypeString(IndexedType) + "'"); Inst = InsertValueInst::Create(Val0, Val1, Indices); @@ -7517,12 +7554,12 @@ // Embedded metadata. //===----------------------------------------------------------------------===// -/// ParseMDNodeVector +/// parseMDNodeVector /// ::= { Element (',' Element)* } /// Element /// ::= 'null' | TypeAndValue -bool LLParser::ParseMDNodeVector(SmallVectorImpl &Elts) { - if (ParseToken(lltok::lbrace, "expected '{' here")) +bool LLParser::parseMDNodeVector(SmallVectorImpl &Elts) { + if (parseToken(lltok::lbrace, "expected '{' here")) return true; // Check for an empty list. @@ -7537,12 +7574,12 @@ } Metadata *MD; - if (ParseMetadata(MD, nullptr)) + if (parseMetadata(MD, nullptr)) return true; Elts.push_back(MD); } while (EatIfPresent(lltok::comma)); - return ParseToken(lltok::rbrace, "expected end of metadata node"); + return parseToken(lltok::rbrace, "expected end of metadata node"); } //===----------------------------------------------------------------------===// @@ -7551,7 +7588,7 @@ bool LLParser::sortUseListOrder(Value *V, ArrayRef Indexes, SMLoc Loc) { if (V->use_empty()) - return Error(Loc, "value has no uses"); + return error(Loc, "value has no uses"); unsigned NumUses = 0; SmallDenseMap Order; @@ -7561,9 +7598,9 @@ Order[&U] = Indexes[NumUses - 1]; } if (NumUses < 2) - return Error(Loc, "value only has one use"); + return error(Loc, "value only has one use"); if (Order.size() != Indexes.size() || NumUses > Indexes.size()) - return Error(Loc, + return error(Loc, "wrong number of indexes, expected " + Twine(V->getNumUses())); V->sortUseList([&](const Use &L, const Use &R) { @@ -7572,11 +7609,11 @@ return false; } -/// ParseUseListOrderIndexes +/// parseUseListOrderIndexes /// ::= '{' uint32 (',' uint32)+ '}' -bool LLParser::ParseUseListOrderIndexes(SmallVectorImpl &Indexes) { +bool LLParser::parseUseListOrderIndexes(SmallVectorImpl &Indexes) { SMLoc Loc = Lex.getLoc(); - if (ParseToken(lltok::lbrace, "expected '{' here")) + if (parseToken(lltok::lbrace, "expected '{' here")) return true; if (Lex.getKind() == lltok::rbrace) return Lex.Error("expected non-empty list of uselistorder indexes"); @@ -7590,7 +7627,7 @@ assert(Indexes.empty() && "Expected empty order vector"); do { unsigned Index; - if (ParseUInt32(Index)) + if (parseUInt32(Index)) return true; // Update consistency checks. @@ -7601,50 +7638,50 @@ Indexes.push_back(Index); } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rbrace, "expected '}' here")) + if (parseToken(lltok::rbrace, "expected '}' here")) return true; if (Indexes.size() < 2) - return Error(Loc, "expected >= 2 uselistorder indexes"); + return error(Loc, "expected >= 2 uselistorder indexes"); if (Offset != 0 || Max >= Indexes.size()) - return Error(Loc, "expected distinct uselistorder indexes in range [0, size)"); + return error(Loc, "expected distinct uselistorder indexes in range [0, size)"); if (IsOrdered) - return Error(Loc, "expected uselistorder indexes to change the order"); + return error(Loc, "expected uselistorder indexes to change the order"); return false; } -/// ParseUseListOrder +/// parseUseListOrder /// ::= 'uselistorder' Type Value ',' UseListOrderIndexes -bool LLParser::ParseUseListOrder(PerFunctionState *PFS) { +bool LLParser::parseUseListOrder(PerFunctionState *PFS) { SMLoc Loc = Lex.getLoc(); - if (ParseToken(lltok::kw_uselistorder, "expected uselistorder directive")) + if (parseToken(lltok::kw_uselistorder, "expected uselistorder directive")) return true; Value *V; SmallVector Indexes; - if (ParseTypeAndValue(V, PFS) || - ParseToken(lltok::comma, "expected comma in uselistorder directive") || - ParseUseListOrderIndexes(Indexes)) + if (parseTypeAndValue(V, PFS) || + parseToken(lltok::comma, "expected comma in uselistorder directive") || + parseUseListOrderIndexes(Indexes)) return true; return sortUseListOrder(V, Indexes, Loc); } -/// ParseUseListOrderBB +/// parseUseListOrderBB /// ::= 'uselistorder_bb' @foo ',' %bar ',' UseListOrderIndexes -bool LLParser::ParseUseListOrderBB() { +bool LLParser::parseUseListOrderBB() { assert(Lex.getKind() == lltok::kw_uselistorder_bb); SMLoc Loc = Lex.getLoc(); Lex.Lex(); ValID Fn, Label; SmallVector Indexes; - if (ParseValID(Fn) || - ParseToken(lltok::comma, "expected comma in uselistorder_bb directive") || - ParseValID(Label) || - ParseToken(lltok::comma, "expected comma in uselistorder_bb directive") || - ParseUseListOrderIndexes(Indexes)) + if (parseValID(Fn) || + parseToken(lltok::comma, "expected comma in uselistorder_bb directive") || + parseValID(Label) || + parseToken(lltok::comma, "expected comma in uselistorder_bb directive") || + parseUseListOrderIndexes(Indexes)) return true; // Check the function. @@ -7654,25 +7691,25 @@ else if (Fn.Kind == ValID::t_GlobalID) GV = Fn.UIntVal < NumberedVals.size() ? NumberedVals[Fn.UIntVal] : nullptr; else - return Error(Fn.Loc, "expected function name in uselistorder_bb"); + return error(Fn.Loc, "expected function name in uselistorder_bb"); if (!GV) - return Error(Fn.Loc, "invalid function forward reference in uselistorder_bb"); + return error(Fn.Loc, "invalid function forward reference in uselistorder_bb"); auto *F = dyn_cast(GV); if (!F) - return Error(Fn.Loc, "expected function name in uselistorder_bb"); + return error(Fn.Loc, "expected function name in uselistorder_bb"); if (F->isDeclaration()) - return Error(Fn.Loc, "invalid declaration in uselistorder_bb"); + return error(Fn.Loc, "invalid declaration in uselistorder_bb"); // Check the basic block. if (Label.Kind == ValID::t_LocalID) - return Error(Label.Loc, "invalid numeric label in uselistorder_bb"); + return error(Label.Loc, "invalid numeric label in uselistorder_bb"); if (Label.Kind != ValID::t_LocalName) - return Error(Label.Loc, "expected basic block name in uselistorder_bb"); + return error(Label.Loc, "expected basic block name in uselistorder_bb"); Value *V = F->getValueSymbolTable()->lookup(Label.StrVal); if (!V) - return Error(Label.Loc, "invalid basic block in uselistorder_bb"); + return error(Label.Loc, "invalid basic block in uselistorder_bb"); if (!isa(V)) - return Error(Label.Loc, "expected basic block in uselistorder_bb"); + return error(Label.Loc, "expected basic block in uselistorder_bb"); return sortUseListOrder(V, Indexes, Loc); } @@ -7680,32 +7717,32 @@ /// ModuleEntry /// ::= 'module' ':' '(' 'path' ':' STRINGCONSTANT ',' 'hash' ':' Hash ')' /// Hash ::= '(' UInt32 ',' UInt32 ',' UInt32 ',' UInt32 ',' UInt32 ')' -bool LLParser::ParseModuleEntry(unsigned ID) { +bool LLParser::parseModuleEntry(unsigned ID) { assert(Lex.getKind() == lltok::kw_module); Lex.Lex(); std::string Path; - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here") || - ParseToken(lltok::kw_path, "expected 'path' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseStringConstant(Path) || - ParseToken(lltok::comma, "expected ',' here") || - ParseToken(lltok::kw_hash, "expected 'hash' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here") || + parseToken(lltok::kw_path, "expected 'path' here") || + parseToken(lltok::colon, "expected ':' here") || + parseStringConstant(Path) || + parseToken(lltok::comma, "expected ',' here") || + parseToken(lltok::kw_hash, "expected 'hash' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; ModuleHash Hash; - if (ParseUInt32(Hash[0]) || ParseToken(lltok::comma, "expected ',' here") || - ParseUInt32(Hash[1]) || ParseToken(lltok::comma, "expected ',' here") || - ParseUInt32(Hash[2]) || ParseToken(lltok::comma, "expected ',' here") || - ParseUInt32(Hash[3]) || ParseToken(lltok::comma, "expected ',' here") || - ParseUInt32(Hash[4])) + if (parseUInt32(Hash[0]) || parseToken(lltok::comma, "expected ',' here") || + parseUInt32(Hash[1]) || parseToken(lltok::comma, "expected ',' here") || + parseUInt32(Hash[2]) || parseToken(lltok::comma, "expected ',' here") || + parseUInt32(Hash[3]) || parseToken(lltok::comma, "expected ',' here") || + parseUInt32(Hash[4])) return true; - if (ParseToken(lltok::rparen, "expected ')' here") || - ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here") || + parseToken(lltok::rparen, "expected ')' here")) return true; auto ModuleEntry = Index->addModule(Path, ID, Hash); @@ -7716,21 +7753,21 @@ /// TypeIdEntry /// ::= 'typeid' ':' '(' 'name' ':' STRINGCONSTANT ',' TypeIdSummary ')' -bool LLParser::ParseTypeIdEntry(unsigned ID) { +bool LLParser::parseTypeIdEntry(unsigned ID) { assert(Lex.getKind() == lltok::kw_typeid); Lex.Lex(); std::string Name; - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here") || - ParseToken(lltok::kw_name, "expected 'name' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseStringConstant(Name)) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here") || + parseToken(lltok::kw_name, "expected 'name' here") || + parseToken(lltok::colon, "expected ':' here") || + parseStringConstant(Name)) return true; TypeIdSummary &TIS = Index->getOrInsertTypeIdSummary(Name); - if (ParseToken(lltok::comma, "expected ',' here") || - ParseTypeIdSummary(TIS) || ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::comma, "expected ',' here") || + parseTypeIdSummary(TIS) || parseToken(lltok::rparen, "expected ')' here")) return true; // Check if this ID was forward referenced, and if so, update the @@ -7750,20 +7787,20 @@ /// TypeIdSummary /// ::= 'summary' ':' '(' TypeTestResolution [',' OptionalWpdResolutions]? ')' -bool LLParser::ParseTypeIdSummary(TypeIdSummary &TIS) { - if (ParseToken(lltok::kw_summary, "expected 'summary' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here") || - ParseTypeTestResolution(TIS.TTRes)) +bool LLParser::parseTypeIdSummary(TypeIdSummary &TIS) { + if (parseToken(lltok::kw_summary, "expected 'summary' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here") || + parseTypeTestResolution(TIS.TTRes)) return true; if (EatIfPresent(lltok::comma)) { // Expect optional wpdResolutions field - if (ParseOptionalWpdResolutions(TIS.WPDRes)) + if (parseOptionalWpdResolutions(TIS.WPDRes)) return true; } - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -7776,40 +7813,40 @@ /// ::= 'typeidCompatibleVTable' ':' '(' 'name' ':' STRINGCONSTANT ',' /// TypeIdCompatibleVtableInfo /// ')' -bool LLParser::ParseTypeIdCompatibleVtableEntry(unsigned ID) { +bool LLParser::parseTypeIdCompatibleVtableEntry(unsigned ID) { assert(Lex.getKind() == lltok::kw_typeidCompatibleVTable); Lex.Lex(); std::string Name; - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here") || - ParseToken(lltok::kw_name, "expected 'name' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseStringConstant(Name)) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here") || + parseToken(lltok::kw_name, "expected 'name' here") || + parseToken(lltok::colon, "expected ':' here") || + parseStringConstant(Name)) return true; TypeIdCompatibleVtableInfo &TI = Index->getOrInsertTypeIdCompatibleVtableSummary(Name); - if (ParseToken(lltok::comma, "expected ',' here") || - ParseToken(lltok::kw_summary, "expected 'summary' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::comma, "expected ',' here") || + parseToken(lltok::kw_summary, "expected 'summary' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; IdToIndexMapType IdToIndexMap; - // Parse each call edge + // parse each call edge do { uint64_t Offset; - if (ParseToken(lltok::lparen, "expected '(' here") || - ParseToken(lltok::kw_offset, "expected 'offset' here") || - ParseToken(lltok::colon, "expected ':' here") || ParseUInt64(Offset) || - ParseToken(lltok::comma, "expected ',' here")) + if (parseToken(lltok::lparen, "expected '(' here") || + parseToken(lltok::kw_offset, "expected 'offset' here") || + parseToken(lltok::colon, "expected ':' here") || parseUInt64(Offset) || + parseToken(lltok::comma, "expected ',' here")) return true; LocTy Loc = Lex.getLoc(); unsigned GVId; ValueInfo VI; - if (ParseGVReference(VI, GVId)) + if (parseGVReference(VI, GVId)) return true; // Keep track of the TypeIdCompatibleVtableInfo array index needing a @@ -7819,7 +7856,7 @@ IdToIndexMap[GVId].push_back(std::make_pair(TI.size(), Loc)); TI.push_back({Offset, VI}); - if (ParseToken(lltok::rparen, "expected ')' in call")) + if (parseToken(lltok::rparen, "expected ')' in call")) return true; } while (EatIfPresent(lltok::comma)); @@ -7834,8 +7871,8 @@ } } - if (ParseToken(lltok::rparen, "expected ')' here") || - ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here") || + parseToken(lltok::rparen, "expected ')' here")) return true; // Check if this ID was forward referenced, and if so, update the @@ -7859,12 +7896,12 @@ /// 'sizeM1BitWidth' ':' SizeM1BitWidth [',' 'alignLog2' ':' UInt64]? /// [',' 'sizeM1' ':' UInt64]? [',' 'bitMask' ':' UInt8]? /// [',' 'inlinesBits' ':' UInt64]? ')' -bool LLParser::ParseTypeTestResolution(TypeTestResolution &TTRes) { - if (ParseToken(lltok::kw_typeTestRes, "expected 'typeTestRes' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here") || - ParseToken(lltok::kw_kind, "expected 'kind' here") || - ParseToken(lltok::colon, "expected ':' here")) +bool LLParser::parseTypeTestResolution(TypeTestResolution &TTRes) { + if (parseToken(lltok::kw_typeTestRes, "expected 'typeTestRes' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here") || + parseToken(lltok::kw_kind, "expected 'kind' here") || + parseToken(lltok::colon, "expected ':' here")) return true; switch (Lex.getKind()) { @@ -7887,34 +7924,34 @@ TTRes.TheKind = TypeTestResolution::AllOnes; break; default: - return Error(Lex.getLoc(), "unexpected TypeTestResolution kind"); + return error(Lex.getLoc(), "unexpected TypeTestResolution kind"); } Lex.Lex(); - if (ParseToken(lltok::comma, "expected ',' here") || - ParseToken(lltok::kw_sizeM1BitWidth, "expected 'sizeM1BitWidth' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseUInt32(TTRes.SizeM1BitWidth)) + if (parseToken(lltok::comma, "expected ',' here") || + parseToken(lltok::kw_sizeM1BitWidth, "expected 'sizeM1BitWidth' here") || + parseToken(lltok::colon, "expected ':' here") || + parseUInt32(TTRes.SizeM1BitWidth)) return true; - // Parse optional fields + // parse optional fields while (EatIfPresent(lltok::comma)) { switch (Lex.getKind()) { case lltok::kw_alignLog2: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || - ParseUInt64(TTRes.AlignLog2)) + if (parseToken(lltok::colon, "expected ':'") || + parseUInt64(TTRes.AlignLog2)) return true; break; case lltok::kw_sizeM1: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseUInt64(TTRes.SizeM1)) + if (parseToken(lltok::colon, "expected ':'") || parseUInt64(TTRes.SizeM1)) return true; break; case lltok::kw_bitMask: { unsigned Val; Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseUInt32(Val)) + if (parseToken(lltok::colon, "expected ':'") || parseUInt32(Val)) return true; assert(Val <= 0xff); TTRes.BitMask = (uint8_t)Val; @@ -7922,16 +7959,16 @@ } case lltok::kw_inlineBits: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || - ParseUInt64(TTRes.InlineBits)) + if (parseToken(lltok::colon, "expected ':'") || + parseUInt64(TTRes.InlineBits)) return true; break; default: - return Error(Lex.getLoc(), "expected optional TypeTestResolution field"); + return error(Lex.getLoc(), "expected optional TypeTestResolution field"); } } - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -7940,26 +7977,26 @@ /// OptionalWpdResolutions /// ::= 'wpsResolutions' ':' '(' WpdResolution [',' WpdResolution]* ')' /// WpdResolution ::= '(' 'offset' ':' UInt64 ',' WpdRes ')' -bool LLParser::ParseOptionalWpdResolutions( +bool LLParser::parseOptionalWpdResolutions( std::map &WPDResMap) { - if (ParseToken(lltok::kw_wpdResolutions, "expected 'wpdResolutions' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::kw_wpdResolutions, "expected 'wpdResolutions' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; do { uint64_t Offset; WholeProgramDevirtResolution WPDRes; - if (ParseToken(lltok::lparen, "expected '(' here") || - ParseToken(lltok::kw_offset, "expected 'offset' here") || - ParseToken(lltok::colon, "expected ':' here") || ParseUInt64(Offset) || - ParseToken(lltok::comma, "expected ',' here") || ParseWpdRes(WPDRes) || - ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::lparen, "expected '(' here") || + parseToken(lltok::kw_offset, "expected 'offset' here") || + parseToken(lltok::colon, "expected ':' here") || parseUInt64(Offset) || + parseToken(lltok::comma, "expected ',' here") || parseWpdRes(WPDRes) || + parseToken(lltok::rparen, "expected ')' here")) return true; WPDResMap[Offset] = WPDRes; } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -7973,12 +8010,12 @@ /// [',' OptionalResByArg]? ')' /// ::= 'wpdRes' ':' '(' 'kind' ':' 'branchFunnel' /// [',' OptionalResByArg]? ')' -bool LLParser::ParseWpdRes(WholeProgramDevirtResolution &WPDRes) { - if (ParseToken(lltok::kw_wpdRes, "expected 'wpdRes' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here") || - ParseToken(lltok::kw_kind, "expected 'kind' here") || - ParseToken(lltok::colon, "expected ':' here")) +bool LLParser::parseWpdRes(WholeProgramDevirtResolution &WPDRes) { + if (parseToken(lltok::kw_wpdRes, "expected 'wpdRes' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here") || + parseToken(lltok::kw_kind, "expected 'kind' here") || + parseToken(lltok::colon, "expected ':' here")) return true; switch (Lex.getKind()) { @@ -7992,30 +8029,30 @@ WPDRes.TheKind = WholeProgramDevirtResolution::BranchFunnel; break; default: - return Error(Lex.getLoc(), "unexpected WholeProgramDevirtResolution kind"); + return error(Lex.getLoc(), "unexpected WholeProgramDevirtResolution kind"); } Lex.Lex(); - // Parse optional fields + // parse optional fields while (EatIfPresent(lltok::comma)) { switch (Lex.getKind()) { case lltok::kw_singleImplName: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseStringConstant(WPDRes.SingleImplName)) + if (parseToken(lltok::colon, "expected ':' here") || + parseStringConstant(WPDRes.SingleImplName)) return true; break; case lltok::kw_resByArg: - if (ParseOptionalResByArg(WPDRes.ResByArg)) + if (parseOptionalResByArg(WPDRes.ResByArg)) return true; break; default: - return Error(Lex.getLoc(), + return error(Lex.getLoc(), "expected optional WholeProgramDevirtResolution field"); } } - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -8028,22 +8065,22 @@ /// 'virtualConstProp' ) /// [',' 'info' ':' UInt64]? [',' 'byte' ':' UInt32]? /// [',' 'bit' ':' UInt32]? ')' -bool LLParser::ParseOptionalResByArg( +bool LLParser::parseOptionalResByArg( std::map, WholeProgramDevirtResolution::ByArg> &ResByArg) { - if (ParseToken(lltok::kw_resByArg, "expected 'resByArg' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::kw_resByArg, "expected 'resByArg' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; do { std::vector Args; - if (ParseArgs(Args) || ParseToken(lltok::comma, "expected ',' here") || - ParseToken(lltok::kw_byArg, "expected 'byArg here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here") || - ParseToken(lltok::kw_kind, "expected 'kind' here") || - ParseToken(lltok::colon, "expected ':' here")) + if (parseArgs(Args) || parseToken(lltok::comma, "expected ',' here") || + parseToken(lltok::kw_byArg, "expected 'byArg here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here") || + parseToken(lltok::kw_kind, "expected 'kind' here") || + parseToken(lltok::colon, "expected ':' here")) return true; WholeProgramDevirtResolution::ByArg ByArg; @@ -8061,45 +8098,45 @@ ByArg.TheKind = WholeProgramDevirtResolution::ByArg::VirtualConstProp; break; default: - return Error(Lex.getLoc(), + return error(Lex.getLoc(), "unexpected WholeProgramDevirtResolution::ByArg kind"); } Lex.Lex(); - // Parse optional fields + // parse optional fields while (EatIfPresent(lltok::comma)) { switch (Lex.getKind()) { case lltok::kw_info: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseUInt64(ByArg.Info)) + if (parseToken(lltok::colon, "expected ':' here") || + parseUInt64(ByArg.Info)) return true; break; case lltok::kw_byte: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseUInt32(ByArg.Byte)) + if (parseToken(lltok::colon, "expected ':' here") || + parseUInt32(ByArg.Byte)) return true; break; case lltok::kw_bit: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseUInt32(ByArg.Bit)) + if (parseToken(lltok::colon, "expected ':' here") || + parseUInt32(ByArg.Bit)) return true; break; default: - return Error(Lex.getLoc(), + return error(Lex.getLoc(), "expected optional whole program devirt field"); } } - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; ResByArg[Args] = ByArg; } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -8107,20 +8144,20 @@ /// OptionalResByArg /// ::= 'args' ':' '(' UInt64[, UInt64]* ')' -bool LLParser::ParseArgs(std::vector &Args) { - if (ParseToken(lltok::kw_args, "expected 'args' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) +bool LLParser::parseArgs(std::vector &Args) { + if (parseToken(lltok::kw_args, "expected 'args' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; do { uint64_t Val; - if (ParseUInt64(Val)) + if (parseUInt64(Val)) return true; Args.push_back(Val); } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -8141,7 +8178,7 @@ /// Stores the given Name/GUID and associated summary into the Index. /// Also updates any forward references to the associated entry ID. -void LLParser::AddGlobalValueToIndex( +void LLParser::addGlobalValueToIndex( std::string Name, GlobalValue::GUID GUID, GlobalValue::LinkageTypes Linkage, unsigned ID, std::unique_ptr Summary) { // First create the ValueInfo utilizing the Name or GUID. @@ -8203,48 +8240,48 @@ } } -/// ParseSummaryIndexFlags +/// parseSummaryIndexFlags /// ::= 'flags' ':' UInt64 -bool LLParser::ParseSummaryIndexFlags() { +bool LLParser::parseSummaryIndexFlags() { assert(Lex.getKind() == lltok::kw_flags); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here")) + if (parseToken(lltok::colon, "expected ':' here")) return true; uint64_t Flags; - if (ParseUInt64(Flags)) + if (parseUInt64(Flags)) return true; if (Index) Index->setFlags(Flags); return false; } -/// ParseBlockCount +/// parseBlockCount /// ::= 'blockcount' ':' UInt64 -bool LLParser::ParseBlockCount() { +bool LLParser::parseBlockCount() { assert(Lex.getKind() == lltok::kw_blockcount); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here")) + if (parseToken(lltok::colon, "expected ':' here")) return true; uint64_t BlockCount; - if (ParseUInt64(BlockCount)) + if (parseUInt64(BlockCount)) return true; if (Index) Index->setBlockCount(BlockCount); return false; } -/// ParseGVEntry +/// parseGVEntry /// ::= 'gv' ':' '(' ('name' ':' STRINGCONSTANT | 'guid' ':' UInt64) /// [',' 'summaries' ':' Summary[',' Summary]* ]? ')' /// Summary ::= '(' (FunctionSummary | VariableSummary | AliasSummary) ')' -bool LLParser::ParseGVEntry(unsigned ID) { +bool LLParser::parseGVEntry(unsigned ID) { assert(Lex.getKind() == lltok::kw_gv); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; std::string Name; @@ -8252,23 +8289,23 @@ switch (Lex.getKind()) { case lltok::kw_name: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseStringConstant(Name)) + if (parseToken(lltok::colon, "expected ':' here") || + parseStringConstant(Name)) return true; // Can't create GUID/ValueInfo until we have the linkage. break; case lltok::kw_guid: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || ParseUInt64(GUID)) + if (parseToken(lltok::colon, "expected ':' here") || parseUInt64(GUID)) return true; break; default: - return Error(Lex.getLoc(), "expected name or guid tag"); + return error(Lex.getLoc(), "expected name or guid tag"); } if (!EatIfPresent(lltok::comma)) { // No summaries. Wrap up. - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; // This was created for a call to an external or indirect target. // A GUID with no summary came from a VALUE_GUID record, dummy GUID @@ -8276,37 +8313,37 @@ // an external definition. We pass ExternalLinkage since that is only // used when the GUID must be computed from Name, and in that case // the symbol must have external linkage. - AddGlobalValueToIndex(Name, GUID, GlobalValue::ExternalLinkage, ID, + addGlobalValueToIndex(Name, GUID, GlobalValue::ExternalLinkage, ID, nullptr); return false; } // Have a list of summaries - if (ParseToken(lltok::kw_summaries, "expected 'summaries' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::kw_summaries, "expected 'summaries' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; do { switch (Lex.getKind()) { case lltok::kw_function: - if (ParseFunctionSummary(Name, GUID, ID)) + if (parseFunctionSummary(Name, GUID, ID)) return true; break; case lltok::kw_variable: - if (ParseVariableSummary(Name, GUID, ID)) + if (parseVariableSummary(Name, GUID, ID)) return true; break; case lltok::kw_alias: - if (ParseAliasSummary(Name, GUID, ID)) + if (parseAliasSummary(Name, GUID, ID)) return true; break; default: - return Error(Lex.getLoc(), "expected summary type"); + return error(Lex.getLoc(), "expected summary type"); } } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' here") || - ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here") || + parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -8317,7 +8354,7 @@ /// ',' 'insts' ':' UInt32 [',' OptionalFFlags]? [',' OptionalCalls]? /// [',' OptionalTypeIdInfo]? [',' OptionalParamAccesses]? /// [',' OptionalRefs]? ')' -bool LLParser::ParseFunctionSummary(std::string Name, GlobalValue::GUID GUID, +bool LLParser::parseFunctionSummary(std::string Name, GlobalValue::GUID GUID, unsigned ID) { assert(Lex.getKind() == lltok::kw_function); Lex.Lex(); @@ -8333,44 +8370,44 @@ std::vector Refs; // Default is all-zeros (conservative values). FunctionSummary::FFlags FFlags = {}; - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here") || - ParseModuleReference(ModulePath) || - ParseToken(lltok::comma, "expected ',' here") || ParseGVFlags(GVFlags) || - ParseToken(lltok::comma, "expected ',' here") || - ParseToken(lltok::kw_insts, "expected 'insts' here") || - ParseToken(lltok::colon, "expected ':' here") || ParseUInt32(InstCount)) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here") || + parseModuleReference(ModulePath) || + parseToken(lltok::comma, "expected ',' here") || parseGVFlags(GVFlags) || + parseToken(lltok::comma, "expected ',' here") || + parseToken(lltok::kw_insts, "expected 'insts' here") || + parseToken(lltok::colon, "expected ':' here") || parseUInt32(InstCount)) return true; - // Parse optional fields + // parse optional fields while (EatIfPresent(lltok::comma)) { switch (Lex.getKind()) { case lltok::kw_funcFlags: - if (ParseOptionalFFlags(FFlags)) + if (parseOptionalFFlags(FFlags)) return true; break; case lltok::kw_calls: - if (ParseOptionalCalls(Calls)) + if (parseOptionalCalls(Calls)) return true; break; case lltok::kw_typeIdInfo: - if (ParseOptionalTypeIdInfo(TypeIdInfo)) + if (parseOptionalTypeIdInfo(TypeIdInfo)) return true; break; case lltok::kw_refs: - if (ParseOptionalRefs(Refs)) + if (parseOptionalRefs(Refs)) return true; break; case lltok::kw_params: - if (ParseOptionalParamAccesses(ParamAccesses)) + if (parseOptionalParamAccesses(ParamAccesses)) return true; break; default: - return Error(Lex.getLoc(), "expected optional function summary field"); + return error(Lex.getLoc(), "expected optional function summary field"); } } - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; auto FS = std::make_unique( @@ -8384,7 +8421,7 @@ FS->setModulePath(ModulePath); - AddGlobalValueToIndex(Name, GUID, (GlobalValue::LinkageTypes)GVFlags.Linkage, + addGlobalValueToIndex(Name, GUID, (GlobalValue::LinkageTypes)GVFlags.Linkage, ID, std::move(FS)); return false; @@ -8393,7 +8430,7 @@ /// VariableSummary /// ::= 'variable' ':' '(' 'module' ':' ModuleReference ',' GVFlags /// [',' OptionalRefs]? ')' -bool LLParser::ParseVariableSummary(std::string Name, GlobalValue::GUID GUID, +bool LLParser::parseVariableSummary(std::string Name, GlobalValue::GUID GUID, unsigned ID) { assert(Lex.getKind() == lltok::kw_variable); Lex.Lex(); @@ -8408,31 +8445,31 @@ GlobalObject::VCallVisibilityPublic); std::vector Refs; VTableFuncList VTableFuncs; - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here") || - ParseModuleReference(ModulePath) || - ParseToken(lltok::comma, "expected ',' here") || ParseGVFlags(GVFlags) || - ParseToken(lltok::comma, "expected ',' here") || - ParseGVarFlags(GVarFlags)) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here") || + parseModuleReference(ModulePath) || + parseToken(lltok::comma, "expected ',' here") || parseGVFlags(GVFlags) || + parseToken(lltok::comma, "expected ',' here") || + parseGVarFlags(GVarFlags)) return true; - // Parse optional fields + // parse optional fields while (EatIfPresent(lltok::comma)) { switch (Lex.getKind()) { case lltok::kw_vTableFuncs: - if (ParseOptionalVTableFuncs(VTableFuncs)) + if (parseOptionalVTableFuncs(VTableFuncs)) return true; break; case lltok::kw_refs: - if (ParseOptionalRefs(Refs)) + if (parseOptionalRefs(Refs)) return true; break; default: - return Error(Lex.getLoc(), "expected optional variable summary field"); + return error(Lex.getLoc(), "expected optional variable summary field"); } } - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; auto GS = @@ -8441,7 +8478,7 @@ GS->setModulePath(ModulePath); GS->setVTableFuncs(std::move(VTableFuncs)); - AddGlobalValueToIndex(Name, GUID, (GlobalValue::LinkageTypes)GVFlags.Linkage, + addGlobalValueToIndex(Name, GUID, (GlobalValue::LinkageTypes)GVFlags.Linkage, ID, std::move(GS)); return false; @@ -8450,7 +8487,7 @@ /// AliasSummary /// ::= 'alias' ':' '(' 'module' ':' ModuleReference ',' GVFlags ',' /// 'aliasee' ':' GVReference ')' -bool LLParser::ParseAliasSummary(std::string Name, GlobalValue::GUID GUID, +bool LLParser::parseAliasSummary(std::string Name, GlobalValue::GUID GUID, unsigned ID) { assert(Lex.getKind() == lltok::kw_alias); LocTy Loc = Lex.getLoc(); @@ -8460,21 +8497,21 @@ GlobalValueSummary::GVFlags GVFlags = GlobalValueSummary::GVFlags( /*Linkage=*/GlobalValue::ExternalLinkage, /*NotEligibleToImport=*/false, /*Live=*/false, /*IsLocal=*/false, /*CanAutoHide=*/false); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here") || - ParseModuleReference(ModulePath) || - ParseToken(lltok::comma, "expected ',' here") || ParseGVFlags(GVFlags) || - ParseToken(lltok::comma, "expected ',' here") || - ParseToken(lltok::kw_aliasee, "expected 'aliasee' here") || - ParseToken(lltok::colon, "expected ':' here")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here") || + parseModuleReference(ModulePath) || + parseToken(lltok::comma, "expected ',' here") || parseGVFlags(GVFlags) || + parseToken(lltok::comma, "expected ',' here") || + parseToken(lltok::kw_aliasee, "expected 'aliasee' here") || + parseToken(lltok::colon, "expected ':' here")) return true; ValueInfo AliaseeVI; unsigned GVId; - if (ParseGVReference(AliaseeVI, GVId)) + if (parseGVReference(AliaseeVI, GVId)) return true; - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; auto AS = std::make_unique(GVFlags); @@ -8490,7 +8527,7 @@ AS->setAliasee(AliaseeVI, Summary); } - AddGlobalValueToIndex(Name, GUID, (GlobalValue::LinkageTypes)GVFlags.Linkage, + addGlobalValueToIndex(Name, GUID, (GlobalValue::LinkageTypes)GVFlags.Linkage, ID, std::move(AS)); return false; @@ -8498,9 +8535,9 @@ /// Flag /// ::= [0|1] -bool LLParser::ParseFlag(unsigned &Val) { +bool LLParser::parseFlag(unsigned &Val) { if (Lex.getKind() != lltok::APSInt || Lex.getAPSIntVal().isSigned()) - return TokError("expected integer"); + return tokError("expected integer"); Val = (unsigned)Lex.getAPSIntVal().getBoolValue(); Lex.Lex(); return false; @@ -8513,12 +8550,12 @@ /// [',' 'noInline' ':' Flag]? ')' /// [',' 'alwaysInline' ':' Flag]? ')' -bool LLParser::ParseOptionalFFlags(FunctionSummary::FFlags &FFlags) { +bool LLParser::parseOptionalFFlags(FunctionSummary::FFlags &FFlags) { assert(Lex.getKind() == lltok::kw_funcFlags); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' in funcFlags") | - ParseToken(lltok::lparen, "expected '(' in funcFlags")) + if (parseToken(lltok::colon, "expected ':' in funcFlags") | + parseToken(lltok::lparen, "expected '(' in funcFlags")) return true; do { @@ -8526,46 +8563,46 @@ switch (Lex.getKind()) { case lltok::kw_readNone: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseFlag(Val)) + if (parseToken(lltok::colon, "expected ':'") || parseFlag(Val)) return true; FFlags.ReadNone = Val; break; case lltok::kw_readOnly: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseFlag(Val)) + if (parseToken(lltok::colon, "expected ':'") || parseFlag(Val)) return true; FFlags.ReadOnly = Val; break; case lltok::kw_noRecurse: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseFlag(Val)) + if (parseToken(lltok::colon, "expected ':'") || parseFlag(Val)) return true; FFlags.NoRecurse = Val; break; case lltok::kw_returnDoesNotAlias: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseFlag(Val)) + if (parseToken(lltok::colon, "expected ':'") || parseFlag(Val)) return true; FFlags.ReturnDoesNotAlias = Val; break; case lltok::kw_noInline: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseFlag(Val)) + if (parseToken(lltok::colon, "expected ':'") || parseFlag(Val)) return true; FFlags.NoInline = Val; break; case lltok::kw_alwaysInline: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseFlag(Val)) + if (parseToken(lltok::colon, "expected ':'") || parseFlag(Val)) return true; FFlags.AlwaysInline = Val; break; default: - return Error(Lex.getLoc(), "expected function flag type"); + return error(Lex.getLoc(), "expected function flag type"); } } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' in funcFlags")) + if (parseToken(lltok::rparen, "expected ')' in funcFlags")) return true; return false; @@ -8575,26 +8612,26 @@ /// := 'calls' ':' '(' Call [',' Call]* ')' /// Call ::= '(' 'callee' ':' GVReference /// [( ',' 'hotness' ':' Hotness | ',' 'relbf' ':' UInt32 )]? ')' -bool LLParser::ParseOptionalCalls(std::vector &Calls) { +bool LLParser::parseOptionalCalls(std::vector &Calls) { assert(Lex.getKind() == lltok::kw_calls); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' in calls") | - ParseToken(lltok::lparen, "expected '(' in calls")) + if (parseToken(lltok::colon, "expected ':' in calls") | + parseToken(lltok::lparen, "expected '(' in calls")) return true; IdToIndexMapType IdToIndexMap; - // Parse each call edge + // parse each call edge do { ValueInfo VI; - if (ParseToken(lltok::lparen, "expected '(' in call") || - ParseToken(lltok::kw_callee, "expected 'callee' in call") || - ParseToken(lltok::colon, "expected ':'")) + if (parseToken(lltok::lparen, "expected '(' in call") || + parseToken(lltok::kw_callee, "expected 'callee' in call") || + parseToken(lltok::colon, "expected ':'")) return true; LocTy Loc = Lex.getLoc(); unsigned GVId; - if (ParseGVReference(VI, GVId)) + if (parseGVReference(VI, GVId)) return true; CalleeInfo::HotnessType Hotness = CalleeInfo::HotnessType::Unknown; @@ -8602,11 +8639,11 @@ if (EatIfPresent(lltok::comma)) { // Expect either hotness or relbf if (EatIfPresent(lltok::kw_hotness)) { - if (ParseToken(lltok::colon, "expected ':'") || ParseHotness(Hotness)) + if (parseToken(lltok::colon, "expected ':'") || parseHotness(Hotness)) return true; } else { - if (ParseToken(lltok::kw_relbf, "expected relbf") || - ParseToken(lltok::colon, "expected ':'") || ParseUInt32(RelBF)) + if (parseToken(lltok::kw_relbf, "expected relbf") || + parseToken(lltok::colon, "expected ':'") || parseUInt32(RelBF)) return true; } } @@ -8617,7 +8654,7 @@ IdToIndexMap[GVId].push_back(std::make_pair(Calls.size(), Loc)); Calls.push_back(FunctionSummary::EdgeTy{VI, CalleeInfo(Hotness, RelBF)}); - if (ParseToken(lltok::rparen, "expected ')' in call")) + if (parseToken(lltok::rparen, "expected ')' in call")) return true; } while (EatIfPresent(lltok::comma)); @@ -8632,7 +8669,7 @@ } } - if (ParseToken(lltok::rparen, "expected ')' in calls")) + if (parseToken(lltok::rparen, "expected ')' in calls")) return true; return false; @@ -8640,7 +8677,7 @@ /// Hotness /// := ('unknown'|'cold'|'none'|'hot'|'critical') -bool LLParser::ParseHotness(CalleeInfo::HotnessType &Hotness) { +bool LLParser::parseHotness(CalleeInfo::HotnessType &Hotness) { switch (Lex.getKind()) { case lltok::kw_unknown: Hotness = CalleeInfo::HotnessType::Unknown; @@ -8658,7 +8695,7 @@ Hotness = CalleeInfo::HotnessType::Critical; break; default: - return Error(Lex.getLoc(), "invalid call edge hotness"); + return error(Lex.getLoc(), "invalid call edge hotness"); } Lex.Lex(); return false; @@ -8667,32 +8704,32 @@ /// OptionalVTableFuncs /// := 'vTableFuncs' ':' '(' VTableFunc [',' VTableFunc]* ')' /// VTableFunc ::= '(' 'virtFunc' ':' GVReference ',' 'offset' ':' UInt64 ')' -bool LLParser::ParseOptionalVTableFuncs(VTableFuncList &VTableFuncs) { +bool LLParser::parseOptionalVTableFuncs(VTableFuncList &VTableFuncs) { assert(Lex.getKind() == lltok::kw_vTableFuncs); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' in vTableFuncs") | - ParseToken(lltok::lparen, "expected '(' in vTableFuncs")) + if (parseToken(lltok::colon, "expected ':' in vTableFuncs") | + parseToken(lltok::lparen, "expected '(' in vTableFuncs")) return true; IdToIndexMapType IdToIndexMap; - // Parse each virtual function pair + // parse each virtual function pair do { ValueInfo VI; - if (ParseToken(lltok::lparen, "expected '(' in vTableFunc") || - ParseToken(lltok::kw_virtFunc, "expected 'callee' in vTableFunc") || - ParseToken(lltok::colon, "expected ':'")) + if (parseToken(lltok::lparen, "expected '(' in vTableFunc") || + parseToken(lltok::kw_virtFunc, "expected 'callee' in vTableFunc") || + parseToken(lltok::colon, "expected ':'")) return true; LocTy Loc = Lex.getLoc(); unsigned GVId; - if (ParseGVReference(VI, GVId)) + if (parseGVReference(VI, GVId)) return true; uint64_t Offset; - if (ParseToken(lltok::comma, "expected comma") || - ParseToken(lltok::kw_offset, "expected offset") || - ParseToken(lltok::colon, "expected ':'") || ParseUInt64(Offset)) + if (parseToken(lltok::comma, "expected comma") || + parseToken(lltok::kw_offset, "expected offset") || + parseToken(lltok::colon, "expected ':'") || parseUInt64(Offset)) return true; // Keep track of the VTableFuncs array index needing a forward reference. @@ -8702,7 +8739,7 @@ IdToIndexMap[GVId].push_back(std::make_pair(VTableFuncs.size(), Loc)); VTableFuncs.push_back({VI, Offset}); - if (ParseToken(lltok::rparen, "expected ')' in vTableFunc")) + if (parseToken(lltok::rparen, "expected ')' in vTableFunc")) return true; } while (EatIfPresent(lltok::comma)); @@ -8717,38 +8754,38 @@ } } - if (ParseToken(lltok::rparen, "expected ')' in vTableFuncs")) + if (parseToken(lltok::rparen, "expected ')' in vTableFuncs")) return true; return false; } /// ParamNo := 'param' ':' UInt64 -bool LLParser::ParseParamNo(uint64_t &ParamNo) { - if (ParseToken(lltok::kw_param, "expected 'param' here") || - ParseToken(lltok::colon, "expected ':' here") || ParseUInt64(ParamNo)) +bool LLParser::parseParamNo(uint64_t &ParamNo) { + if (parseToken(lltok::kw_param, "expected 'param' here") || + parseToken(lltok::colon, "expected ':' here") || parseUInt64(ParamNo)) return true; return false; } /// ParamAccessOffset := 'offset' ':' '[' APSINTVAL ',' APSINTVAL ']' -bool LLParser::ParseParamAccessOffset(ConstantRange &Range) { +bool LLParser::parseParamAccessOffset(ConstantRange &Range) { APSInt Lower; APSInt Upper; - auto ParseAPSInt = [&](APSInt &Val) { + auto parseAPSInt = [&](APSInt &Val) { if (Lex.getKind() != lltok::APSInt) - return TokError("expected integer"); + return tokError("expected integer"); Val = Lex.getAPSIntVal(); Val = Val.extOrTrunc(FunctionSummary::ParamAccess::RangeWidth); Val.setIsSigned(true); Lex.Lex(); return false; }; - if (ParseToken(lltok::kw_offset, "expected 'offset' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lsquare, "expected '[' here") || ParseAPSInt(Lower) || - ParseToken(lltok::comma, "expected ',' here") || ParseAPSInt(Upper) || - ParseToken(lltok::rsquare, "expected ']' here")) + if (parseToken(lltok::kw_offset, "expected 'offset' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lsquare, "expected '[' here") || parseAPSInt(Lower) || + parseToken(lltok::comma, "expected ',' here") || parseAPSInt(Upper) || + parseToken(lltok::rsquare, "expected ']' here")) return true; ++Upper; @@ -8762,29 +8799,29 @@ /// ParamAccessCall /// := '(' 'callee' ':' GVReference ',' ParamNo ',' ParamAccessOffset ')' -bool LLParser::ParseParamAccessCall(FunctionSummary::ParamAccess::Call &Call, +bool LLParser::parseParamAccessCall(FunctionSummary::ParamAccess::Call &Call, IdLocListType &IdLocList) { - if (ParseToken(lltok::lparen, "expected '(' here") || - ParseToken(lltok::kw_callee, "expected 'callee' here") || - ParseToken(lltok::colon, "expected ':' here")) + if (parseToken(lltok::lparen, "expected '(' here") || + parseToken(lltok::kw_callee, "expected 'callee' here") || + parseToken(lltok::colon, "expected ':' here")) return true; unsigned GVId; ValueInfo VI; LocTy Loc = Lex.getLoc(); - if (ParseGVReference(VI, GVId)) + if (parseGVReference(VI, GVId)) return true; Call.Callee = VI; IdLocList.emplace_back(GVId, Loc); - if (ParseToken(lltok::comma, "expected ',' here") || - ParseParamNo(Call.ParamNo) || - ParseToken(lltok::comma, "expected ',' here") || - ParseParamAccessOffset(Call.Offsets)) + if (parseToken(lltok::comma, "expected ',' here") || + parseParamNo(Call.ParamNo) || + parseToken(lltok::comma, "expected ',' here") || + parseParamAccessOffset(Call.Offsets)) return true; - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -8793,31 +8830,31 @@ /// ParamAccess /// := '(' ParamNo ',' ParamAccessOffset [',' OptionalParamAccessCalls]? ')' /// OptionalParamAccessCalls := '(' Call [',' Call]* ')' -bool LLParser::ParseParamAccess(FunctionSummary::ParamAccess &Param, +bool LLParser::parseParamAccess(FunctionSummary::ParamAccess &Param, IdLocListType &IdLocList) { - if (ParseToken(lltok::lparen, "expected '(' here") || - ParseParamNo(Param.ParamNo) || - ParseToken(lltok::comma, "expected ',' here") || - ParseParamAccessOffset(Param.Use)) + if (parseToken(lltok::lparen, "expected '(' here") || + parseParamNo(Param.ParamNo) || + parseToken(lltok::comma, "expected ',' here") || + parseParamAccessOffset(Param.Use)) return true; if (EatIfPresent(lltok::comma)) { - if (ParseToken(lltok::kw_calls, "expected 'calls' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::kw_calls, "expected 'calls' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; do { FunctionSummary::ParamAccess::Call Call; - if (ParseParamAccessCall(Call, IdLocList)) + if (parseParamAccessCall(Call, IdLocList)) return true; Param.Calls.push_back(Call); } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; } - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -8825,27 +8862,27 @@ /// OptionalParamAccesses /// := 'params' ':' '(' ParamAccess [',' ParamAccess]* ')' -bool LLParser::ParseOptionalParamAccesses( +bool LLParser::parseOptionalParamAccesses( std::vector &Params) { assert(Lex.getKind() == lltok::kw_params); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; IdLocListType VContexts; size_t CallsNum = 0; do { FunctionSummary::ParamAccess ParamAccess; - if (ParseParamAccess(ParamAccess, VContexts)) + if (parseParamAccess(ParamAccess, VContexts)) return true; CallsNum += ParamAccess.Calls.size(); assert(VContexts.size() == CallsNum); Params.emplace_back(std::move(ParamAccess)); } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; // Now that the Params is finalized, it is safe to save the locations @@ -8866,12 +8903,12 @@ /// OptionalRefs /// := 'refs' ':' '(' GVReference [',' GVReference]* ')' -bool LLParser::ParseOptionalRefs(std::vector &Refs) { +bool LLParser::parseOptionalRefs(std::vector &Refs) { assert(Lex.getKind() == lltok::kw_refs); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' in refs") || - ParseToken(lltok::lparen, "expected '(' in refs")) + if (parseToken(lltok::colon, "expected ':' in refs") || + parseToken(lltok::lparen, "expected '(' in refs")) return true; struct ValueContext { @@ -8880,11 +8917,11 @@ LocTy Loc; }; std::vector VContexts; - // Parse each ref edge + // parse each ref edge do { ValueContext VC; VC.Loc = Lex.getLoc(); - if (ParseGVReference(VC.VI, VC.GVId)) + if (parseGVReference(VC.VI, VC.GVId)) return true; VContexts.push_back(VC); } while (EatIfPresent(lltok::comma)); @@ -8917,7 +8954,7 @@ } } - if (ParseToken(lltok::rparen, "expected ')' in refs")) + if (parseToken(lltok::rparen, "expected ')' in refs")) return true; return false; @@ -8927,47 +8964,47 @@ /// := 'typeidinfo' ':' '(' [',' TypeTests]? [',' TypeTestAssumeVCalls]? /// [',' TypeCheckedLoadVCalls]? [',' TypeTestAssumeConstVCalls]? /// [',' TypeCheckedLoadConstVCalls]? ')' -bool LLParser::ParseOptionalTypeIdInfo( +bool LLParser::parseOptionalTypeIdInfo( FunctionSummary::TypeIdInfo &TypeIdInfo) { assert(Lex.getKind() == lltok::kw_typeIdInfo); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' in typeIdInfo")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' in typeIdInfo")) return true; do { switch (Lex.getKind()) { case lltok::kw_typeTests: - if (ParseTypeTests(TypeIdInfo.TypeTests)) + if (parseTypeTests(TypeIdInfo.TypeTests)) return true; break; case lltok::kw_typeTestAssumeVCalls: - if (ParseVFuncIdList(lltok::kw_typeTestAssumeVCalls, + if (parseVFuncIdList(lltok::kw_typeTestAssumeVCalls, TypeIdInfo.TypeTestAssumeVCalls)) return true; break; case lltok::kw_typeCheckedLoadVCalls: - if (ParseVFuncIdList(lltok::kw_typeCheckedLoadVCalls, + if (parseVFuncIdList(lltok::kw_typeCheckedLoadVCalls, TypeIdInfo.TypeCheckedLoadVCalls)) return true; break; case lltok::kw_typeTestAssumeConstVCalls: - if (ParseConstVCallList(lltok::kw_typeTestAssumeConstVCalls, + if (parseConstVCallList(lltok::kw_typeTestAssumeConstVCalls, TypeIdInfo.TypeTestAssumeConstVCalls)) return true; break; case lltok::kw_typeCheckedLoadConstVCalls: - if (ParseConstVCallList(lltok::kw_typeCheckedLoadConstVCalls, + if (parseConstVCallList(lltok::kw_typeCheckedLoadConstVCalls, TypeIdInfo.TypeCheckedLoadConstVCalls)) return true; break; default: - return Error(Lex.getLoc(), "invalid typeIdInfo list type"); + return error(Lex.getLoc(), "invalid typeIdInfo list type"); } } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' in typeIdInfo")) + if (parseToken(lltok::rparen, "expected ')' in typeIdInfo")) return true; return false; @@ -8976,12 +9013,12 @@ /// TypeTests /// ::= 'typeTests' ':' '(' (SummaryID | UInt64) /// [',' (SummaryID | UInt64)]* ')' -bool LLParser::ParseTypeTests(std::vector &TypeTests) { +bool LLParser::parseTypeTests(std::vector &TypeTests) { assert(Lex.getKind() == lltok::kw_typeTests); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' in typeIdInfo")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' in typeIdInfo")) return true; IdToIndexMapType IdToIndexMap; @@ -8995,7 +9032,7 @@ // can only do so once the std::vector is finalized. IdToIndexMap[ID].push_back(std::make_pair(TypeTests.size(), Loc)); Lex.Lex(); - } else if (ParseUInt64(GUID)) + } else if (parseUInt64(GUID)) return true; TypeTests.push_back(GUID); } while (EatIfPresent(lltok::comma)); @@ -9011,7 +9048,7 @@ } } - if (ParseToken(lltok::rparen, "expected ')' in typeIdInfo")) + if (parseToken(lltok::rparen, "expected ')' in typeIdInfo")) return true; return false; @@ -9019,24 +9056,24 @@ /// VFuncIdList /// ::= Kind ':' '(' VFuncId [',' VFuncId]* ')' -bool LLParser::ParseVFuncIdList( +bool LLParser::parseVFuncIdList( lltok::Kind Kind, std::vector &VFuncIdList) { assert(Lex.getKind() == Kind); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; IdToIndexMapType IdToIndexMap; do { FunctionSummary::VFuncId VFuncId; - if (ParseVFuncId(VFuncId, IdToIndexMap, VFuncIdList.size())) + if (parseVFuncId(VFuncId, IdToIndexMap, VFuncIdList.size())) return true; VFuncIdList.push_back(VFuncId); } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; // Now that the VFuncIdList vector is finalized, it is safe to save the @@ -9055,25 +9092,25 @@ /// ConstVCallList /// ::= Kind ':' '(' ConstVCall [',' ConstVCall]* ')' -bool LLParser::ParseConstVCallList( +bool LLParser::parseConstVCallList( lltok::Kind Kind, std::vector &ConstVCallList) { assert(Lex.getKind() == Kind); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; IdToIndexMapType IdToIndexMap; do { FunctionSummary::ConstVCall ConstVCall; - if (ParseConstVCall(ConstVCall, IdToIndexMap, ConstVCallList.size())) + if (parseConstVCall(ConstVCall, IdToIndexMap, ConstVCallList.size())) return true; ConstVCallList.push_back(ConstVCall); } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; // Now that the ConstVCallList vector is finalized, it is safe to save the @@ -9092,17 +9129,17 @@ /// ConstVCall /// ::= '(' VFuncId ',' Args ')' -bool LLParser::ParseConstVCall(FunctionSummary::ConstVCall &ConstVCall, +bool LLParser::parseConstVCall(FunctionSummary::ConstVCall &ConstVCall, IdToIndexMapType &IdToIndexMap, unsigned Index) { - if (ParseToken(lltok::lparen, "expected '(' here") || - ParseVFuncId(ConstVCall.VFunc, IdToIndexMap, Index)) + if (parseToken(lltok::lparen, "expected '(' here") || + parseVFuncId(ConstVCall.VFunc, IdToIndexMap, Index)) return true; if (EatIfPresent(lltok::comma)) - if (ParseArgs(ConstVCall.Args)) + if (parseArgs(ConstVCall.Args)) return true; - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -9111,13 +9148,13 @@ /// VFuncId /// ::= 'vFuncId' ':' '(' (SummaryID | 'guid' ':' UInt64) ',' /// 'offset' ':' UInt64 ')' -bool LLParser::ParseVFuncId(FunctionSummary::VFuncId &VFuncId, +bool LLParser::parseVFuncId(FunctionSummary::VFuncId &VFuncId, IdToIndexMapType &IdToIndexMap, unsigned Index) { assert(Lex.getKind() == lltok::kw_vFuncId); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; if (Lex.getKind() == lltok::SummaryID) { @@ -9129,16 +9166,16 @@ // can only do so once the caller's std::vector is finalized. IdToIndexMap[ID].push_back(std::make_pair(Index, Loc)); Lex.Lex(); - } else if (ParseToken(lltok::kw_guid, "expected 'guid' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseUInt64(VFuncId.GUID)) + } else if (parseToken(lltok::kw_guid, "expected 'guid' here") || + parseToken(lltok::colon, "expected ':' here") || + parseUInt64(VFuncId.GUID)) return true; - if (ParseToken(lltok::comma, "expected ',' here") || - ParseToken(lltok::kw_offset, "expected 'offset' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseUInt64(VFuncId.Offset) || - ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::comma, "expected ',' here") || + parseToken(lltok::kw_offset, "expected 'offset' here") || + parseToken(lltok::colon, "expected ':' here") || + parseUInt64(VFuncId.Offset) || + parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -9148,12 +9185,12 @@ /// ::= 'flags' ':' '(' 'linkage' ':' OptionalLinkageAux ',' /// 'notEligibleToImport' ':' Flag ',' 'live' ':' Flag ',' /// 'dsoLocal' ':' Flag ',' 'canAutoHide' ':' Flag ')' -bool LLParser::ParseGVFlags(GlobalValueSummary::GVFlags &GVFlags) { +bool LLParser::parseGVFlags(GlobalValueSummary::GVFlags &GVFlags) { assert(Lex.getKind() == lltok::kw_flags); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; do { @@ -9161,7 +9198,7 @@ switch (Lex.getKind()) { case lltok::kw_linkage: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'")) + if (parseToken(lltok::colon, "expected ':'")) return true; bool HasLinkage; GVFlags.Linkage = parseOptionalLinkageAux(Lex.getKind(), HasLinkage); @@ -9170,34 +9207,34 @@ break; case lltok::kw_notEligibleToImport: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseFlag(Flag)) + if (parseToken(lltok::colon, "expected ':'") || parseFlag(Flag)) return true; GVFlags.NotEligibleToImport = Flag; break; case lltok::kw_live: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseFlag(Flag)) + if (parseToken(lltok::colon, "expected ':'") || parseFlag(Flag)) return true; GVFlags.Live = Flag; break; case lltok::kw_dsoLocal: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseFlag(Flag)) + if (parseToken(lltok::colon, "expected ':'") || parseFlag(Flag)) return true; GVFlags.DSOLocal = Flag; break; case lltok::kw_canAutoHide: Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'") || ParseFlag(Flag)) + if (parseToken(lltok::colon, "expected ':'") || parseFlag(Flag)) return true; GVFlags.CanAutoHide = Flag; break; default: - return Error(Lex.getLoc(), "expected gv flag type"); + return error(Lex.getLoc(), "expected gv flag type"); } } while (EatIfPresent(lltok::comma)); - if (ParseToken(lltok::rparen, "expected ')' here")) + if (parseToken(lltok::rparen, "expected ')' here")) return true; return false; @@ -9207,58 +9244,58 @@ /// ::= 'varFlags' ':' '(' 'readonly' ':' Flag /// ',' 'writeonly' ':' Flag /// ',' 'constant' ':' Flag ')' -bool LLParser::ParseGVarFlags(GlobalVarSummary::GVarFlags &GVarFlags) { +bool LLParser::parseGVarFlags(GlobalVarSummary::GVarFlags &GVarFlags) { assert(Lex.getKind() == lltok::kw_varFlags); Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::lparen, "expected '(' here")) + if (parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::lparen, "expected '(' here")) return true; - auto ParseRest = [this](unsigned int &Val) { + auto parseRest = [this](unsigned int &Val) { Lex.Lex(); - if (ParseToken(lltok::colon, "expected ':'")) + if (parseToken(lltok::colon, "expected ':'")) return true; - return ParseFlag(Val); + return parseFlag(Val); }; do { unsigned Flag = 0; switch (Lex.getKind()) { case lltok::kw_readonly: - if (ParseRest(Flag)) + if (parseRest(Flag)) return true; GVarFlags.MaybeReadOnly = Flag; break; case lltok::kw_writeonly: - if (ParseRest(Flag)) + if (parseRest(Flag)) return true; GVarFlags.MaybeWriteOnly = Flag; break; case lltok::kw_constant: - if (ParseRest(Flag)) + if (parseRest(Flag)) return true; GVarFlags.Constant = Flag; break; case lltok::kw_vcall_visibility: - if (ParseRest(Flag)) + if (parseRest(Flag)) return true; GVarFlags.VCallVisibility = Flag; break; default: - return Error(Lex.getLoc(), "expected gvar flag type"); + return error(Lex.getLoc(), "expected gvar flag type"); } } while (EatIfPresent(lltok::comma)); - return ParseToken(lltok::rparen, "expected ')' here"); + return parseToken(lltok::rparen, "expected ')' here"); } /// ModuleReference /// ::= 'module' ':' UInt -bool LLParser::ParseModuleReference(StringRef &ModulePath) { - // Parse module id. - if (ParseToken(lltok::kw_module, "expected 'module' here") || - ParseToken(lltok::colon, "expected ':' here") || - ParseToken(lltok::SummaryID, "expected module ID")) +bool LLParser::parseModuleReference(StringRef &ModulePath) { + // parse module id. + if (parseToken(lltok::kw_module, "expected 'module' here") || + parseToken(lltok::colon, "expected ':' here") || + parseToken(lltok::SummaryID, "expected module ID")) return true; unsigned ModuleID = Lex.getUIntVal(); @@ -9271,11 +9308,11 @@ /// GVReference /// ::= SummaryID -bool LLParser::ParseGVReference(ValueInfo &VI, unsigned &GVId) { +bool LLParser::parseGVReference(ValueInfo &VI, unsigned &GVId) { bool WriteOnly = false, ReadOnly = EatIfPresent(lltok::kw_readonly); if (!ReadOnly) WriteOnly = EatIfPresent(lltok::kw_writeonly); - if (ParseToken(lltok::SummaryID, "expected GV ID")) + if (parseToken(lltok::SummaryID, "expected GV ID")) return true; GVId = Lex.getUIntVal(); Index: llvm/lib/Bitcode/Reader/MetadataLoader.cpp =================================================================== --- llvm/lib/Bitcode/Reader/MetadataLoader.cpp +++ llvm/lib/Bitcode/Reader/MetadataLoader.cpp @@ -875,6 +875,7 @@ case bitc::METADATA_OBJC_PROPERTY: case bitc::METADATA_IMPORTED_ENTITY: case bitc::METADATA_GLOBAL_VAR_EXPR: + case bitc::METADATA_GENERIC_SUBRANGE: // We don't expect to see any of these, if we see one, give up on // lazy-loading and fallback. MDStringRef.clear(); @@ -1371,6 +1372,18 @@ NextMetadataNo++; break; } + case bitc::METADATA_GENERIC_SUBRANGE: { + Metadata *Val = nullptr; + Val = GET_OR_DISTINCT(DIGenericSubrange, + (Context, getMDOrNull(Record[1]), + getMDOrNull(Record[2]), getMDOrNull(Record[3]), + getMDOrNull(Record[4]))); + + MetadataList.assignValue(Val, NextMetadataNo); + IsDistinct = Record[0] & 1; + NextMetadataNo++; + break; + } case bitc::METADATA_ENUMERATOR: { if (Record.size() < 3) return error("Invalid record"); Index: llvm/lib/Bitcode/Writer/BitcodeWriter.cpp =================================================================== --- llvm/lib/Bitcode/Writer/BitcodeWriter.cpp +++ llvm/lib/Bitcode/Writer/BitcodeWriter.cpp @@ -300,6 +300,9 @@ SmallVectorImpl &Record, unsigned &Abbrev); void writeDISubrange(const DISubrange *N, SmallVectorImpl &Record, unsigned Abbrev); + void writeDIGenericSubrange(const DIGenericSubrange *N, + SmallVectorImpl &Record, + unsigned Abbrev); void writeDIEnumerator(const DIEnumerator *N, SmallVectorImpl &Record, unsigned Abbrev); void writeDIBasicType(const DIBasicType *N, SmallVectorImpl &Record, @@ -1549,6 +1552,19 @@ Record.clear(); } +void ModuleBitcodeWriter::writeDIGenericSubrange( + const DIGenericSubrange *N, SmallVectorImpl &Record, + unsigned Abbrev) { + Record.push_back((uint64_t)N->isDistinct()); + Record.push_back(VE.getMetadataOrNullID(N->getRawCountNode())); + Record.push_back(VE.getMetadataOrNullID(N->getRawLowerBound())); + Record.push_back(VE.getMetadataOrNullID(N->getRawUpperBound())); + Record.push_back(VE.getMetadataOrNullID(N->getRawStride())); + + Stream.EmitRecord(bitc::METADATA_GENERIC_SUBRANGE, Record, Abbrev); + Record.clear(); +} + static void emitSignedInt64(SmallVectorImpl &Vals, uint64_t V) { if ((int64_t)V >= 0) Vals.push_back(V << 1); Index: llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp =================================================================== --- llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp +++ llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp @@ -812,6 +812,19 @@ if (auto ST = Subrange->getStride()) if (auto *Dependency = ST.dyn_cast()) Result.push_back(Dependency); + } else if (auto *GenericSubrange = dyn_cast(El)) { + if (auto Count = GenericSubrange->getCount()) + if (auto *Dependency = Count.dyn_cast()) + Result.push_back(Dependency); + if (auto LB = GenericSubrange->getLowerBound()) + if (auto *Dependency = LB.dyn_cast()) + Result.push_back(Dependency); + if (auto UB = GenericSubrange->getUpperBound()) + if (auto *Dependency = UB.dyn_cast()) + Result.push_back(Dependency); + if (auto ST = GenericSubrange->getStride()) + if (auto *Dependency = ST.dyn_cast()) + Result.push_back(Dependency); } } return Result; Index: llvm/lib/CodeGen/AsmPrinter/DwarfUnit.h =================================================================== --- llvm/lib/CodeGen/AsmPrinter/DwarfUnit.h +++ llvm/lib/CodeGen/AsmPrinter/DwarfUnit.h @@ -300,6 +300,8 @@ void constructTypeDIE(DIE &Buffer, const DIDerivedType *DTy); void constructTypeDIE(DIE &Buffer, const DISubroutineType *CTy); void constructSubrangeDIE(DIE &Buffer, const DISubrange *SR, DIE *IndexTy); + void constructGenericSubrangeDIE(DIE &Buffer, const DIGenericSubrange *SR, + DIE *IndexTy); void constructArrayTypeDIE(DIE &Buffer, const DICompositeType *CTy); void constructEnumTypeDIE(DIE &Buffer, const DICompositeType *CTy); DIE &constructMemberDIE(DIE &Buffer, const DIDerivedType *DT); Index: llvm/lib/CodeGen/AsmPrinter/DwarfUnit.cpp =================================================================== --- llvm/lib/CodeGen/AsmPrinter/DwarfUnit.cpp +++ llvm/lib/CodeGen/AsmPrinter/DwarfUnit.cpp @@ -1357,7 +1357,7 @@ if (auto *CI = SR->getCount().dyn_cast()) Count = CI->getSExtValue(); - auto addBoundTypeEntry = [&](dwarf::Attribute Attr, + auto AddBoundTypeEntry = [&](dwarf::Attribute Attr, DISubrange::BoundType Bound) -> void { if (auto *BV = Bound.dyn_cast()) { if (auto *VarDIE = getDIE(BV)) @@ -1375,7 +1375,7 @@ } }; - addBoundTypeEntry(dwarf::DW_AT_lower_bound, SR->getLowerBound()); + AddBoundTypeEntry(dwarf::DW_AT_lower_bound, SR->getLowerBound()); if (auto *CV = SR->getCount().dyn_cast()) { if (auto *CountVarDIE = getDIE(CV)) @@ -1383,9 +1383,46 @@ } else if (Count != -1) addUInt(DW_Subrange, dwarf::DW_AT_count, None, Count); - addBoundTypeEntry(dwarf::DW_AT_upper_bound, SR->getUpperBound()); + AddBoundTypeEntry(dwarf::DW_AT_upper_bound, SR->getUpperBound()); - addBoundTypeEntry(dwarf::DW_AT_byte_stride, SR->getStride()); + AddBoundTypeEntry(dwarf::DW_AT_byte_stride, SR->getStride()); +} + +void DwarfUnit::constructGenericSubrangeDIE(DIE &Buffer, + const DIGenericSubrange *GSR, + DIE *IndexTy) { + DIE &DwGenericSubrange = + createAndAddDIE(dwarf::DW_TAG_generic_subrange, Buffer); + addDIEEntry(DwGenericSubrange, dwarf::DW_AT_type, *IndexTy); + + int64_t DefaultLowerBound = getDefaultLowerBound(); + + auto AddBoundTypeEntry = [&](dwarf::Attribute Attr, + DISubrange::BoundType Bound) -> void { + if (auto *BV = Bound.dyn_cast()) { + if (auto *VarDIE = getDIE(BV)) + addDIEEntry(DwGenericSubrange, Attr, *VarDIE); + } else if (auto *BE = Bound.dyn_cast()) { + DIELoc *Loc = new (DIEValueAllocator) DIELoc; + DIEDwarfExpression DwarfExpr(*Asm, getCU(), *Loc); + DwarfExpr.setMemoryLocationKind(); + DwarfExpr.addExpression(BE); + addBlock(DwGenericSubrange, Attr, DwarfExpr.finalize()); + } else if (auto *BI = Bound.dyn_cast()) { + if (Attr != dwarf::DW_AT_lower_bound || DefaultLowerBound == -1 || + BI->getSExtValue() != DefaultLowerBound) + addSInt(DwGenericSubrange, Attr, dwarf::DW_FORM_sdata, + BI->getSExtValue()); + } + }; + + AddBoundTypeEntry(dwarf::DW_AT_lower_bound, GSR->getLowerBound()); + + AddBoundTypeEntry(dwarf::DW_AT_count, GSR->getCount()); + + AddBoundTypeEntry(dwarf::DW_AT_upper_bound, GSR->getUpperBound()); + + AddBoundTypeEntry(dwarf::DW_AT_byte_stride, GSR->getStride()); } DIE *DwarfUnit::getIndexTyDie() { @@ -1495,9 +1532,13 @@ DINodeArray Elements = CTy->getElements(); for (unsigned i = 0, N = Elements.size(); i < N; ++i) { // FIXME: Should this really be such a loose cast? - if (auto *Element = dyn_cast_or_null(Elements[i])) + if (auto *Element = dyn_cast_or_null(Elements[i])) { if (Element->getTag() == dwarf::DW_TAG_subrange_type) constructSubrangeDIE(Buffer, cast(Element), IdxTy); + else if (Element->getTag() == dwarf::DW_TAG_generic_subrange) + constructGenericSubrangeDIE(Buffer, cast(Element), + IdxTy); + } } } Index: llvm/lib/IR/AsmWriter.cpp =================================================================== --- llvm/lib/IR/AsmWriter.cpp +++ llvm/lib/IR/AsmWriter.cpp @@ -1899,6 +1899,47 @@ Out << ")"; } +static void writeDIGenericSubrange(raw_ostream &Out, const DIGenericSubrange *N, + TypePrinting *TypePrinter, + SlotTracker *Machine, + const Module *Context) { + Out << "!DIGenericSubrange("; + MDFieldPrinter Printer(Out, TypePrinter, Machine, Context); + + auto *Count = N->getRawCountNode(); + if (auto *CE = dyn_cast_or_null(Count)) { + auto *CV = cast(CE->getValue()); + Printer.printInt("count", CV->getSExtValue(), + /* ShouldSkipZero */ false); + } else + Printer.printMetadata("count", Count, /*ShouldSkipNull */ true); + + auto *LBound = N->getRawLowerBound(); + if (auto *LE = dyn_cast_or_null(LBound)) { + auto *LV = cast(LE->getValue()); + Printer.printInt("lowerBound", LV->getSExtValue(), + /* ShouldSkipZero */ false); + } else + Printer.printMetadata("lowerBound", LBound, /*ShouldSkipNull */ true); + + auto *UBound = N->getRawUpperBound(); + if (auto *UE = dyn_cast_or_null(UBound)) { + auto *UV = cast(UE->getValue()); + Printer.printInt("upperBound", UV->getSExtValue(), + /* ShouldSkipZero */ false); + } else + Printer.printMetadata("upperBound", UBound, /*ShouldSkipNull */ true); + + auto *Stride = N->getRawStride(); + if (auto *SE = dyn_cast_or_null(Stride)) { + auto *SV = cast(SE->getValue()); + Printer.printInt("stride", SV->getSExtValue(), /* ShouldSkipZero */ false); + } else + Printer.printMetadata("stride", Stride, /*ShouldSkipNull */ true); + + Out << ")"; +} + static void writeDIEnumerator(raw_ostream &Out, const DIEnumerator *N, TypePrinting *, SlotTracker *, const Module *) { Out << "!DIEnumerator("; Index: llvm/lib/IR/DIBuilder.cpp =================================================================== --- llvm/lib/IR/DIBuilder.cpp +++ llvm/lib/IR/DIBuilder.cpp @@ -649,6 +649,13 @@ return DISubrange::get(VMContext, CountNode, LB, UB, Stride); } +DIGenericSubrange *DIBuilder::getOrCreateGenericSubrange(Metadata *CountNode, + Metadata *LB, + Metadata *UB, + Metadata *Stride) { + return DIGenericSubrange::get(VMContext, CountNode, LB, UB, Stride); +} + static void checkGlobalVariableScope(DIScope *Context) { #ifndef NDEBUG if (auto *CT = Index: llvm/lib/IR/DebugInfoMetadata.cpp =================================================================== --- llvm/lib/IR/DebugInfoMetadata.cpp +++ llvm/lib/IR/DebugInfoMetadata.cpp @@ -435,6 +435,100 @@ return BoundType(); } +DIGenericSubrange *DIGenericSubrange::getImpl(LLVMContext &Context, + Metadata *CountNode, Metadata *LB, + Metadata *UB, Metadata *Stride, + StorageType Storage, + bool ShouldCreate) { + DEFINE_GETIMPL_LOOKUP(DIGenericSubrange, (CountNode, LB, UB, Stride)); + Metadata *Ops[] = {CountNode, LB, UB, Stride}; + DEFINE_GETIMPL_STORE_NO_CONSTRUCTOR_ARGS(DIGenericSubrange, Ops); +} + +DIGenericSubrange::BoundType DIGenericSubrange::getCount() const { + Metadata *CB = getRawCountNode(); + if (!CB) + return BoundType(); + + assert((isa(CB) || isa(CB) || + isa(CB)) && + "Count must be signed constant or DIVariable or DIExpression"); + + if (auto *MD = dyn_cast(CB)) + return BoundType(cast(MD->getValue())); + + if (auto *MD = dyn_cast(CB)) + return BoundType(MD); + + if (auto *MD = dyn_cast(CB)) + return BoundType(MD); + + return BoundType(); +} + +DIGenericSubrange::BoundType DIGenericSubrange::getLowerBound() const { + Metadata *LB = getRawLowerBound(); + if (!LB) + return BoundType(); + + assert((isa(LB) || isa(LB) || + isa(LB)) && + "LowerBound must be signed constant or DIVariable or DIExpression"); + + if (auto *MD = dyn_cast(LB)) + return BoundType(cast(MD->getValue())); + + if (auto *MD = dyn_cast(LB)) + return BoundType(MD); + + if (auto *MD = dyn_cast(LB)) + return BoundType(MD); + + return BoundType(); +} + +DIGenericSubrange::BoundType DIGenericSubrange::getUpperBound() const { + Metadata *UB = getRawUpperBound(); + if (!UB) + return BoundType(); + + assert((isa(UB) || isa(UB) || + isa(UB)) && + "UpperBound must be signed constant or DIVariable or DIExpression"); + + if (auto *MD = dyn_cast(UB)) + return BoundType(cast(MD->getValue())); + + if (auto *MD = dyn_cast(UB)) + return BoundType(MD); + + if (auto *MD = dyn_cast(UB)) + return BoundType(MD); + + return BoundType(); +} + +DIGenericSubrange::BoundType DIGenericSubrange::getStride() const { + Metadata *ST = getRawStride(); + if (!ST) + return BoundType(); + + assert((isa(ST) || isa(ST) || + isa(ST)) && + "Stride must be signed constant or DIVariable or DIExpression"); + + if (auto *MD = dyn_cast(ST)) + return BoundType(cast(MD->getValue())); + + if (auto *MD = dyn_cast(ST)) + return BoundType(MD); + + if (auto *MD = dyn_cast(ST)) + return BoundType(MD); + + return BoundType(); +} + DIEnumerator *DIEnumerator::getImpl(LLVMContext &Context, const APInt &Value, bool IsUnsigned, MDString *Name, StorageType Storage, bool ShouldCreate) { Index: llvm/lib/IR/LLVMContextImpl.h =================================================================== --- llvm/lib/IR/LLVMContextImpl.h +++ llvm/lib/IR/LLVMContextImpl.h @@ -346,6 +346,51 @@ } }; +template <> struct MDNodeKeyImpl { + Metadata *CountNode; + Metadata *LowerBound; + Metadata *UpperBound; + Metadata *Stride; + + MDNodeKeyImpl(Metadata *CountNode, Metadata *LowerBound, Metadata *UpperBound, + Metadata *Stride) + : CountNode(CountNode), LowerBound(LowerBound), UpperBound(UpperBound), + Stride(Stride) {} + MDNodeKeyImpl(const DIGenericSubrange *N) + : CountNode(N->getRawCountNode()), LowerBound(N->getRawLowerBound()), + UpperBound(N->getRawUpperBound()), Stride(N->getRawStride()) {} + + bool isKeyOf(const DIGenericSubrange *RHS) const { + auto BoundsEqual = [=](Metadata *Node1, Metadata *Node2) -> bool { + if (Node1 == Node2) + return true; + + ConstantAsMetadata *MD1 = dyn_cast_or_null(Node1); + ConstantAsMetadata *MD2 = dyn_cast_or_null(Node2); + if (MD1 && MD2) { + ConstantInt *CV1 = cast(MD1->getValue()); + ConstantInt *CV2 = cast(MD2->getValue()); + if (CV1->getSExtValue() == CV2->getSExtValue()) + return true; + } + return false; + }; + + return BoundsEqual(CountNode, RHS->getRawCountNode()) && + BoundsEqual(LowerBound, RHS->getRawLowerBound()) && + BoundsEqual(UpperBound, RHS->getRawUpperBound()) && + BoundsEqual(Stride, RHS->getRawStride()); + } + + unsigned getHashValue() const { + if (CountNode) + if (auto *MD = dyn_cast(CountNode)) + return hash_combine(cast(MD->getValue())->getSExtValue(), + LowerBound, UpperBound, Stride); + return hash_combine(CountNode, LowerBound, UpperBound, Stride); + } +}; + template <> struct MDNodeKeyImpl { APInt Value; MDString *Name; Index: llvm/lib/IR/Verifier.cpp =================================================================== --- llvm/lib/IR/Verifier.cpp +++ llvm/lib/IR/Verifier.cpp @@ -926,6 +926,34 @@ "Stride must be signed constant or DIVariable or DIExpression", &N); } +void Verifier::visitDIGenericSubrange(const DIGenericSubrange &N) { + AssertDI(N.getTag() == dwarf::DW_TAG_generic_subrange, "invalid tag", &N); + AssertDI(N.getRawCountNode() || N.getRawUpperBound(), + "GenericSubrange must contain count or upperBound", &N); + AssertDI(!N.getRawCountNode() || !N.getRawUpperBound(), + "GenericSubrange can have any one of count or upperBound", &N); + auto *CBound = N.getRawCountNode(); + AssertDI(!CBound || isa(CBound) || + isa(CBound) || isa(CBound), + "Count must be signed constant or DIVariable or DIExpression", &N); + auto *LBound = N.getRawLowerBound(); + AssertDI(LBound, "GenericSubrange must contain lowerBound", &N); + AssertDI(isa(LBound) || isa(LBound) || + isa(LBound), + "LowerBound must be signed constant or DIVariable or DIExpression", + &N); + auto *UBound = N.getRawUpperBound(); + AssertDI(!UBound || isa(UBound) || + isa(UBound) || isa(UBound), + "UpperBound must be signed constant or DIVariable or DIExpression", + &N); + auto *Stride = N.getRawStride(); + AssertDI(Stride, "GenericSubrange must contain stride", &N); + AssertDI(isa(Stride) || isa(Stride) || + isa(Stride), + "Stride must be signed constant or DIVariable or DIExpression", &N); +} + void Verifier::visitDIEnumerator(const DIEnumerator &N) { AssertDI(N.getTag() == dwarf::DW_TAG_enumerator, "invalid tag", &N); } Index: llvm/test/Bitcode/generic_subrange.ll =================================================================== --- /dev/null +++ llvm/test/Bitcode/generic_subrange.ll @@ -0,0 +1,35 @@ +;; This test checks generation of DIGenericSubrange. + +; RUN: llvm-as < %s | llvm-dis | llvm-as | llvm-dis | FileCheck %s + +;; Test whether DIGenericSubrange is generated. +; CHECK: !DIGenericSubrange(lowerBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 80, DW_OP_plus, DW_OP_deref), upperBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 120, DW_OP_plus, DW_OP_deref), stride: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 112, DW_OP_plus, DW_OP_deref, DW_OP_constu, 4, DW_OP_mul)) + +; ModuleID = 'generic_subrange.f90' +source_filename = "/dir/generic_subrange.ll" + +!llvm.module.flags = !{!0, !1} +!llvm.dbg.cu = !{!2} + +!0 = !{i32 2, !"Dwarf Version", i32 4} +!1 = !{i32 2, !"Debug Info Version", i32 3} +!2 = distinct !DICompileUnit(language: DW_LANG_Fortran90, file: !3, producer: " F90 Flang - 1.5 2017-05-01", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !4, retainedTypes: !5, globals: !4, imports: !4) +!3 = !DIFile(filename: "generic_subrange.f90", directory: "/dir") +!4 = !{} +!5 = !{!6} +!6 = !DICompositeType(tag: DW_TAG_array_type, baseType: !7, size: 32, align: 32, elements: !8, dataLocation: !10, rank: !DIExpression(DW_OP_push_object_address, DW_OP_plus_uconst, 8, DW_OP_deref)) +!7 = !DIBasicType(name: "real", size: 32, align: 32, encoding: DW_ATE_float) +!8 = !{!9} +!9 = !DIGenericSubrange(lowerBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 80, DW_OP_plus, DW_OP_deref), upperBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 120, DW_OP_plus, DW_OP_deref), stride: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 112, DW_OP_plus, DW_OP_deref, DW_OP_constu, 4, DW_OP_mul)) +!10 = distinct !DILocalVariable(scope: !11, file: !3, type: !18, flags: DIFlagArtificial) +!11 = distinct !DISubprogram(name: "sub1", scope: !2, file: !3, line: 1, type: !12, scopeLine: 1, spFlags: DISPFlagDefinition, unit: !2) +!12 = !DISubroutineType(types: !13) +!13 = !{null, !14, !19} +!14 = !DICompositeType(tag: DW_TAG_array_type, baseType: !7, size: 32, align: 32, elements: !15) +!15 = !{!16} +!16 = !DISubrange(lowerBound: 1, upperBound: !17) +!17 = distinct !DILocalVariable(scope: !11, file: !3, type: !18, flags: DIFlagArtificial) +!18 = !DIBasicType(name: "integer*8", size: 64, align: 64, encoding: DW_ATE_signed) +!19 = !DICompositeType(tag: DW_TAG_array_type, baseType: !18, size: 1024, align: 64, elements: !20) +!20 = !{!21} +!21 = !DISubrange(lowerBound: 1, upperBound: 16) Index: llvm/test/Bitcode/generic_subrange_count.ll =================================================================== --- /dev/null +++ llvm/test/Bitcode/generic_subrange_count.ll @@ -0,0 +1,35 @@ +;; This test checks generation of DIGenericSubrange. + +; RUN: llvm-as < %s | llvm-dis | llvm-as | llvm-dis | FileCheck %s + +;; Test whether DIGenericSubrange is generated. +; CHECK: !DIGenericSubrange(count: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 88, DW_OP_plus, DW_OP_deref), lowerBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 80, DW_OP_plus, DW_OP_deref), stride: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 112, DW_OP_plus, DW_OP_deref, DW_OP_constu, 4, DW_OP_mul)) + +; ModuleID = 'generic_subrange.f90' +source_filename = "/dir/generic_subrange.ll" + +!llvm.module.flags = !{!0, !1} +!llvm.dbg.cu = !{!2} + +!0 = !{i32 2, !"Dwarf Version", i32 4} +!1 = !{i32 2, !"Debug Info Version", i32 3} +!2 = distinct !DICompileUnit(language: DW_LANG_Fortran90, file: !3, producer: " F90 Flang - 1.5 2017-05-01", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !4, retainedTypes: !5, globals: !4, imports: !4) +!3 = !DIFile(filename: "generic_subrange.f90", directory: "/dir") +!4 = !{} +!5 = !{!6} +!6 = !DICompositeType(tag: DW_TAG_array_type, baseType: !7, size: 32, align: 32, elements: !8, dataLocation: !10, rank: !DIExpression(DW_OP_push_object_address, DW_OP_plus_uconst, 8, DW_OP_deref)) +!7 = !DIBasicType(name: "real", size: 32, align: 32, encoding: DW_ATE_float) +!8 = !{!9} +!9 = !DIGenericSubrange(count: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 88, DW_OP_plus, DW_OP_deref), lowerBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 80, DW_OP_plus, DW_OP_deref), stride: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 112, DW_OP_plus, DW_OP_deref, DW_OP_constu, 4, DW_OP_mul)) +!10 = distinct !DILocalVariable(scope: !11, file: !3, type: !18, flags: DIFlagArtificial) +!11 = distinct !DISubprogram(name: "sub1", scope: !2, file: !3, line: 1, type: !12, scopeLine: 1, spFlags: DISPFlagDefinition, unit: !2) +!12 = !DISubroutineType(types: !13) +!13 = !{null, !14, !19} +!14 = !DICompositeType(tag: DW_TAG_array_type, baseType: !7, size: 32, align: 32, elements: !15) +!15 = !{!16} +!16 = !DISubrange(lowerBound: 1, upperBound: !17) +!17 = distinct !DILocalVariable(scope: !11, file: !3, type: !18, flags: DIFlagArtificial) +!18 = !DIBasicType(name: "integer*8", size: 64, align: 64, encoding: DW_ATE_signed) +!19 = !DICompositeType(tag: DW_TAG_array_type, baseType: !18, size: 1024, align: 64, elements: !20) +!20 = !{!21} +!21 = !DISubrange(lowerBound: 1, upperBound: 16) Index: llvm/test/DebugInfo/X86/dwarfdump-generic_subrange.ll =================================================================== --- /dev/null +++ llvm/test/DebugInfo/X86/dwarfdump-generic_subrange.ll @@ -0,0 +1,65 @@ +;; This test checks whether DW_AT_rank attribute accepts DIExpression. + +; RUN: llc %s -filetype=obj -o - | llvm-dwarfdump - | FileCheck %s + +;; Test whether DW_AT_data_location is generated. +; CHECK-LABEL: DW_TAG_array_type + +; CHECK: DW_AT_rank (DW_OP_push_object_address, DW_OP_plus_uconst 0x8, DW_OP_deref) +; CHECK: DW_TAG_generic_subrange +; CHECK: DW_AT_lower_bound (DW_OP_push_object_address, DW_OP_over, DW_OP_constu 0x30, DW_OP_mul, DW_OP_plus_uconst 0x50, DW_OP_plus, DW_OP_deref) +; CHECK: DW_AT_upper_bound (DW_OP_push_object_address, DW_OP_over, DW_OP_constu 0x30, DW_OP_mul, DW_OP_plus_uconst 0x78, DW_OP_plus, DW_OP_deref) +; CHECK: DW_AT_byte_stride (DW_OP_push_object_address, DW_OP_over, DW_OP_constu 0x30, DW_OP_mul, DW_OP_plus_uconst 0x70, DW_OP_plus, DW_OP_deref, DW_OP_lit4, DW_OP_mul) + +;; Test case is hand written with the help of below testcase +;;------------------------------ +;;subroutine sub(arank) +;; real :: arank(..) +;; print *, RANK(arank) +;;end +;;------------------------------ + +; ModuleID = 'dwarfdump-rank.ll' +source_filename = "dwarfdump-rank.ll" + +define void @sub_(i64* noalias %arank, i64* noalias %"arank$sd") !dbg !5 { +L.entry: + call void @llvm.dbg.value(metadata i64* %arank, metadata !17, metadata !DIExpression()), !dbg !18 + call void @llvm.dbg.declare(metadata i64* %"arank$sd", metadata !19, metadata !DIExpression()), !dbg !18 + call void @llvm.dbg.declare(metadata i64* %"arank$sd", metadata !29, metadata !DIExpression()), !dbg !18 + ret void, !dbg !18 +} + +; Function Attrs: nounwind readnone speculatable willreturn +declare void @llvm.dbg.declare(metadata, metadata, metadata) + +; Function Attrs: nounwind readnone speculatable willreturn +declare void @llvm.dbg.value(metadata, metadata, metadata) + +!llvm.module.flags = !{!0, !1} +!llvm.dbg.cu = !{!2} + +!0 = !{i32 2, !"Dwarf Version", i32 4} +!1 = !{i32 2, !"Debug Info Version", i32 3} +!2 = distinct !DICompileUnit(language: DW_LANG_Fortran90, file: !3, producer: " F90 Flang - 1.5 2017-05-01", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !4, retainedTypes: !4, globals: !4, imports: !4) +!3 = !DIFile(filename: "generic_subrange.f90", directory: "/dir") +!4 = !{} +!5 = distinct !DISubprogram(name: "sub", scope: !2, file: !3, line: 1, type: !6, scopeLine: 1, spFlags: DISPFlagDefinition, unit: !2) +!6 = !DISubroutineType(types: !7) +!7 = !{null, !8, !14} +!8 = !DICompositeType(tag: DW_TAG_array_type, baseType: !9, size: 32, align: 32, elements: !10) +!9 = !DIBasicType(name: "real", size: 32, align: 32, encoding: DW_ATE_float) +!10 = !{!11} +!11 = !DISubrange(lowerBound: 1, upperBound: !12) +!12 = distinct !DILocalVariable(scope: !5, file: !3, type: !13, flags: DIFlagArtificial) +!13 = !DIBasicType(name: "integer*8", size: 64, align: 64, encoding: DW_ATE_signed) +!14 = !DICompositeType(tag: DW_TAG_array_type, baseType: !13, size: 1024, align: 64, elements: !15) +!15 = !{!16} +!16 = !DISubrange(lowerBound: 1, upperBound: 16) +!17 = distinct !DILocalVariable(scope: !5, file: !3, type: !13, flags: DIFlagArtificial) +!18 = !DILocation(line: 0, scope: !5) +!19 = !DILocalVariable(name: "arank", arg: 1, scope: !5, file: !3, line: 1, type: !20) +!20 = !DICompositeType(tag: DW_TAG_array_type, baseType: !9, size: 32, align: 32, elements: !21, dataLocation: !17, rank: !DIExpression(DW_OP_push_object_address, DW_OP_plus_uconst, 8, DW_OP_deref)) +!21 = !{!22} +!22 = !DIGenericSubrange(lowerBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 80, DW_OP_plus, DW_OP_deref), upperBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 120, DW_OP_plus, DW_OP_deref), stride: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 112, DW_OP_plus, DW_OP_deref, DW_OP_constu, 4, DW_OP_mul)) +!29 = !DILocalVariable(arg: 2, scope: !5, file: !3, line: 1, type: !14, flags: DIFlagArtificial) Index: llvm/test/DebugInfo/X86/dwarfdump-generic_subrange_count.ll =================================================================== --- /dev/null +++ llvm/test/DebugInfo/X86/dwarfdump-generic_subrange_count.ll @@ -0,0 +1,65 @@ +;; This test checks whether DW_AT_rank attribute accepts DIExpression. + +; RUN: llc %s -filetype=obj -o - | llvm-dwarfdump - | FileCheck %s + +;; Test whether DW_AT_data_location is generated. +; CHECK-LABEL: DW_TAG_array_type + +; CHECK: DW_AT_rank (DW_OP_push_object_address, DW_OP_plus_uconst 0x8, DW_OP_deref) +; CHECK: DW_TAG_generic_subrange +; CHECK: DW_AT_lower_bound (DW_OP_push_object_address, DW_OP_over, DW_OP_constu 0x30, DW_OP_mul, DW_OP_plus_uconst 0x50, DW_OP_plus, DW_OP_deref) +; CHECK: DW_AT_count (DW_OP_push_object_address, DW_OP_over, DW_OP_constu 0x30, DW_OP_mul, DW_OP_plus_uconst 0x58, DW_OP_plus, DW_OP_deref) +; CHECK: DW_AT_byte_stride (DW_OP_push_object_address, DW_OP_over, DW_OP_constu 0x30, DW_OP_mul, DW_OP_plus_uconst 0x70, DW_OP_plus, DW_OP_deref, DW_OP_lit4, DW_OP_mul) + +;; Test case is hand written with the help of below testcase +;;------------------------------ +;;subroutine sub(arank) +;; real :: arank(..) +;; print *, RANK(arank) +;;end +;;------------------------------ + +; ModuleID = 'dwarfdump-rank.ll' +source_filename = "dwarfdump-rank.ll" + +define void @sub_(i64* noalias %arank, i64* noalias %"arank$sd") !dbg !5 { +L.entry: + call void @llvm.dbg.value(metadata i64* %arank, metadata !17, metadata !DIExpression()), !dbg !18 + call void @llvm.dbg.declare(metadata i64* %"arank$sd", metadata !19, metadata !DIExpression()), !dbg !18 + call void @llvm.dbg.declare(metadata i64* %"arank$sd", metadata !29, metadata !DIExpression()), !dbg !18 + ret void, !dbg !18 +} + +; Function Attrs: nounwind readnone speculatable willreturn +declare void @llvm.dbg.declare(metadata, metadata, metadata) + +; Function Attrs: nounwind readnone speculatable willreturn +declare void @llvm.dbg.value(metadata, metadata, metadata) + +!llvm.module.flags = !{!0, !1} +!llvm.dbg.cu = !{!2} + +!0 = !{i32 2, !"Dwarf Version", i32 4} +!1 = !{i32 2, !"Debug Info Version", i32 3} +!2 = distinct !DICompileUnit(language: DW_LANG_Fortran90, file: !3, producer: " F90 Flang - 1.5 2017-05-01", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !4, retainedTypes: !4, globals: !4, imports: !4) +!3 = !DIFile(filename: "generic_subrange.f90", directory: "/dir") +!4 = !{} +!5 = distinct !DISubprogram(name: "sub", scope: !2, file: !3, line: 1, type: !6, scopeLine: 1, spFlags: DISPFlagDefinition, unit: !2) +!6 = !DISubroutineType(types: !7) +!7 = !{null, !8, !14} +!8 = !DICompositeType(tag: DW_TAG_array_type, baseType: !9, size: 32, align: 32, elements: !10) +!9 = !DIBasicType(name: "real", size: 32, align: 32, encoding: DW_ATE_float) +!10 = !{!11} +!11 = !DISubrange(lowerBound: 1, upperBound: !12) +!12 = distinct !DILocalVariable(scope: !5, file: !3, type: !13, flags: DIFlagArtificial) +!13 = !DIBasicType(name: "integer*8", size: 64, align: 64, encoding: DW_ATE_signed) +!14 = !DICompositeType(tag: DW_TAG_array_type, baseType: !13, size: 1024, align: 64, elements: !15) +!15 = !{!16} +!16 = !DISubrange(lowerBound: 1, upperBound: 16) +!17 = distinct !DILocalVariable(scope: !5, file: !3, type: !13, flags: DIFlagArtificial) +!18 = !DILocation(line: 0, scope: !5) +!19 = !DILocalVariable(name: "arank", arg: 1, scope: !5, file: !3, line: 1, type: !20) +!20 = !DICompositeType(tag: DW_TAG_array_type, baseType: !9, size: 32, align: 32, elements: !21, dataLocation: !17, rank: !DIExpression(DW_OP_push_object_address, DW_OP_plus_uconst, 8, DW_OP_deref)) +!21 = !{!22} +!22 = !DIGenericSubrange(count: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 88, DW_OP_plus, DW_OP_deref), lowerBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 80, DW_OP_plus, DW_OP_deref), stride: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 112, DW_OP_plus, DW_OP_deref, DW_OP_constu, 4, DW_OP_mul)) +!29 = !DILocalVariable(arg: 2, scope: !5, file: !3, line: 1, type: !14, flags: DIFlagArtificial) Index: llvm/test/Verifier/digenericsubrange-count-upperBound.ll =================================================================== --- /dev/null +++ llvm/test/Verifier/digenericsubrange-count-upperBound.ll @@ -0,0 +1,5 @@ +; RUN: not llvm-as < %s -disable-output 2>&1 | FileCheck %s + +!named = !{!0} +; CHECK: GenericSubrange can have any one of count or upperBound +!0 = !DIGenericSubrange(count: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 88, DW_OP_plus, DW_OP_deref), lowerBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 80, DW_OP_plus, DW_OP_deref), upperBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 120, DW_OP_plus, DW_OP_deref), stride: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 112, DW_OP_plus, DW_OP_deref, DW_OP_constu, 4, DW_OP_mul)) Index: llvm/test/Verifier/digenericsubrange-missing-stride.ll =================================================================== --- /dev/null +++ llvm/test/Verifier/digenericsubrange-missing-stride.ll @@ -0,0 +1,5 @@ +; RUN: not llvm-as < %s -disable-output 2>&1 | FileCheck %s + +!named = !{!0} +; CHECK: GenericSubrange must contain stride +!0 = !DIGenericSubrange(lowerBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 80, DW_OP_plus, DW_OP_deref), upperBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 120, DW_OP_plus, DW_OP_deref)) Index: llvm/test/Verifier/digenericsubrange-missing-upperBound.ll =================================================================== --- /dev/null +++ llvm/test/Verifier/digenericsubrange-missing-upperBound.ll @@ -0,0 +1,5 @@ +; RUN: not llvm-as < %s -disable-output 2>&1 | FileCheck %s + +!named = !{!0} +; CHECK: GenericSubrange must contain count or upperBound +!0 = !DIGenericSubrange(lowerBound: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 80, DW_OP_plus, DW_OP_deref), stride: !DIExpression(DW_OP_push_object_address, DW_OP_over, DW_OP_constu, 48, DW_OP_mul, DW_OP_plus_uconst, 112, DW_OP_plus, DW_OP_deref, DW_OP_constu, 4, DW_OP_mul))