Skip to content

Commit 763be01

Browse files
authored
[RemoveDIs][NFC] Update docs to reflect new class structure (#85109)
This patch adds some small updates to the LLVM documentation regarding DbgRecords to accurately describe the current class structure. There are some more refactorings to come, so this isn't intended to be the final document update, but it covers the immediate task of updating references to DPValue that really refer to DbgRecord.
1 parent 95fef1d commit 763be01

File tree

2 files changed

+23
-21
lines changed

2 files changed

+23
-21
lines changed

llvm/docs/RemoveDIsDebugInfo.md

Lines changed: 22 additions & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,7 @@ The debug records are not instructions, do not appear in the instruction list, a
2424

2525
# Great, what do I need to do!
2626

27-
Approximately nothing -- we've already instrumented all of LLVM to handle these new records ("`DPValues`") and behave identically to past LLVM behaviour. We plan on turning this on by default some time soon, with IR converted to the intrinsic form of debug info at terminals (textual IR, bitcode) for a short while, before then changing the textual IR and bitcode formats.
27+
Approximately nothing -- we've already instrumented all of LLVM to handle these new records ("`DbgRecords`") and behave identically to past LLVM behaviour. We plan on turning this on by default some time soon, with IR converted to the intrinsic form of debug info at terminals (textual IR, bitcode) for a short while, before then changing the textual IR and bitcode formats.
2828

2929
There are two significant changes to be aware of. Firstly, we're adding a single bit of debug relevant data to the `BasicBlock::iterator` class (it's so that we can determine whether ranges intend on including debug info at the beginning of a block or not). That means when writing passes that insert LLVM IR instructions, you need to identify positions with `BasicBlock::iterator` rather than just a bare `Instruction *`. Most of the time this means that after identifying where you intend on inserting something, you must also call `getIterator` on the instruction position -- however when inserting at the start of a block you _must_ use `getFirstInsertionPt`, `getFirstNonPHIIt` or `begin` and use that iterator to insert, rather than just fetching a pointer to the first instruction.
3030

@@ -40,13 +40,15 @@ This will all happen transparently without needing to think about it!
4040

4141
## What exactly have you replaced debug intrinsics with?
4242

43-
We're using a dedicated C++ class called `DPValue` to store debug info, with a one-to-one relationship between each instance of a debug intrinsic and each `DPValue` object in any LLVM IR program. This class stores exactly the same information as is stored in debugging intrinsics. It also has almost entirely the same set of methods, that behave in the same way:
43+
We're using a dedicated C++ class called `DbgRecord` to store debug info, with a one-to-one relationship between each instance of a debug intrinsic and each `DbgRecord` object in any LLVM IR program; these `DbgRecord`s are represented in the IR as non-instruction debug records, as described in the [Source Level Debugging](project:SourceLevelDebugging.rst#Debug Records) document. This class has a set of subclasses that store exactly the same information as is stored in debugging intrinsics. Each one also has almost entirely the same set of methods, that behave in the same way:
4444

45+
https://llvm.org/docs/doxygen/classllvm_1_1DbgRecord.html
4546
https://llvm.org/docs/doxygen/classllvm_1_1DPValue.html
47+
https://llvm.org/docs/doxygen/classllvm_1_1DPLabel.html
4648

47-
This allows you to treat a `DPValue` as if it's a `dbg.value` intrinsic most of the time, for example in generic (auto-param) lambdas.
49+
This allows you to treat a `DPValue` as if it's a `dbg.value`/`dbg.declare`/`dbg.assign` intrinsic most of the time, for example in generic (auto-param) lambdas, and the same for `DPLabel` and `dbg.label`s.
4850

49-
## How do these DPValues fit into the instruction stream?
51+
## How do these `DbgRecords` fit into the instruction stream?
5052

5153
Like so:
5254

