Memory dependence analysis no longer counts DbgInfoIntrinsics towards the
limit where to abort the analysis. Before, a bunch of calls to dbg.value
could affect the generated code, meaning that with -g we could generate
different code than without.
Details
Diff Detail
Event Timeline
test/Transforms/DeadStoreElimination/mda-with-dbg-values.ll | ||
---|---|---|
45 | Did you hand-edit this debug info? It's missing pieces I would normally expect (specifically, the function doesn't have any debug info), so I'm not sure it's really valid. I'd prefer if you would just use debug info generated by clang so it's likely correct. |
test/Transforms/DeadStoreElimination/mda-with-dbg-values.ll | ||
---|---|---|
45 | Yes, I've hand edited it. Originally I found this with my out-of-tree frontend/backend and the example was huge. Then I've hand reduced it as much as I could without having opt complain about the input, since I thought that the only important thing with respect to the bugfix was that the single dbg.value affected the output. |
Rebased and updated the testcase with fresh output from clang.
I did hand edit the output a little bit this time too though and replaced a dbg.declare
before the store, with a dbg.value after it, so that the bug would still trigger.
test/Transforms/DeadStoreElimination/mda-with-dbg-values.ll | ||
---|---|---|
45 | Do you prefer the updated version? |
Did you hand-edit this debug info? It's missing pieces I would normally expect (specifically, the function doesn't have any debug info), so I'm not sure it's really valid. I'd prefer if you would just use debug info generated by clang so it's likely correct.