|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | the type exists.
Fix up cases where we weren't checking for optional types and add
an assert to addType to make sure we catch this in the future.
Fix up a testcase that was using the tag for DW_TAG_array_type
when it meant DW_TAG_enumeration_type.
llvm-svn: 187963 | 
| | 
| 
| 
| | llvm-svn: 187953 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Also remove checking of llvm.dbg.sp since it is not used in generating dwarf.
Current state of Finder:
DebugInfoFinder tries to list all debug info MDNodes used in a module. To
list debug info MDNodes used by an instruction, DebugInfoFinder provides
processDeclare, processValue and processLocation to handle DbgDeclareInst,
DbgValueInst and DbgLoc attached to instructions. processModule will go
through all DICompileUnits in llvm.dbg.cu and list debug info MDNodes
used by the CUs.
TODO:
1> Finder has a list of CUs, SPs, Types, Scopes and global variables. We
need to add a list of variables that are used by DbgDeclareInst and
DbgValueInst.
2> MDString fields should be null or isa<MDString> and MDNode fields should be
null or isa<MDNode>. We currently use empty string or int 0 to represent null.
3> Go though Verify functions and make sure that they check field types.
4> Clean up existing testing cases to remove llvm.dbg.sp and make sure each
testing case has a llvm.dbg.cu.
Re-apply r187609 with fix to pass ocaml binding. vmcore.ml generates a debug
location with scope being metadata !{}, in verifier we treat this as a null
scope.
llvm-svn: 187812 | 
| | 
| 
| 
| 
| 
| 
| 
| | instructions." in an attempt to bring back some bots.
This reverts commit r187609.
llvm-svn: 187638 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Also remove checking of llvm.dbg.sp since it is not used in generating dwarf.
Current state of Finder:
DebugInfoFinder tries to list all debug info MDNodes used in a module. To
list debug info MDNodes used by an instruction, DebugInfoFinder provides
processDeclare, processValue and processLocation to handle DbgDeclareInst,
DbgValueInst and DbgLoc attached to instructions. processModule will go
through all DICompileUnits in llvm.dbg.cu and list debug info MDNodes
used by the CUs.
TODO:
1> Finder has a list of CUs, SPs, Types, Scopes and global variables. We
need to add a list of variables that are used by DbgDeclareInst and
DbgValueInst.
2> MDString fields should be null or isa<MDString> and MDNode fields should be
null or isa<MDNode>. We currently use empty string or int 0 to represent null.
3> Go though Verify functions and make sure that they check field types.
4> Clean up existing testing cases to remove llvm.dbg.sp and make sure each
testing case has a llvm.dbg.cu.
llvm-svn: 187609 | 
| | 
| 
| 
| 
| 
| 
| 
| | Also always add DIType, DISubprogram and DIGlobalVariable to the list
in DebugInfoFinder without checking them, so we can verify them later
on.
llvm-svn: 187285 | 
| | 
| 
| 
| | llvm-svn: 187247 | 
| | 
| 
| 
| 
| 
| 
| 
| | We used to call Verify before adding DICompileUnit to the list, and now we
remove the check and always add DICompileUnit to the list in DebugInfoFinder,
so we can verify them later on.
llvm-svn: 187237 | 
| | 
| 
| 
| | llvm-svn: 187224 | 
| | 
| 
| 
| | llvm-svn: 187212 | 
| | 
| 
| 
| | llvm-svn: 187157 | 
| | 
| 
| 
| 
| 
| 
| | Make sure the context field of DIType is MDNode.
Fix testing cases to make them pass the verifier.
llvm-svn: 187150 | 
| | 
| 
| 
| 
| 
| 
| 
| | Make sure the context and type fields are MDNodes. We will generate
verification errors if those fields are non-empty strings.
Fix testing cases to make them pass the verifier.
llvm-svn: 187106 | 
| | 
| 
| 
| 
| 
| 
| | Improve the Finder to handle context of a DIVariable used by DbgValueInst.
Fix testing cases to make them pass the verifier.
llvm-svn: 187052 | 
| | 
| 
| 
| 
| 
| | to assume we're replacing. Clarify comments.
llvm-svn: 187018 | 
| | 
| 
| 
| | llvm-svn: 187017 | 
| | 
| 
| 
| 
| 
| 
| | all enumerated cases. Reformat the rest of the existing constructors to
match.
llvm-svn: 187015 | 
| | 
| 
| 
| 
| 
| 
| | Move to a single constructor with a default argument and avoid
the check and nullification.
llvm-svn: 187014 | 
| | 
| 
| 
| | llvm-svn: 187013 | 
| | 
| 
| 
| | llvm-svn: 187012 | 
| | 
| 
| 
| 
| 
| 
| | Improve the Finder to handle context of a DIVariable.
If Scope is a DICompileUnit, add it to the list of CUs.
llvm-svn: 187003 | 
| | 
| 
| 
| | llvm-svn: 187002 | 
| | 
| 
| 
| | llvm-svn: 187001 | 
| | 
| 
| 
| 
| 
| 
| | Use getNodeField to access a field as a MDNode.
No functionality change.
llvm-svn: 186985 | 
| | 
| 
| 
| | llvm-svn: 186972 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | MDNodes used by DbgDeclareInst and DbgValueInst.
Another 16 testing cases failed and they are disabled with
-disable-debug-info-verifier.
A total of 34 cases are disabled with -disable-debug-info-verifier and will be
corrected.
llvm-svn: 186902 | 
| | 
| 
| 
| 
| 
| | Instead of just adding the scope to the list, we actually handle the scope.
llvm-svn: 186867 | 
| | 
| 
| 
| 
| 
| 
| 
| | Simplify DIxxx:Verify to not call Verify on an operand. Instead, we use
DebugInfoFinder to list all MDNodes that should be a DIScope and all MDNodes
that should be a DIType and we will call Verify on those lists.
llvm-svn: 186737 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 1> Use DebugInfoFinder to find debug info MDNodes.
2> Add disable-debug-info-verifier to disable verifying debug info.
3> Disable verifying for testing cases that fail (will update the testing cases
   later on).