@@ -60,37 +62,37 @@ Like so:
6062
|
6163
v
6264
+------------+
63-
<-----+ DPMarker |<----
64-
/ +------------+ \
65-
/ \
66-
/ \
67-
v ^
68-
+-----------+ +-----------+ +-----------+
69-
| DPValue +--->| DPValue +-->| DPValue |
70-
+-----------+ +-----------+ +-----------+
65+
<-------+ DPMarker |<-------
66+
/ +------------+ \
67+
/ \
68+
/ \
69+
v ^
70+
+-------------+ +-------------+ +-------------+
71+
| DbgRecord +--->| DbgRecord +-->| DbgRecord |
72+
+-------------+ +-------------+ +-------------+
7173
```
7274

73-
Each instruction has a pointer to a `DPMarker` (which will become optional), that contains a list of `DPValue` objects. No debugging records appear in the instruction list at all. `DPValue`s have a parent pointer to their owning `DPMarker`, and each `DPMarker` has a pointer back to it's owning instruction.
75+
Each instruction has a pointer to a `DPMarker` (which will become optional), that contains a list of `DbgRecord` objects. No debugging records appear in the instruction list at all. `DbgRecord`s have a parent pointer to their owning `DPMarker`, and each `DPMarker` has a pointer back to it's owning instruction.
7476

75-
Not shown are the links from DPValues to other parts of the `Value`/`Metadata` hierachy: `DPValue`s have raw pointers to `DILocalVariable`, `DIExpression` and `DILocation` objects, and references to `Value`s are stored in a `DebugValueUser` base class. This refers to a `ValueAsMetadata` object referring to `Value`s, via the `TrackingMetadata` facility.
77+
Not shown are the links from DbgRecord to other parts of the `Value`/`Metadata` hierachy: `DbgRecord` subclasses have tracking pointers to the DIMetadata that they use, and `DPValue` has references to `Value`s that are stored in a `DebugValueUser` base class. This refers to a `ValueAsMetadata` object referring to `Value`s, via the `TrackingMetadata` facility.
7678

77-
The various kinds of debug intrinsic (value, declare, assign) are all stored in the `DPValue` object, with a "Type" field disamgibuating which is which.
79+
The various kinds of debug intrinsic (value, declare, assign, label) are all stored in `DbgRecord` subclasses, with a "RecordKind" field distinguishing `DPLabel`s from `DPValue`s, and a `LocationType` field in the `DPValue` class further disambiguating the various debug variable intrinsics it can represent.
7880

7981
## Finding debug info records
8082

8183
Utilities such as `findDbgUsers` and the like now have an optional argument that will return the set of `DPValue` records that refer to a `Value`. You should be able to treat them the same as intrinsics.
8284

8385
## Examining debug info records at positions
8486

85-
Call `Instruction::getDbgRecordRange()` to get the range of `DPValue` objects that are attached to an instruction.
87+
Call `Instruction::getDbgRecordRange()` to get the range of `DbgRecord` objects that are attached to an instruction.
8688

8789
## Moving around, deleting
8890

89-
You can use `DPValue::removeFromParent` to unlink a `DPValue` from it's marker, and then `BasicBlock::insertDbgRecordBefore` or `BasicBlock::insertDbgRecordAfter` to re-insert the `DPValue` somewhere else. You cannot insert a `DPValue` at an arbitary point in a list of `DPValue`s (if you're doing this with `dbg.value`s then it's unlikely to be correct).
91+
You can use `DbgRecord::removeFromParent` to unlink a `DbgRecord` from it's marker, and then `BasicBlock::insertDbgRecordBefore` or `BasicBlock::insertDbgRecordAfter` to re-insert the `DbgRecord` somewhere else. You cannot insert a `DbgRecord` at an arbitary point in a list of `DbgRecord`s (if you're doing this with `dbg.value`s then it's unlikely to be correct).
9092

91-
Erase `DPValue`s by calling `eraseFromParent` or `deleteInstr` if it's already been removed.
93+
Erase `DbgRecord`s by calling `eraseFromParent` or `deleteInstr` if it's already been removed.
9294

93-
## What about dangling `DPValue`s?
95+
## What about dangling `DbgRecord`s?
9496

9597
If you have a block like so:
9698

@@ -101,6 +103,6 @@ If you have a block like so:
101103
br label %xyzzy
102104
```
103105

104-
your optimisation pass may wish to erase the terminator and then do something to the block. This is easy to do when debug info is kept in instructions, but with `DPValue`s there is no trailing instruction to attach the variable information to in the block above, once the terminator is erased. For such degenerate blocks, `DPValue`s are stored temporarily in a map in `LLVMContext`, and are re-inserted when a terminator is reinserted to the block or other instruction inserted at `end()`.
106+
your optimisation pass may wish to erase the terminator and then do something to the block. This is easy to do when debug info is kept in instructions, but with `DbgRecord`s there is no trailing instruction to attach the variable information to in the block above, once the terminator is erased. For such degenerate blocks, `DbgRecord`s are stored temporarily in a map in `LLVMContext`, and are re-inserted when a terminator is reinserted to the block or other instruction inserted at `end()`.
105107

106108
This can technically lead to trouble in the vanishingly rare scenario where an optimisation pass erases a terminator and then decides to erase the whole block. (We recommend not doing that).

llvm/docs/UserGuides.rst

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -181,7 +181,7 @@ Optimizations
181181

182182
:doc:`RemoveDIsDebugInfo`
183183
This is a migration guide describing how to move from debug info using
184-
intrinsics such as dbg.value to using the non-instruction DPValue object.
184+
intrinsics such as dbg.value to using the non-instruction DbgRecord object.
185185

186186
:doc:`InstrProfileFormat`
187187
This document explains two binary formats of instrumentation-based profiles.

0 commit comments

Comments
 (0)