[llvm] r248010 - SelectionDAG: Introduce PersistentID to SDNode for assert builds.
Matthias Braun via llvm-commits
llvm-commits at lists.llvm.org
Mon Sep 21 10:43:28 PDT 2015
> On Sep 19, 2015, at 1:05 PM, Matt Arsenault via llvm-commits <llvm-commits at lists.llvm.org> wrote:
>
>
>> On Sep 18, 2015, at 10:41 AM, Matthias Braun via llvm-commits <llvm-commits at lists.llvm.org> wrote:
>>
>> Author: matze
>> Date: Fri Sep 18 12:41:00 2015
>> New Revision: 248010
>>
>> URL: http://llvm.org/viewvc/llvm-project?rev=248010&view=rev
>> Log:
>> SelectionDAG: Introduce PersistentID to SDNode for assert builds.
>>
>> This gives us more human readable numbers to identify nodes in debug
>> dumps.
>>
>> Before:
>> 0x7fcbd9700160: ch = EntryToken
>>
>> 0x7fcbd985c7c8: i64 = Register %RAX
>>
>> ...
>>
>> 0x7fcbd9700160: <multiple use>
>> 0x7fcbd985c578: i64,ch = MOV64rm 0x7fcbd985c6a0, 0x7fcbd985cc68, 0x7fcbd985c200, 0x7fcbd985cd90, 0x7fcbd985ceb8, 0x7fcbd9700160<Mem:LD8[@foo]> [ORD=2]
>>
>> 0x7fcbd985c8f0: ch,glue = CopyToReg 0x7fcbd9700160, 0x7fcbd985c7c8, 0x7fcbd985c578 [ORD=3]
>>
>> 0x7fcbd985c7c8: <multiple use>
>> 0x7fcbd985c8f0: <multiple use>
>> 0x7fcbd985c8f0: <multiple use>
>> 0x7fcbd985ca18: ch = RETQ 0x7fcbd985c7c8, 0x7fcbd985c8f0, 0x7fcbd985c8f0:1 [ORD=3]
>>
>> Now:
>> t0: ch = EntryToken
>>
>> t5: i64 = Register %RAX
>>
>> ...
>>
>> t0: <multiple use>
>> t3: i64,ch = MOV64rm t10, t12, t11, t13, t14, t0<Mem:LD8[@foo]> [ORD=2]
>>
>> t6: ch,glue = CopyToReg t0, t5, t3 [ORD=3]
>>
>> t5: <multiple use>
>> t6: <multiple use>
>> t6: <multiple use>
>> t7: ch = RETQ t5, t6, t6:1 [ORD=3]
>>
>
> I’m noticing a problem with the ID assigning. In the testcase from http://reviews.llvm.org/D12775
>
> the EntryToken and another node end up assigned the same ID 0 which doesn’t make much sense:
>
> Initial selection DAG: BB#0 'merge_store_partial_overlap_load:'
> SelectionDAG has 20 nodes:
> t0: ch = EntryToken
> t0: i64 = Register %vreg0
Thanks for the report, fixed in r248182.
- Matthias
More information about the llvm-commits
mailing list