diff options
author | Siri Hansen <[email protected]> | 2018-10-29 16:12:01 +0100 |
---|---|---|
committer | Siri Hansen <[email protected]> | 2018-10-29 16:55:41 +0100 |
commit | c9c1efe3815a49eb59ef62e8319cd9f6ea6c67d8 (patch) | |
tree | c6c769330ddff6520d222f5f18970aa5c72eec6c /lib/observer/src | |
parent | 896b367ad01ffa27637567af8fb722b9a379b972 (diff) | |
download | otp-c9c1efe3815a49eb59ef62e8319cd9f6ea6c67d8.tar.gz otp-c9c1efe3815a49eb59ef62e8319cd9f6ea6c67d8.tar.bz2 otp-c9c1efe3815a49eb59ef62e8319cd9f6ea6c67d8.zip |
[cdv] Handle multiple "Yc" lines refering to the same refc binary
Usually, sub binaries are implemented as special sub binary terms
("Ys" lines). But if a sub binary is sent to another process, sub
binaries will be eliminated and incorporated into the ProcBin ("Yc"
line), and when that happens there can be several "Yc" lines that
refer to the same underlying binary object. Make sure that that the
crash dump viewer can handle multiple "Yc" lines referring to the same
binary object.
Diffstat (limited to 'lib/observer/src')
-rw-r--r-- | lib/observer/src/crashdump_viewer.erl | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/lib/observer/src/crashdump_viewer.erl b/lib/observer/src/crashdump_viewer.erl index 41a569c2bf..af4e2f1dda 100644 --- a/lib/observer/src/crashdump_viewer.erl +++ b/lib/observer/src/crashdump_viewer.erl @@ -2802,12 +2802,12 @@ parse_heap_term("Yc"++Line0, Addr, DecodeOpts, D0) -> %Reference-counted binary. SymbolicBin = {'#CDVBin',Start}, Term = cdvbin(Offset, Sz, SymbolicBin), D1 = gb_trees:insert(Addr, Term, D0), - D = gb_trees:insert(Binp, SymbolicBin, D1), + D = gb_trees:enter(Binp, SymbolicBin, D1), {Term,Line,D}; [] -> Term = '#CDVNonexistingBinary', D1 = gb_trees:insert(Addr, Term, D0), - D = gb_trees:insert(Binp, Term, D1), + D = gb_trees:enter(Binp, Term, D1), {Term,Line,D} end; parse_heap_term("Ys"++Line0, Addr, DecodeOpts, D0) -> %Sub binary. |