4> MDNodes generated by clang can have empty filename for TAG_inheritance and
   TAG_friend, so DIType::Verify is modified accordingly.
Note that DebugInfoFinder does not list all debug info MDNode.
For example, clang can generate:
metadata !{i32 786468}, which will fail to verify.
This MDNode is used by debug info but not included in DebugInfoFinder.
This MDNode is generated as a temporary node in DIBuilder::createFunction
  Value *TElts[] = { GetTagConstant(VMContext, DW_TAG_base_type) };
  MDNode::getTemporary(VMContext, TElts)
llvm-svn: 186634 | 
| | 
| 
| 
| 
| 
| 
| | This reverts commit r185876 as the functions appear to still be used
by dragonegg.
llvm-svn: 185890 | 
| | 
| 
| 
| | llvm-svn: 185876 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | We were being a bit too aggresive here in classifying global variables
with no global reference or constant value to be invalid - this would
cause LLVM to not emit the DWARF description of the global variable if
it had been optimized away, which isn't helpful for users who might
benefit from the global variable's description even if there's no
location information.
This also fixes a crasher issue here that I was unable to reduce a test
case for - involving a using decl (& subsequent
DW_TAG_imported_declaration ) of such a global variable that, once
optimized away, would crash when an attempt to emit the imported
declaration was made.
llvm-svn: 185675 | 
| | 
| 
| 
| 
| 
| | No functionality change. Remove handling for the null case.
llvm-svn: 185354 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | No functionality change.
It should suffice to check the type of a debug info metadata, instead of
calling Verify. For cases where we know the type of a DI metadata, use
assert.
llvm-svn: 185249 | 
| | 
| 
| 
| 
| 
| | and parameter packs
llvm-svn: 184643 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | definitions (& rename the 'fwd' tag to 'decl' for clarity)
This change is version locked with a change in Clang, so expect some
transient buildbot fallout.
llvm-svn: 184525 | 
| | 
| 
| 
| 
| 
| | Also simplify code a bit while there. No functionality change.
llvm-svn: 183076 | 
| | 
| 
| 
| | llvm-svn: 182869 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This resolves the last of the PR14606 failures in the GDB 7.5 test
suite by implementing an optional name field for
DW_TAG_imported_modules/DIImportedEntities and using that to implement
C++ namespace aliases (eg: "namespace X = Y;").
llvm-svn: 182328 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | parameters.
This is only tested for global variables at the moment (& includes tests
for the unnamed parameter case, since apparently this entire function
was completely untested previously)
llvm-svn: 181632 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - requires existing debug information to be present
- fixes up file name and line number information in metadata
- emits a "<orig_filename>-debug.ll" succinct IR file (without !dbg metadata
  or debug intrinsics) that can be read by a debugger
- initialize pass in opt tool to enable the "-debug-ir" flag
- lit tests to follow
llvm-svn: 181467 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | DIBuilder::createImportedDeclaration isn't fully plumbed through (note,
lacking in AsmPrinter/DwarfDebug support) but this seemed like a
sufficiently useful division of code to make the subsequent patch(es)
easier to follow.
llvm-svn: 181364 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | This reverts commit r179840 with a fix to test/DebugInfo/two-cus-from-same-file.ll
I'm not sure why that test only failed on ARM & MIPS and not X86 Linux, even
though the debug info was clearly invalid on all of them, but this ought to fix
it.
llvm-svn: 179996 | 
| | 
| 
| 
| 
| 
| | This reverts commit r179836 as it seems to have caused test failures.
llvm-svn: 179840 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Adding another CU-wide list, in this case of imported_modules (since they
should be relatively rare, it seemed better to add a list where each element
had a "context" value, rather than add a (usually empty) list to every scope).
This takes care of DW_TAG_imported_module, but to fully address PR14606 we'll
need to expand this to cover DW_TAG_imported_declaration too.
llvm-svn: 179836 | 
| | 
| 
| 
| 
| 
| 
| 
| | add a test case
CR feedback from Rafael Espindola and Paul Robinson.
llvm-svn: 179664 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This reverts commit 342d92c7a0adeabc9ab00f3f0d88d739fe7da4c7.
Turns out we're going with a different schema design to represent
DW_TAG_imported_modules so we won't need this extra field.
llvm-svn: 178215 | 
| | 
| 
| 
| | llvm-svn: 178155 | 
| | 
| 
| 
| | llvm-svn: 178144 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is just the basic groundwork for supporting DW_TAG_imported_module but I
wanted to commit this before pushing support further into Clang or LLVM so that
this rather churny change is isolated from the rest of the work. The major
churn here is obviously adding another field (within the common DIScope prefix)
to all DIScopes (files, classes, namespaces, lexical scopes, etc). This should
be the last big churny change needed for DW_TAG_imported_module/using directive
support/PR14606.
llvm-svn: 178099 |