diff options
Diffstat (limited to 'llvm/lib/AsmParser')
| -rw-r--r-- | llvm/lib/AsmParser/AsmParserContext.cpp | 89 | ||||
| -rw-r--r-- | llvm/lib/AsmParser/CMakeLists.txt | 1 | ||||
| -rw-r--r-- | llvm/lib/AsmParser/LLLexer.cpp | 2 | ||||
| -rw-r--r-- | llvm/lib/AsmParser/LLParser.cpp | 24 | ||||
| -rw-r--r-- | llvm/lib/AsmParser/Parser.cpp | 31 | 
5 files changed, 132 insertions, 15 deletions
| diff --git a/llvm/lib/AsmParser/AsmParserContext.cpp b/llvm/lib/AsmParser/AsmParserContext.cpp new file mode 100644 index 0000000..59d3ffc --- /dev/null +++ b/llvm/lib/AsmParser/AsmParserContext.cpp @@ -0,0 +1,89 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#include "llvm/AsmParser/AsmParserContext.h" + +namespace llvm { + +std::optional<FileLocRange> +AsmParserContext::getFunctionLocation(const Function *F) const { +  if (auto FIt = Functions.find(F); FIt != Functions.end()) +    return FIt->second; +  return std::nullopt; +} + +std::optional<FileLocRange> +AsmParserContext::getBlockLocation(const BasicBlock *BB) const { +  if (auto BBIt = Blocks.find(BB); BBIt != Blocks.end()) +    return BBIt->second; +  return std::nullopt; +} + +std::optional<FileLocRange> +AsmParserContext::getInstructionLocation(const Instruction *I) const { +  if (auto IIt = Instructions.find(I); IIt != Instructions.end()) +    return IIt->second; +  return std::nullopt; +} + +Function * +AsmParserContext::getFunctionAtLocation(const FileLocRange &Query) const { +  for (auto &[F, Loc] : Functions) { +    if (Loc.contains(Query)) +      return F; +  } +  return nullptr; +} + +Function *AsmParserContext::getFunctionAtLocation(const FileLoc &Query) const { +  return getFunctionAtLocation(FileLocRange(Query, Query)); +} + +BasicBlock * +AsmParserContext::getBlockAtLocation(const FileLocRange &Query) const { +  for (auto &[BB, Loc] : Blocks) { +    if (Loc.contains(Query)) +      return BB; +  } +  return nullptr; +} + +BasicBlock *AsmParserContext::getBlockAtLocation(const FileLoc &Query) const { +  return getBlockAtLocation(FileLocRange(Query, Query)); +} + +Instruction * +AsmParserContext::getInstructionAtLocation(const FileLocRange &Query) const { +  for (auto &[I, Loc] : Instructions) { +    if (Loc.contains(Query)) +      return I; +  } +  return nullptr; +} + +Instruction * +AsmParserContext::getInstructionAtLocation(const FileLoc &Query) const { +  return getInstructionAtLocation(FileLocRange(Query, Query)); +} + +bool AsmParserContext::addFunctionLocation(Function *F, +                                           const FileLocRange &Loc) { +  return Functions.insert({F, Loc}).second; +} + +bool AsmParserContext::addBlockLocation(BasicBlock *BB, +                                        const FileLocRange &Loc) { +  return Blocks.insert({BB, Loc}).second; +} + +bool AsmParserContext::addInstructionLocation(Instruction *I, +                                              const FileLocRange &Loc) { +  return Instructions.insert({I, Loc}).second; +} + +} // namespace llvm diff --git a/llvm/lib/AsmParser/CMakeLists.txt b/llvm/lib/AsmParser/CMakeLists.txt index 20d0c50..dcfcc06 100644 --- a/llvm/lib/AsmParser/CMakeLists.txt +++ b/llvm/lib/AsmParser/CMakeLists.txt @@ -1,5 +1,6 @@  # AsmParser  add_llvm_component_library(LLVMAsmParser +  AsmParserContext.cpp    LLLexer.cpp    LLParser.cpp    Parser.cpp diff --git a/llvm/lib/AsmParser/LLLexer.cpp b/llvm/lib/AsmParser/LLLexer.cpp index 50d1d47..7a6c19e 100644 --- a/llvm/lib/AsmParser/LLLexer.cpp +++ b/llvm/lib/AsmParser/LLLexer.cpp @@ -191,6 +191,8 @@ int LLLexer::getNextChar() {  }  lltok::Kind LLLexer::LexToken() { +  // Set token end to next location, since the end is exclusive. +  PrevTokEnd = CurPtr;    while (true) {      TokStart = CurPtr; diff --git a/llvm/lib/AsmParser/LLParser.cpp b/llvm/lib/AsmParser/LLParser.cpp index f71a534..5164cec 100644 --- a/llvm/lib/AsmParser/LLParser.cpp +++ b/llvm/lib/AsmParser/LLParser.cpp @@ -752,14 +752,21 @@ bool LLParser::parseDeclare() {  ///   ::= 'define' FunctionHeader (!dbg !56)* '{' ...  bool LLParser::parseDefine() {    assert(Lex.getKind() == lltok::kw_define); +  FileLoc FunctionStart(Lex.getTokLineColumnPos());    Lex.Lex();    Function *F;    unsigned FunctionNumber = -1;    SmallVector<unsigned> UnnamedArgNums; -  return parseFunctionHeader(F, true, FunctionNumber, UnnamedArgNums) || -         parseOptionalFunctionMetadata(*F) || -         parseFunctionBody(*F, FunctionNumber, UnnamedArgNums); +  bool RetValue = +      parseFunctionHeader(F, true, FunctionNumber, UnnamedArgNums) || +      parseOptionalFunctionMetadata(*F) || +      parseFunctionBody(*F, FunctionNumber, UnnamedArgNums); +  if (ParserContext) +    ParserContext->addFunctionLocation( +        F, FileLocRange(FunctionStart, Lex.getPrevTokEndLineColumnPos())); + +  return RetValue;  }  /// parseGlobalType @@ -7018,6 +7025,8 @@ bool LLParser::parseFunctionBody(Function &Fn, unsigned FunctionNumber,  /// parseBasicBlock  ///   ::= (LabelStr|LabelID)? Instruction*  bool LLParser::parseBasicBlock(PerFunctionState &PFS) { +  FileLoc BBStart(Lex.getTokLineColumnPos()); +    // If this basic block starts out with a name, remember it.    std::string Name;    int NameID = -1; @@ -7059,6 +7068,7 @@ bool LLParser::parseBasicBlock(PerFunctionState &PFS) {        TrailingDbgRecord.emplace_back(DR, DeleteDbgRecord);      } +    FileLoc InstStart(Lex.getTokLineColumnPos());      // This instruction may have three possibilities for a name: a) none      // specified, b) name specified "%foo =", c) number specified: "%4 =".      LocTy NameLoc = Lex.getLoc(); @@ -7108,8 +7118,16 @@ bool LLParser::parseBasicBlock(PerFunctionState &PFS) {      for (DbgRecordPtr &DR : TrailingDbgRecord)        BB->insertDbgRecordBefore(DR.release(), Inst->getIterator());      TrailingDbgRecord.clear(); +    if (ParserContext) { +      ParserContext->addInstructionLocation( +          Inst, FileLocRange(InstStart, Lex.getPrevTokEndLineColumnPos())); +    }    } while (!Inst->isTerminator()); +  if (ParserContext) +    ParserContext->addBlockLocation( +        BB, FileLocRange(BBStart, Lex.getPrevTokEndLineColumnPos())); +    assert(TrailingDbgRecord.empty() &&           "All debug values should have been attached to an instruction."); diff --git a/llvm/lib/AsmParser/Parser.cpp b/llvm/lib/AsmParser/Parser.cpp index 07fdce9..c5346d0 100644 --- a/llvm/lib/AsmParser/Parser.cpp +++ b/llvm/lib/AsmParser/Parser.cpp @@ -24,33 +24,38 @@ using namespace llvm;  static bool parseAssemblyInto(MemoryBufferRef F, Module *M,                                ModuleSummaryIndex *Index, SMDiagnostic &Err,                                SlotMapping *Slots, bool UpgradeDebugInfo, -                              DataLayoutCallbackTy DataLayoutCallback) { +                              DataLayoutCallbackTy DataLayoutCallback, +                              AsmParserContext *ParserContext = nullptr) {    SourceMgr SM;    std::unique_ptr<MemoryBuffer> Buf = MemoryBuffer::getMemBuffer(F);    SM.AddNewSourceBuffer(std::move(Buf), SMLoc());    std::optional<LLVMContext> OptContext;    return LLParser(F.getBuffer(), SM, Err, M, Index, -                  M ? M->getContext() : OptContext.emplace(), Slots) +                  M ? M->getContext() : OptContext.emplace(), Slots, +                  ParserContext)        .Run(UpgradeDebugInfo, DataLayoutCallback);  }  bool llvm::parseAssemblyInto(MemoryBufferRef F, Module *M,                               ModuleSummaryIndex *Index, SMDiagnostic &Err,                               SlotMapping *Slots, -                             DataLayoutCallbackTy DataLayoutCallback) { +                             DataLayoutCallbackTy DataLayoutCallback, +                             AsmParserContext *ParserContext) {    return ::parseAssemblyInto(F, M, Index, Err, Slots, -                             /*UpgradeDebugInfo*/ true, DataLayoutCallback); +                             /*UpgradeDebugInfo*/ true, DataLayoutCallback, +                             ParserContext);  }  std::unique_ptr<Module>  llvm::parseAssembly(MemoryBufferRef F, SMDiagnostic &Err, LLVMContext &Context, -                    SlotMapping *Slots, -                    DataLayoutCallbackTy DataLayoutCallback) { +                    SlotMapping *Slots, DataLayoutCallbackTy DataLayoutCallback, +                    AsmParserContext *ParserContext) {    std::unique_ptr<Module> M =        std::make_unique<Module>(F.getBufferIdentifier(), Context); -  if (parseAssemblyInto(F, M.get(), nullptr, Err, Slots, DataLayoutCallback)) +  if (parseAssemblyInto(F, M.get(), nullptr, Err, Slots, DataLayoutCallback, +                        ParserContext))      return nullptr;    return M; @@ -133,12 +138,14 @@ ParsedModuleAndIndex llvm::parseAssemblyFileWithIndexNoUpgradeDebugInfo(                                        DataLayoutCallback);  } -std::unique_ptr<Module> llvm::parseAssemblyString(StringRef AsmString, -                                                  SMDiagnostic &Err, -                                                  LLVMContext &Context, -                                                  SlotMapping *Slots) { +std::unique_ptr<Module> +llvm::parseAssemblyString(StringRef AsmString, SMDiagnostic &Err, +                          LLVMContext &Context, SlotMapping *Slots, +                          AsmParserContext *ParserContext) {    MemoryBufferRef F(AsmString, "<string>"); -  return parseAssembly(F, Err, Context, Slots); +  return parseAssembly( +      F, Err, Context, Slots, [](StringRef, StringRef) { return std::nullopt; }, +      ParserContext);  }  static bool parseSummaryIndexAssemblyInto(MemoryBufferRef F, | 
