Bartosz Taudul
2931c83442
Lookup further at the beginning of the collapsed zones area.
2019-03-18 18:32:45 +01:00
Bartosz Taudul
e19f2f26e1
Optimize drawing collapsed CPU zones.
2019-03-18 18:24:27 +01:00
Bartosz Taudul
b5fce70f25
Fix rapid advancing to next frames.
2019-03-17 20:51:54 +01:00
Bartosz Taudul
e034eabeb8
Animate plot ranges.
2019-03-17 17:21:30 +01:00
Bartosz Taudul
b6ccb9d686
Allocation times may be displayed relative to zone start.
2019-03-17 16:53:09 +01:00
Bartosz Taudul
d2cca5dc3f
Allow custom time offset in memory allocation list.
2019-03-17 16:47:44 +01:00
Bartosz Taudul
f0aadfe066
Don't push the same zone on zone info stack multiple times.
2019-03-17 16:43:20 +01:00
Bartosz Taudul
06421cf5ca
Always auto-resize memory allocation info window.
2019-03-17 16:39:27 +01:00
Bartosz Taudul
4914ef6b14
Display zone messages in zone info window.
2019-03-17 16:33:18 +01:00
Bartosz Taudul
016f7ac4b6
Allow retrieval of zone's thread data.
2019-03-17 16:17:47 +01:00
Bartosz Taudul
b4bfdb7872
Dim information about no memory events.
2019-03-17 02:56:26 +01:00
Bartosz Taudul
17718b4d25
Fix asserts.
2019-03-16 20:36:06 +01:00
Bartosz Taudul
28dfa21fda
Move conditional out of loop.
2019-03-16 14:46:21 +01:00
Bartosz Taudul
7e6a8135df
Remove double indirection in GetNextLockEvent().
2019-03-16 14:18:43 +01:00
Bartosz Taudul
6db1a9ccd4
Use lock thread ranges in lock tooltips.
2019-03-16 02:50:51 +01:00
Bartosz Taudul
833151b868
Don't search for lock events outside of thread range.
2019-03-16 02:50:51 +01:00
Bartosz Taudul
200621f952
Use lock ranges for early exclusion test.
2019-03-16 02:50:51 +01:00
Bartosz Taudul
71e20e7e7f
Store lock map as flat_hash_map with pointer values.
2019-03-16 02:50:51 +01:00
Bartosz Taudul
b43d962194
Set labels for input text fields.
2019-03-15 02:35:27 +01:00
Bartosz Taudul
6a36bb2fc2
Add hints to input text fields.
2019-03-15 01:31:06 +01:00
Bartosz Taudul
a10ec49a60
Don't use obsolete function.
2019-03-15 01:00:43 +01:00
Bartosz Taudul
5177629130
Add standard deviation explanation tooltips.
2019-03-14 01:34:50 +01:00
Bartosz Taudul
18e7b9df11
Add standard deviations to compare menu.
2019-03-14 01:32:50 +01:00
Bartosz Taudul
a0299cc63a
Optimize calculation of standard deviation.
2019-03-14 01:23:37 +01:00
Bartosz Taudul
d3fdd6b1d1
Display standard deviation.
2019-03-14 01:14:06 +01:00
Bartosz Taudul
9563c8316d
Optimize lock drawing.
...
Don't iterate over locks that are present in only one thread, if only
contended lock events are to be displayed. Such locks cannot be
contended.
2019-03-09 14:20:34 +01:00
Bartosz Taudul
cbfd524b6c
Set sane messages window column widths.
2019-03-09 00:37:58 +01:00
Bartosz Taudul
815d7fdcb4
Set sane callstack window column widths.
2019-03-09 00:34:04 +01:00
Bartosz Taudul
5445ffb149
Set sane statistics window column widths.
2019-03-09 00:30:53 +01:00
Bartosz Taudul
0748655797
Allow opening source file view from statistics menu.
2019-03-09 00:15:23 +01:00
Bartosz Taudul
761a08b055
Dim location in statistics menu.
2019-03-09 00:08:57 +01:00
Bartosz Taudul
9fd8a20d7c
Use small checkbox in appropriate places.
2019-03-08 18:39:41 +01:00
Bartosz Taudul
e004dc85a9
Display waiting dots in "waiting for connection" window.
2019-03-07 17:00:40 +01:00
Bartosz Taudul
f69f9d4660
Disable window transparency.
2019-03-07 01:18:24 +01:00
Bartosz Taudul
535d7b2da1
Add waiting dots to statistics menu.
2019-03-07 00:59:43 +01:00
Bartosz Taudul
aa054f1f46
Add waiting dots to compare traces menu.
2019-03-07 00:59:02 +01:00
Bartosz Taudul
6e4bc7d9c5
Add waiting dots to memory data in zone info window.
2019-03-07 00:57:32 +01:00
Bartosz Taudul
d547700e50
Update time in a common location.
2019-03-07 00:57:25 +01:00
Bartosz Taudul
f2f19241e6
Display waiting dots in find zone menu during precompute.
2019-03-06 18:25:39 +01:00
Bartosz Taudul
cee625b375
Animate frame selection expansion.
2019-03-06 01:45:39 +01:00
Bartosz Taudul
4b1c0ff0c5
Fix frame selection when zoom anim is active.
2019-03-06 01:45:26 +01:00
Bartosz Taudul
00de21f7e7
Smooth zooming on mouse scroll.
2019-03-06 01:15:38 +01:00
Bartosz Taudul
f6913eecf0
Don't display custom stack frames as pointers.
2019-03-03 18:20:55 +01:00
Bartosz Taudul
9fc022346b
Replace frame pointers with callstack frame ids.
2019-03-03 18:05:03 +01:00
Bartosz Taudul
fc63b6b07d
Display trace version in trace info window.
2019-03-01 01:47:36 +01:00
Bartosz Taudul
6065d25335
Extend list of tracy callstack frames.
2019-03-01 01:41:10 +01:00
Bartosz Taudul
e284248995
Fix display of last message.
2019-03-01 01:30:56 +01:00
Bartosz Taudul
8fd09fe8f0
Get proper width.
2019-03-01 01:20:20 +01:00
Bartosz Taudul
d80dc82b96
Don't display invalid thread in failure dialog.
2019-02-28 19:31:45 +01:00
Bartosz Taudul
b4daad684c
Display frame numbers in zone trace.
2019-02-27 21:12:56 +01:00
Bartosz Taudul
8d784f7fae
Display inline frames in all call stacks.
2019-02-27 20:55:58 +01:00
Bartosz Taudul
422ed1f452
Special mode for callstack grouping in find zone menu.
2019-02-27 20:37:38 +01:00
Bartosz Taudul
851ae9077b
Make small callstack button tooltip optional.
2019-02-27 19:59:49 +01:00
Bartosz Taudul
e20e7caab0
Increase size of frame left/right buttons.
2019-02-27 19:58:44 +01:00
Bartosz Taudul
e9aeb0c522
Darken timeline outside of capture area.
2019-02-24 18:35:03 +01:00
Bartosz Taudul
9f621bf67f
Improve lock label tooltips.
2019-02-24 17:44:44 +01:00
Bartosz Taudul
c78aedae62
Zoom-to-range for lock labels.
2019-02-24 17:30:58 +01:00
Bartosz Taudul
021d369b80
Fix calculation of thread lock extent.
2019-02-24 17:30:18 +01:00
Bartosz Taudul
271d7ccaa3
Bring plot tooltip up-to-par.
2019-02-24 17:01:46 +01:00
Bartosz Taudul
bf2ecbae36
Middle-click on thread label to zoom to thread extent.
2019-02-24 17:01:46 +01:00
Bartosz Taudul
62162d4cdb
Display count of messages and locks in thread tooltip.
2019-02-24 17:01:46 +01:00
Bartosz Taudul
6dceec4ea8
Improve thread tooltip.
...
- In addition to the first event time, also display last one and the
time period.
- Include messages and locks in thread events discovery.
2019-02-24 17:01:46 +01:00
Bartosz Taudul
a0b5ac33cc
Always show label of a crashed thread.
2019-02-23 01:34:45 +01:00
Bartosz Taudul
af3eb93e4a
Hide tracks that don't have anything to display.
2019-02-23 01:28:12 +01:00
Bartosz Taudul
7ab326c4fe
Don't clip area above track.
2019-02-23 00:59:09 +01:00
Bartosz Taudul
53992b9b6b
Don't hide hex thread id in tooltip.
2019-02-23 00:34:01 +01:00
Bartosz Taudul
29fcddca0b
Display frame count in frame type selection dropdown.
2019-02-22 21:07:33 +01:00
Bartosz Taudul
ae53c8e6f0
Don't display threads with no messages.
2019-02-22 21:07:33 +01:00
Bartosz Taudul
48b5b25a6a
Display count of messages in threads.
2019-02-22 21:07:33 +01:00
Bartosz Taudul
d0c1b9bf67
Proper formatting of plot values.
2019-02-21 23:07:32 +01:00
Bartosz Taudul
e9baa80bf3
Process CPU usage reports.
2019-02-21 22:56:59 +01:00
Bartosz Taudul
f1dd4ef3d9
Animate thread position and height.
2019-02-21 21:18:41 +01:00
Bartosz Taudul
e945902f40
Merge visibility and show full options into one struct.
2019-02-21 20:24:08 +01:00
Bartosz Taudul
bc713463d8
Improve zooming animation.
2019-02-21 20:00:29 +01:00
Bartosz Taudul
3a562ae6c9
Fix display of unresolved call stack frames.
2019-02-19 16:37:34 +01:00
Bartosz Taudul
081b1069f6
Properly count number of locks in options menu.
2019-02-17 17:19:17 +01:00
Bartosz Taudul
9dd1d6a744
Don't display locks with no lock events.
2019-02-17 17:13:20 +01:00
Bartosz Taudul
a2819baa35
Split locks as single and multithreaded in options menu.
2019-02-17 17:06:39 +01:00
Bartosz Taudul
5cc738593f
Fix drawing lock highlight.
2019-02-17 16:57:52 +01:00
Bartosz Taudul
92a7e02e73
Highlight locks hovered in the options menu.
2019-02-17 16:53:33 +01:00
Bartosz Taudul
bec27f7d60
Handle highlighting lock in fast-exit code path.
2019-02-17 16:49:18 +01:00
Bartosz Taudul
1e32821097
Move drawing lock header to a separate function.
2019-02-17 16:49:03 +01:00
Bartosz Taudul
ea4f4ebb3a
Highlight selected/hovered lock.
2019-02-17 16:20:56 +01:00
Bartosz Taudul
1cefd4d8ac
Don't use reserve_exact for temporary things.
2019-02-15 01:43:30 +01:00
Bartosz Taudul
e8d15e8295
Mirror zone child grouping for GPU zones.
2019-02-14 01:38:34 +01:00
Bartosz Taudul
e24ac42755
Add self time to GPU zone info window.
2019-02-14 01:31:06 +01:00
Bartosz Taudul
0fad23dbae
Add GPU zone self time in tooltip.
2019-02-14 01:28:27 +01:00
Bartosz Taudul
f06609eb61
GPU child zones time getter.
2019-02-14 01:28:12 +01:00
Bartosz Taudul
7f11260bf0
Handle dropped connection during handshake.
2019-02-12 01:41:09 +01:00
Bartosz Taudul
147b31f014
Implement grouping children zones.
2019-02-10 17:21:01 +01:00
Bartosz Taudul
740486a0ce
Add children locations grouping button.
2019-02-10 16:14:13 +01:00
Bartosz Taudul
b7bd3696b7
Do not draw time subdividers on a nanosecond scale.
2019-02-10 16:04:04 +01:00
Bartosz Taudul
d18c3432a4
Fix call stack window.
2019-02-10 13:38:14 +01:00
Bartosz Taudul
2d50664180
Use multiply instead of divide.
2019-02-10 13:01:16 +01:00
Bartosz Taudul
f1940aab2e
Use help marker helper function.
2019-02-10 03:02:54 +01:00
Bartosz Taudul
96e38501b6
Use unformatted text drawing where possible.
2019-02-10 02:50:34 +01:00
Bartosz Taudul
3a8abdf9c1
Integer time specialization is not needed anymore.
2019-02-10 01:14:34 +01:00
Bartosz Taudul
2ad0258925
Don't print trailing zeros in fractions (e.g. 2.5 instead of 2.50).
2019-02-10 01:12:22 +01:00
Bartosz Taudul
af16872693
Don't display fractional part if it's 0.
2019-02-10 01:03:35 +01:00
Bartosz Taudul
e4f4fee6d4
Optimize printing days.
2019-02-10 01:02:57 +01:00
Bartosz Taudul
ee66b1354d
IntTable10 is not needed.
2019-02-10 00:51:13 +01:00
Bartosz Taudul
d940e315bd
Optimize TimeToString().
2019-02-08 22:11:06 +01:00
Bartosz Taudul
3c4394489c
Workaround GCC bug #67274 .
...
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=67274
2019-02-08 11:54:29 +01:00
Bartosz Taudul
053932249c
Style fixes.
2019-02-08 02:29:24 +01:00
Dedmen Miller (Dedmenmiller)
8fb6c0dfcb
Merged in dedmenmiller/tracy/findZoneSorting (pull request #31 )
...
Add sorting for findZone zonelist
2019-02-08 00:53:48 +00:00
Dedmen Miller
ab0dc0da11
Use memcpy
2019-02-07 16:10:28 +01:00
Dedmen Miller
59ae188a7f
Cleanup
2019-02-07 14:51:34 +01:00
Dedmen Miller
7361d696c5
Return proper buf
2019-02-07 14:38:42 +01:00
Dedmen Miller
bfa5386bbe
Cleanup
2019-02-07 14:36:33 +01:00
Dedmen Miller
e4ef491fdf
Cleaner TimeToString
2019-02-07 13:14:52 +01:00
Dedmen Miller
92c872dfc0
Added sorting for findZone zonelist
2019-02-07 12:25:05 +01:00
Bartosz Taudul
b945f83169
Don't separate inclusive/exclusive counts.
...
There is no way for one frame to have both. Coloring is preserved and is
now determined by presence of children.
2019-02-06 22:36:21 +01:00
Bartosz Taudul
1953a1a1d5
Notify user about pitfalls of function name grouping.
2019-02-06 22:02:59 +01:00
Bartosz Taudul
70ea9e7712
Implement grouping call stack tree by function names.
2019-02-06 21:56:49 +01:00
Bartosz Taudul
044b7e1522
Add function name grouping controls.
2019-02-06 21:45:26 +01:00
Bartosz Taudul
7aa24864bf
Make it easier to add new matches against tracy own stack frames.
2019-02-06 21:07:41 +01:00
Bartosz Taudul
104415ced8
Display base frame, not inline frame, if inlines are not shown.
2019-02-06 14:17:18 +01:00
Bartosz Taudul
c2e9c00a38
Add top-down call stack memory tree.
2019-02-06 13:53:14 +01:00
Bartosz Taudul
c689a494da
Move call stack paths calculation to a separate function.
2019-02-06 13:46:50 +01:00
Bartosz Taudul
dbf8115771
Same for linux.
2019-02-04 02:33:03 +01:00
Bartosz Taudul
4dc05195ca
Skip internal call stack capture inline frames for MSVC.
2019-02-04 02:27:13 +01:00
Bartosz Taudul
b0d319890b
Allow sorting find zone groups by mean time per call.
2019-01-30 01:54:18 +01:00
Bartosz Taudul
c5fd347401
Initialize variable.
2019-01-29 23:18:36 +01:00
Bartosz Taudul
89ddfd0006
Remove dead code.
2019-01-29 23:18:36 +01:00
Bartosz Taudul
852fe03cbc
More references.
2019-01-29 22:10:14 +01:00
Bartosz Taudul
5e3390894d
Use preincrementation for iterators.
2019-01-29 22:01:47 +01:00
Bartosz Taudul
1b3f10148d
Fix logic snafu.
2019-01-29 21:46:14 +01:00
Bartosz Taudul
66a5e06803
Allow disconnecting from a client.
2019-01-24 19:00:34 +01:00
Dedmen Miller (Dedmenmiller)
e83e63caa4
Fix other lines
2019-01-24 15:02:36 +00:00
Dedmen Miller (Dedmenmiller)
72966a24a3
Fixed offset in histogram with non-log time
2019-01-24 14:16:23 +00:00
Bartosz Taudul
c67d91c6ac
Display numerical thread id in thread tooltip.
2019-01-23 18:15:19 +01:00
Bartosz Taudul
71f1a0b31e
Display self time percentage in find zone menu.
2019-01-23 18:11:47 +01:00
Bartosz Taudul
56b530e99c
Fix tooltip active area.
2019-01-23 18:04:31 +01:00
Bartosz Taudul
7f015b1b24
Implement self time in find zone menu.
2019-01-23 14:25:45 +01:00
Bartosz Taudul
92766430d9
Add "self time" checkbox to find zone menu.
2019-01-23 14:25:28 +01:00
Bartosz Taudul
118fab1561
Fast version of zone child time getter.
...
This one can only be used when all child zones are properly ended.
2019-01-23 13:59:14 +01:00
Bartosz Taudul
3d2cc2d54d
Display zone self time.
2019-01-23 13:44:11 +01:00
Bartosz Taudul
06292f1a3f
Add zone child time getter.
2019-01-23 13:39:44 +01:00
Bartosz Taudul
ef17699887
Fix order of inline and base subframes.
2019-01-21 17:12:01 +01:00
Bartosz Taudul
ddad475c19
Make it possible to store multiple frames at single frame address.
2019-01-20 19:11:48 +01:00
Bartosz Taudul
d4e9baa0d9
Display time savings also as time percentage.
2019-01-20 03:16:32 +01:00
Rokas K. (rku)
31bbdfe2f2
Merged in rokups/tracy/mingw-support (pull request #26 )
...
MingW support
2019-01-20 00:44:44 +00:00
Bartosz Taudul
f6edbccfc8
Fix triangle rendering.
2019-01-19 14:22:45 +01:00
Rokas Kupstys
8157e3a0b3
Fix builds with MingW.
2019-01-19 13:53:10 +02:00
Bartosz Taudul
3e3ee0ec2f
There may be no source location associated with failure.
2019-01-15 18:54:41 +01:00
Bartosz Taudul
9944a73444
Store failure reason strings in Worker.
2019-01-15 18:42:15 +01:00
Bartosz Taudul
57decf5875
Display failure information.
2019-01-14 23:42:58 +01:00
Bartosz Taudul
a5736a9c1b
Change crash visuals in options menu.
2019-01-14 18:48:16 +01:00
Bartosz Taudul
cb50cf9de6
Last time is stored in worker.
2019-01-08 15:44:29 +01:00
Bartosz Taudul
9c6d037859
Another unneeded capture.
2019-01-06 21:15:49 +01:00
Bartosz Taudul
096022a718
Proper string printing.
2019-01-06 21:15:26 +01:00
Bartosz Taudul
d1beb12dc3
Remove unused variable.
2019-01-06 21:14:02 +01:00
Bartosz Taudul
dabdf1360f
Display trace loading time.
2019-01-06 19:20:17 +01:00
Bartosz Taudul
77c9a8c407
Add support for notification text in View.
2019-01-06 19:14:24 +01:00
Bartosz Taudul
ea396354d0
^F opens find zone menu and focuses on the input box.
2018-12-22 17:39:22 +01:00
Bartosz Taudul
2d143ce516
Add support for handling keyboard shortcuts.
2018-12-22 17:36:20 +01:00
Bartosz Taudul
4bb4a568ca
Move initialization of View values to header.
2018-12-22 17:22:26 +01:00
Bartosz Taudul
cd8d86edf3
Allow hiding "[unknown frames]" entries.
2018-12-21 21:10:29 +01:00
Bartosz Taudul
407fb61a30
Display maximum number of waiting threads for a lock.
2018-12-19 18:34:53 +01:00
Bartosz Taudul
0f2b61cf24
Display wait and hold times of locks.
2018-12-19 18:28:48 +01:00
Bartosz Taudul
df1a125fc0
Mirror find zone menu changes in compare menu.
2018-12-18 16:56:19 +01:00
Bartosz Taudul
a220f38fbd
Add support for matching source locations ignoring case.
2018-12-18 16:52:29 +01:00
Bartosz Taudul
24235406a0
Enter key in find zone menu acts the same as pressing "find".
2018-12-18 16:40:23 +01:00
Bartosz Taudul
7fc03736f2
Add "ignore case" toggle to find zone menu.
2018-12-18 16:38:55 +01:00
Bartosz Taudul
a740074da6
Color tweaks.
2018-12-18 16:30:13 +01:00
Bartosz Taudul
b60d5b892a
Unify coloring of highlighted buttons.
2018-12-18 16:30:13 +01:00
Bartosz Taudul
c2485fbcb0
Add visual notification of an active toggle.
2018-12-18 16:30:13 +01:00
Bartosz Taudul
9e18db01c9
Menu bar buttons are now toggles.
2018-12-18 16:30:13 +01:00
Bartosz Taudul
79eb6a5836
Right click on lock in options to open info window.
2018-12-16 21:14:15 +01:00
Bartosz Taudul
9a7689c65d
Display lock announce, terminate and life time.
2018-12-16 21:09:37 +01:00
Bartosz Taudul
91171a6674
Draw zig-zag pattern over collapsed locks.
2018-12-16 20:20:27 +01:00
Bartosz Taudul
abad5574f3
Middle click on lock event to zoom to it.
2018-12-16 20:04:45 +01:00
Bartosz Taudul
8f6f54e412
Clicking on a lock event also opens lock info window.
2018-12-16 20:01:40 +01:00
Bartosz Taudul
444d5e20f0
Add basic lock info window.
2018-12-16 19:58:11 +01:00
Bartosz Taudul
ff8c9ab6dc
Properly terminate source file data.
2018-12-16 19:48:34 +01:00
Bartosz Taudul
1235a5aa0a
Allow discarding active trace.
2018-11-25 19:31:26 +01:00
Bartosz Taudul
fec0017bb6
Add third state (stopped) to the pause/resume button.
2018-11-25 19:15:16 +01:00
Bartosz Taudul
63f0dd72a5
Allow cancelling pending connection.
2018-10-23 19:49:57 +02:00
Bartosz Taudul
54baec9e7e
Fix drawing last collapsed non-contiguous frame.
2018-10-21 17:46:24 +02:00
Bartosz Taudul
556b3e8efe
Add "go to frame" functionality.
2018-10-21 17:36:27 +02:00
Bartosz Taudul
9342ba0e71
Don't track last frames in offline mode.
2018-10-21 16:03:21 +02:00
Bartosz Taudul
5280d6586b
Switching active frame set by clicking on a frame.
2018-10-21 15:46:02 +02:00
Bartosz Taudul
05c9325018
Highlight zones selected in the find zone menu.
2018-10-09 15:54:28 +02:00
Bartosz Taudul
4ca4c85976
Fix an edge case in zone drawing.
...
If the last zone on a track was not ended, and in the view's past
(beyond the left edge of the view) it was still included in calculation
of track height.
2018-10-06 12:58:38 +02:00
Bartosz Taudul
75ab9147d0
Reduce amount of information in "menu" bar.
...
Zone count, queue delay and timer resolution were moved to the trace
information window.
Time span and View span are now displayed as icons.
2018-10-05 23:02:23 +02:00
Bartosz Taudul
9e94dcd320
Fix zoom-to-allocation not working on selected allocations.
2018-10-05 21:13:31 +02:00
Bartosz Taudul
1a8b184d10
Mute inactive frame sets.
2018-10-05 21:10:37 +02:00
Bartosz Taudul
286a6cfe0a
Move check out of loop.
2018-10-05 21:03:04 +02:00
Bartosz Taudul
0d8b79f6c9
Don't miss frame separators.
2018-10-05 20:59:00 +02:00
Bartosz Taudul
81cf024498
Highlight message marker even if it's collapsed.
2018-10-05 20:40:10 +02:00
Bartosz Taudul
b7d2a690d9
Zoom to allocation range when middle clicking on address.
2018-09-28 11:43:45 +02:00
Bartosz Taudul
4960e691d4
Added ability to zoom to allocation range in allocation window.
2018-09-28 11:40:22 +02:00
Bartosz Taudul
428b7da1cc
The underlying vector might be reallocated.
2018-09-27 23:19:20 +02:00
Bartosz Taudul
6cfd53b274
Add allocations list window.
2018-09-27 23:19:20 +02:00
Bartosz Taudul
01e0bbb5f9
Build list of allocations in a given call stack tree entry.
2018-09-27 23:19:20 +02:00
Bartosz Taudul
9301986bae
Collect callstacks for each entry in call stack tree.
2018-09-27 22:56:44 +02:00
Bartosz Taudul
44fae53583
Display lock source location in tooltip.
2018-09-18 16:29:02 +02:00
Bartosz Taudul
06eec51ed9
Display locks source locations in options locks list.
2018-09-18 16:14:32 +02:00
Bartosz Taudul
9211ce42da
Non-on-demand client is only able to handle one connection.
2018-09-09 19:42:06 +02:00
Bartosz Taudul
984a711666
Send protocol version to verify handshake.
2018-09-09 19:28:53 +02:00
Bartosz Taudul
4471329661
Display time savings in the compare traces menu.
2018-09-08 20:23:49 +02:00
Bartosz Taudul
19f3c5f5ff
Ignore frames with 0 time.
2018-09-08 19:04:38 +02:00
Bartosz Taudul
2c43e1337f
Fast log10 is no longer needed.
2018-09-08 19:01:51 +02:00
Bartosz Taudul
2f9d0aa9eb
Use improved algorithm in compare trace histogram.
2018-09-03 21:26:50 +02:00
Bartosz Taudul
384a42cc47
Display average and median times in compare traces.
2018-09-03 20:45:51 +02:00
Bartosz Taudul
29d649216e
In compare traces put both total times in the same line.
2018-09-03 20:39:34 +02:00
Bartosz Taudul
9fb26b3622
If there's no group selected, dim group selection legend.
2018-09-03 20:36:40 +02:00
Bartosz Taudul
fc40c7bbf6
Calculate compare traces average, median.
2018-09-03 20:34:07 +02:00
Bartosz Taudul
b485aad2a3
Cosmetics.
2018-09-03 20:34:00 +02:00
Bartosz Taudul
a02121d78a
Allow disabling average, median markers on frame set histogram.
2018-09-02 13:37:36 +02:00
Bartosz Taudul
fb013c0df5
Properly reset state when switching matched source locations.
2018-09-02 13:25:17 +02:00
Bartosz Taudul
08729c2b42
Allow disabling average and median time markers.
2018-09-02 13:06:09 +02:00
Bartosz Taudul
1bff8a7997
Draw group average and median times on histogram.
2018-09-02 13:00:21 +02:00
Bartosz Taudul
c3c48117d4
Display group average and median times.
2018-09-02 13:00:21 +02:00
Bartosz Taudul
2d3ce1bf25
Calculate group average and median times.
2018-09-02 13:00:21 +02:00
Bartosz Taudul
5733b420a1
Use the same algorithm for selection group binning.
2018-09-02 03:46:16 +02:00
Bartosz Taudul
c1630936d4
Use the improved method in find zone histogram.
2018-09-02 02:58:15 +02:00
Bartosz Taudul
854210a7e3
Fix find zone histogram selection start/end.
2018-09-02 02:09:29 +02:00
Bartosz Taudul
8152e213f8
Collapse separate find zone histogram paths into one.
2018-09-02 01:31:09 +02:00
Bartosz Taudul
f43b875b83
Display average and median zone time in find zone histogram.
2018-09-02 00:28:57 +02:00
Bartosz Taudul
f66ed00d71
Calculate sorted zone times for find zone histogram.
2018-09-02 00:19:15 +02:00
Bartosz Taudul
e81218ddaf
Radically improve frame set histogram performance.
...
This change exploits the fact that frame set data is sorted, and the
histogram bins can be calculated as distances in the frame-time vectors.
2018-09-01 14:50:38 +02:00
Bartosz Taudul
1bef4b45b7
Display continuous/discontinuous info about frame sets.
2018-09-01 14:04:23 +02:00
Bartosz Taudul
213b33a4fa
No need to check for zero value in a sorted set.
2018-09-01 13:55:25 +02:00
Bartosz Taudul
0c086e3a30
In-place merge new frames instead of re-sorting the whole set.
2018-09-01 13:34:02 +02:00
Bartosz Taudul
9f4d6692dc
Proper way to get full frame count.
2018-09-01 12:38:12 +02:00
Bartosz Taudul
faea036c16
Ignore last, probably unfinished frame.
2018-09-01 02:07:52 +02:00
Bartosz Taudul
c8a0bfd9be
Merge average and median lines, if they overlap.
2018-09-01 01:48:00 +02:00
Bartosz Taudul
8211eb1371
Display FPS ranges.
2018-09-01 01:48:00 +02:00
Bartosz Taudul
0825c40938
Display average and median frame times.
2018-09-01 01:48:00 +02:00
Bartosz Taudul
8df82278a5
Display frame set time as a percentage of profile time.
2018-09-01 01:48:00 +02:00
Bartosz Taudul
98b5363ebc
Add frame set histogram.
2018-09-01 01:48:00 +02:00
Bartosz Taudul
9b8a0a8364
Display total frame set time.
2018-09-01 01:48:00 +02:00
Bartosz Taudul
27a2d8595d
Time is int64_t.
2018-09-01 01:48:00 +02:00
Bartosz Taudul
cb47ac6165
Actually mark the data as used.
2018-09-01 01:01:41 +02:00
Bartosz Taudul
9da3364c77
Display non-rounded FPS in a tooltip.
2018-08-31 18:58:39 +02:00
Bartosz Taudul
230ee71368
Do not recalculate frame stats, if frame data didn't change.
2018-08-31 18:51:00 +02:00
Bartosz Taudul
4ee8e7c372
Also display frames per second for average and median frame times.
2018-08-31 18:43:25 +02:00
Bartosz Taudul
0d6d296e94
Display average and median frame times.
2018-08-31 15:32:30 +02:00
Bartosz Taudul
d977fa004d
Enable keyboard navigation.
2018-08-30 02:08:08 +02:00
Bartosz Taudul
81655816f0
Display captured program name and capture time.
2018-08-29 01:02:29 +02:00
Bartosz Taudul
d835d4da2a
Remove display of found allocations count.
2018-08-25 15:07:23 +02:00
Bartosz Taudul
256d905ed5
Hide memory address search in "allocations" section.
2018-08-25 15:05:22 +02:00
Bartosz Taudul
6ad184447a
Call stack window may now display frame addresses.
2018-08-21 17:55:59 +02:00
Bartosz Taudul
def6c674b2
Add crash notification to thread tooltip.
2018-08-20 14:37:14 +02:00
Bartosz Taudul
ebcdebaa69
Display crash marker on timeline.
2018-08-20 03:00:45 +02:00
Bartosz Taudul
5fa4cf6e5d
Display crash information on visible threads lists.
2018-08-20 02:41:11 +02:00
Bartosz Taudul
b1227cf9fd
Display crashed thread in red color.
2018-08-20 02:36:58 +02:00
Bartosz Taudul
619fba41ab
Display crash information in info window.
2018-08-20 02:23:55 +02:00
Bartosz Taudul
2a696418cd
Cosmetics.
2018-08-20 02:23:55 +02:00
Bartosz Taudul
71bfd15d9e
Display host info.
2018-08-19 18:24:43 +02:00
Bartosz Taudul
6224daf9c9
Greatly simplify call stack tree calculation.
...
Instead of caching paths, compute accumulated cost of each path and only
then create the tree, going through each path just once.
2018-08-19 16:34:26 +02:00
Bartosz Taudul
cb51fdec20
Fix multiple file name retrievals in a row.
2018-08-18 20:38:14 +02:00
Bartosz Taudul
42636cfe89
Allow viewing source files from within find zone menu.
2018-08-18 20:35:25 +02:00
Bartosz Taudul
2445cc72bc
Add icons to memory menu.
2018-08-18 20:10:14 +02:00
Bartosz Taudul
235da1eded
Use focused text for source locations count.
2018-08-18 20:01:57 +02:00
Bartosz Taudul
4060a59b4f
Call stack tree nodes that have no siblings are expanded by default.
2018-08-18 20:00:24 +02:00
Bartosz Taudul
a4df805746
Allow filtering messages by thread.
2018-08-18 19:57:36 +02:00
Bartosz Taudul
59293b1850
Enable support for restrict time in call stack tree.
2018-08-18 19:44:29 +02:00
Bartosz Taudul
1410ba6f01
Increase readability.
2018-08-18 19:34:17 +02:00
Bartosz Taudul
79c437ba7f
Let's not search in a map.
2018-08-18 19:29:04 +02:00
Bartosz Taudul
bd96c2ce51
Cache call stack tree paths.
2018-08-18 19:13:46 +02:00
Bartosz Taudul
7f0fb851b4
Force inline GetFrameTreeItem().
2018-08-18 18:46:16 +02:00
Bartosz Taudul
7ef6944246
Remove compare menu visual aids if extended font is not available.
2018-08-18 16:32:26 +02:00
Bartosz Taudul
410616f7f8
Allow viewing source from zone trace.
2018-08-18 14:26:10 +02:00
Bartosz Taudul
fb876344e3
No need for indentVal outside of scope.
2018-08-18 14:14:33 +02:00
Bartosz Taudul
b9e83871a8
Add visual aids to compare menu.
2018-08-18 14:02:20 +02:00
Bartosz Taudul
2852784f55
Separate global and level indices for call stack tree.
2018-08-18 02:23:55 +02:00
Bartosz Taudul
0757930521
Only display "go to parent" if there is a parent.
2018-08-18 02:12:34 +02:00
Bartosz Taudul
69dd0b72c1
Just accept const char ptr in ImGuiColorTextEdit.
2018-08-18 01:16:15 +02:00
Bartosz Taudul
2c7d457755
Highlight source buttons, if source file is displayed.
2018-08-18 00:28:36 +02:00
Bartosz Taudul
e8da52324d
Add memory icon to memory usage plot name.
2018-08-18 00:24:23 +02:00
Bartosz Taudul
07952f0a1f
Add icons to options menu.
2018-08-18 00:21:01 +02:00
Bartosz Taudul
8db30a9016
Add icon to statistics menu.
2018-08-18 00:09:23 +02:00
Bartosz Taudul
816c91922e
Add icons to memory menu.
2018-08-17 23:58:52 +02:00
Bartosz Taudul
441a5e257c
Add wifi icon to "waiting for connection" window.
2018-08-17 23:56:06 +02:00
Bartosz Taudul
b613a60c88
Add icons to compare menu.
2018-08-17 23:54:40 +02:00
Bartosz Taudul
4c228fe862
Add icons to find zone menu.
2018-08-17 23:52:03 +02:00
Bartosz Taudul
350fb6a5b0
Add icons to zone info window buttons.
2018-08-17 23:47:01 +02:00
Bartosz Taudul
cdee1d4ce4
Remove obsolete frame rounding setting.
2018-08-17 23:27:14 +02:00
Bartosz Taudul
0aebf614db
Add icons to pause/resume button.
2018-08-17 23:24:25 +02:00
Bartosz Taudul
940dda8fc1
Use helper header for icons.
2018-08-17 23:22:13 +02:00
Bartosz Taudul
4c393a2b8d
Allow opening source files from withing call stack tree.
2018-08-17 22:51:26 +02:00
Bartosz Taudul
4e23ce9a24
Shared index for all call stack tree nodes.
2018-08-17 22:31:55 +02:00
Bartosz Taudul
07d2aaa1ad
Play a little animation when source file cannot be opened.
2018-08-17 22:23:16 +02:00
Bartosz Taudul
12f2080387
Right click on call stack file name to view source.
2018-08-17 22:06:59 +02:00
Bartosz Taudul
5752156695
Use "call stack" instead of "callstack".
2018-08-17 22:00:35 +02:00
Bartosz Taudul
0de3e088d9
Use icons in main profiler window buttons.
2018-08-17 19:03:35 +02:00
Bartosz Taudul
92284b65e7
Use save file icon.
2018-08-17 18:36:06 +02:00
Bartosz Taudul
9b1af05472
Use power off icon.
2018-08-17 18:33:56 +02:00
Bartosz Taudul
5125c2487b
Use exclamation icon instead of ascii representation.
2018-08-17 17:57:13 +02:00
Bartosz Taudul
2b3490e6f7
Handle window title setter callback in View.
2018-08-17 17:24:18 +02:00
Bartosz Taudul
b7ac41ab1b
Make the warning signs stand out more.
2018-08-17 17:08:16 +02:00
Bartosz Taudul
b76707ffa1
Render main profiler view in whole window.
2018-08-17 17:00:56 +02:00
Bartosz Taudul
9416f5bb49
Add close button to loaded traces (not the window close one).
2018-08-17 16:34:58 +02:00
Bartosz Taudul
facae0b9e1
Draw text editor with potential source code.
2018-08-17 15:33:12 +02:00
Bartosz Taudul
d45efbe640
Don't reload source file, if it's already there.
2018-08-17 15:24:52 +02:00
Bartosz Taudul
5dc3d73ad6
Set cursor on proper line.
2018-08-17 15:21:37 +02:00
Bartosz Taudul
5cd61c4b07
Text editor needs fixed-width font.
2018-08-17 15:18:09 +02:00
Bartosz Taudul
5bd35eb34e
Open file preview in text editor.
2018-08-17 14:54:28 +02:00
Bartosz Taudul
9dbc56beb6
Initialize text editor.
2018-08-17 14:44:41 +02:00
Bartosz Taudul
8cbb518f28
Display average allocation sizes.
2018-08-14 18:48:29 +02:00
Bartosz Taudul
df14cf5330
Implement callstack tree of memory allocations.
2018-08-14 18:37:06 +02:00
Bartosz Taudul
c2c0f887aa
Display srcloc, callstack counts.
2018-08-14 16:41:27 +02:00
Bartosz Taudul
68dd90cb94
Also display exact memory allocation size.
2018-08-09 02:27:55 +02:00
Bartosz Taudul
92c1685528
Fix shortening of negative memory values.
2018-08-09 02:25:47 +02:00
Bartosz Taudul
96ecf47ecf
Add profiler FPS and memory usage to info window.
2018-08-08 20:53:01 +02:00
Bartosz Taudul
4a9cbafc7e
Proper formatting of memory sizes.
2018-08-08 20:38:58 +02:00
Bartosz Taudul
7d465aab1d
Add memory size formatting.
2018-08-08 20:38:58 +02:00
Bartosz Taudul
29c6498890
Add minimal trace info window.
2018-08-08 19:25:13 +02:00
Bartosz Taudul
237bb06dd6
Move frame set selection button to the right.
2018-08-08 18:40:31 +02:00
Bartosz Taudul
3e622cda6b
Decapitalize "zone" in "Find Zone".
2018-08-08 18:40:20 +02:00
Bartosz Taudul
2a08687afe
Left click on message marker displays it on the msg list.
2018-08-05 16:57:21 +02:00
Bartosz Taudul
1d6f388a81
Middle-click on message marker to center on it.
2018-08-05 16:47:49 +02:00
Bartosz Taudul
1d0203ac17
Abstracted away one-frame-decay values.
2018-08-05 16:45:34 +02:00
Bartosz Taudul
44e027ad11
Highlight message markers on timeline.
2018-08-05 16:37:51 +02:00
Bartosz Taudul
eb7064f13d
Display frame set tooltip.
2018-08-05 13:33:18 +02:00
Bartosz Taudul
44fecc4390
Improve rendering of small discontinuous frames.
2018-08-05 13:29:44 +02:00
Bartosz Taudul
d590fa7ce2
Display that frames are discontinuous in options.
2018-08-05 02:30:41 +02:00
Bartosz Taudul
cb9f243987
Fix navigation in discontinuous frames.
2018-08-05 02:27:59 +02:00
Bartosz Taudul
947f829797
Fix drawing discontinuous frames.
2018-08-05 02:23:26 +02:00
Bartosz Taudul
cbb45160af
Disable zoom anim on user interaction.
2018-08-05 01:23:00 +02:00
Bartosz Taudul
1b44b31eff
Prevent range-zoom when range has zero length.
2018-08-05 01:20:26 +02:00
Bartosz Taudul
2acea5da3c
Also draw zig-zag on too-small zones.
2018-08-04 23:32:53 +02:00
Bartosz Taudul
3869c1dbca
Count frames from 1, not 0.
2018-08-04 23:21:58 +02:00
Bartosz Taudul
6b8a3b25ba
Fix drawing of last frame.
2018-08-04 23:19:35 +02:00
Bartosz Taudul
9cd6932b13
Draw zig-zag in place of invisible (too small) frames.
2018-08-04 23:11:47 +02:00
Bartosz Taudul
f385e5520b
Draw frame separators only if the frame set is selected.
2018-08-04 21:51:46 +02:00
Bartosz Taudul
1282aa9739
Darken frame set counter, if it is disabled.
2018-08-04 21:48:40 +02:00
Bartosz Taudul
37f42a52fb
Proper frame names on frames graph.
2018-08-04 21:46:26 +02:00
Bartosz Taudul
acabdf3c2a
Implement switching between frame sets.
2018-08-04 21:43:29 +02:00
Bartosz Taudul
88d9307d7a
Allow disabling frame sets.
2018-08-04 21:26:01 +02:00
Bartosz Taudul
1ea1cd57b3
Use proper frame names.
2018-08-04 21:19:24 +02:00
Bartosz Taudul
aad3e941e5
Draw multiple frame sets.
2018-08-04 21:10:45 +02:00
Bartosz Taudul
5e9b2e36be
Make getting start of time less cryptic.
2018-08-04 21:10:45 +02:00
Bartosz Taudul
23dfc2e3fc
Multiple frame sets support.
2018-08-04 21:10:45 +02:00
Bartosz Taudul
8de214b4d5
Display number of events for items in options menu.
2018-08-04 15:09:52 +02:00
Bartosz Taudul
ea588072f2
Stop connection window from jumping around.
2018-08-04 14:50:31 +02:00
Bartosz Taudul
672925ac04
Add separators to frame numbers.
2018-07-29 21:56:30 +02:00
Bartosz Taudul
0d76ccfb71
Add days to time-to-string converter.
2018-07-29 21:14:56 +02:00
Bartosz Taudul
d04126eabe
Make time-to-string more readable.
2018-07-29 21:09:11 +02:00
Bartosz Taudul
2eddbeb164
Use ctrl key to zoom-out using selection range.
2018-07-29 20:53:29 +02:00
Bartosz Taudul
1cf168c95e
Fix impossible zoom animation.
2018-07-29 20:53:29 +02:00
Bartosz Taudul
310203101f
Stop zoom-range-selection when zooming to range.
...
This also disables zoom range selection when middle click is used to
zoom view to a selected zone.
2018-07-29 20:53:29 +02:00
Bartosz Taudul
b4f4fcfde9
Add zoom-to-middle-mouse-button-selection-range.
2018-07-29 20:15:49 +02:00
Bartosz Taudul
8ddf32bc6b
Highlight zones with the same srcloc on hover.
2018-07-28 19:53:11 +02:00
Bartosz Taudul
6a3a9c0bc5
Load second trace on a separate thread.
2018-07-28 18:47:33 +02:00
Bartosz Taudul
a54ff1f56d
Use 'μ' instead of 'u' to indicate micro.
2018-07-28 01:06:36 +02:00
Bartosz Taudul
149812c071
Always keep main profiler window on bottom.
2018-07-26 23:38:45 +02:00
Bartosz Taudul
7d7877517e
Also remove child vectors from GPU events.
2018-07-22 19:47:01 +02:00
Bartosz Taudul
3a934b2ba3
Store children vectors in a separate data collection.
...
This reduces per-zone memory cost by 9 bytes if there are no children
and increases it by 4 bytes, if there are children. This is universally
a better solution, as the following data shows:
+++ /home/wolf/desktop/tracy-old/android.tracy +++
Vectors: 2794480
Size 0: 2373070 (84.92%)
Size 1: 70237 (2.51%)
Size 2+: 351173 (12.57%)
+++ /home/wolf/desktop/tracy-old/asset-new.tracy +++
Vectors: 1799227
Size 0: 1482691 (82.41%)
Size 1: 93272 (5.18%)
Size 2+: 223264 (12.41%)
+++ /home/wolf/desktop/tracy-old/asset-new-id.tracy +++
Vectors: 1977996
Size 0: 1640817 (82.95%)
Size 1: 97198 (4.91%)
Size 2+: 239981 (12.13%)
+++ /home/wolf/desktop/tracy-old/asset-old.tracy +++
Vectors: 1782395
Size 0: 1471437 (82.55%)
Size 1: 88813 (4.98%)
Size 2+: 222145 (12.46%)
+++ /home/wolf/desktop/tracy-old/big.tracy +++
Vectors: 180794047
Size 0: 172696094 (95.52%)
Size 1: 2799772 (1.55%)
Size 2+: 5298181 (2.93%)
+++ /home/wolf/desktop/tracy-old/darkrl.tracy +++
Vectors: 12014129
Size 0: 11611324 (96.65%)
Size 1: 134980 (1.12%)
Size 2+: 267825 (2.23%)
+++ /home/wolf/desktop/tracy-old/mem.tracy +++
Vectors: 383097
Size 0: 321932 (84.03%)
Size 1: 854 (0.22%)
Size 2+: 60311 (15.74%)
+++ /home/wolf/desktop/tracy-old/new.tracy +++
Vectors: 77536
Size 0: 63035 (81.30%)
Size 1: 8886 (11.46%)
Size 2+: 5615 (7.24%)
+++ /home/wolf/desktop/tracy-old/selfprofile.tracy +++
Vectors: 22940871
Size 0: 22704868 (98.97%)
Size 1: 73000 (0.32%)
Size 2+: 163003 (0.71%)
+++ /home/wolf/desktop/tracy-old/tbrowser.tracy +++
Vectors: 962682
Size 0: 695380 (72.23%)
Size 1: 43007 (4.47%)
Size 2+: 224295 (23.30%)
+++ /home/wolf/desktop/tracy-old/virtualfile_hc.tracy +++
Vectors: 529170
Size 0: 449386 (84.92%)
Size 1: 15694 (2.97%)
Size 2+: 64090 (12.11%)
+++ /home/wolf/desktop/tracy-old/zfile_hc.tracy +++
Vectors: 264849
Size 0: 220589 (83.29%)
Size 1: 9386 (3.54%)
Size 2+: 34874 (13.17%)
2018-07-22 16:05:50 +02:00
Bartosz Taudul
be40ee9dbc
Fix crash when there's no callstack.
2018-07-22 00:13:23 +02:00
Bartosz Taudul
59c188a18d
Invalid callstack is 0, not UINT64_MAX.
2018-07-22 00:13:11 +02:00
Bartosz Taudul
fbfc0e151d
Replace combo lists with radio buttons.
2018-07-22 00:04:41 +02:00
Bartosz Taudul
d1cef20c0b
Allow sorting groups by time.
2018-07-21 23:58:50 +02:00
Bartosz Taudul
59e0f3d490
Use precalculated zone group time.
2018-07-21 23:54:35 +02:00
Bartosz Taudul
cacbac8915
Calculate and display group times.
2018-07-21 23:53:11 +02:00
Bartosz Taudul
d03356c1f5
Rename "threads" to "groups" in find zone data structs.
2018-07-21 23:41:50 +02:00
Bartosz Taudul
36c207fb51
Fix some unused variables.
2018-07-21 21:35:35 +02:00
Bartosz Taudul
9291a88020
Zones can be now also grouped by call stack.
2018-07-21 20:26:13 +02:00
Bartosz Taudul
3c6baf53da
Memory alloc range hover also works on allocation lists.
2018-07-19 15:55:15 +02:00
Bartosz Taudul
389e0facd3
Draw memory allocation range on mouse hover on mem event.
2018-07-19 15:43:45 +02:00
Bartosz Taudul
108ba20af8
Fix closing memory allocation info window.
2018-07-18 00:25:02 +02:00
Bartosz Taudul
e8726c72b1
Display memory allocation range on memory plot.
2018-07-18 00:21:16 +02:00
Bartosz Taudul
9ab09d9867
Only show "same zone" if zones are valid.
2018-07-17 23:32:29 +02:00
Bartosz Taudul
84d0f1a3ea
Indicate inspected memory address on alloc list.
2018-07-17 23:17:46 +02:00
Bartosz Taudul
cf3bf4378b
No need to return MemEvent ptr from DrawAddress().
2018-07-17 23:13:56 +02:00
Bartosz Taudul
18a460e782
Clicking on mem address in alloc list displays info window.
2018-07-17 23:08:10 +02:00
Bartosz Taudul
0889334462
Add memory allocation info window.
2018-07-17 23:03:03 +02:00
Bartosz Taudul
6485a090ed
Separate small callstack button setup.
2018-07-17 22:53:38 +02:00
Rokas Kupstys
abfa90012f
Fix build errors with some compilers due to using std::max(float, double).
2018-07-17 16:36:41 +03:00
Bartosz Taudul
807d2a02bc
Display collapsed zones counts with separators.
2018-07-16 01:24:43 +02:00
Bartosz Taudul
acf3bc7d43
Show only contended locks by default.
2018-07-15 20:29:35 +02:00
Bartosz Taudul
561d2dc360
Use the fastest mutex available.
...
The selection is based on the following test results:
MSVC:
=== Lock test, 6 threads ===
=> NonRecursiveBenaphore
No contention: 11.641 ns/iter
2 thread contention: 141.559 ns/iter
3 thread contention: 242.733 ns/iter
4 thread contention: 409.807 ns/iter
5 thread contention: 561.544 ns/iter
6 thread contention: 785.845 ns/iter
=> std::mutex
No contention: 19.190 ns/iter
2 thread contention: 39.305 ns/iter
3 thread contention: 58.999 ns/iter
4 thread contention: 59.532 ns/iter
5 thread contention: 103.539 ns/iter
6 thread contention: 110.314 ns/iter
=> std::shared_timed_mutex
No contention: 45.487 ns/iter
2 thread contention: 96.351 ns/iter
3 thread contention: 142.871 ns/iter
4 thread contention: 184.999 ns/iter
5 thread contention: 336.608 ns/iter
6 thread contention: 542.551 ns/iter
=> std::shared_mutex
No contention: 10.861 ns/iter
2 thread contention: 17.495 ns/iter
3 thread contention: 31.126 ns/iter
4 thread contention: 40.468 ns/iter
5 thread contention: 15.677 ns/iter
6 thread contention: 64.505 ns/iter
Cygwin (clang):
=== Lock test, 6 threads ===
=> NonRecursiveBenaphore
No contention: 11.536 ns/iter
2 thread contention: 121.082 ns/iter
3 thread contention: 396.430 ns/iter
4 thread contention: 672.555 ns/iter
5 thread contention: 1327.761 ns/iter
6 thread contention: 14151.955 ns/iter
=> std::mutex
No contention: 62.583 ns/iter
2 thread contention: 3990.464 ns/iter
3 thread contention: 7161.189 ns/iter
4 thread contention: 9870.820 ns/iter
5 thread contention: 12355.178 ns/iter
6 thread contention: 14694.903 ns/iter
=> std::shared_timed_mutex
No contention: 91.687 ns/iter
2 thread contention: 1115.037 ns/iter
3 thread contention: 4183.792 ns/iter
4 thread contention: 15283.491 ns/iter
5 thread contention: 27812.477 ns/iter
6 thread contention: 35028.140 ns/iter
=> std::shared_mutex
No contention: 91.764 ns/iter
2 thread contention: 1051.826 ns/iter
3 thread contention: 5574.720 ns/iter
4 thread contention: 15721.416 ns/iter
5 thread contention: 27721.487 ns/iter
6 thread contention: 35420.404 ns/iter
Linux (x64):
=== Lock test, 6 threads ===
=> NonRecursiveBenaphore
No contention: 13.487 ns/iter
2 thread contention: 210.317 ns/iter
3 thread contention: 430.855 ns/iter
4 thread contention: 510.533 ns/iter
5 thread contention: 1003.609 ns/iter
6 thread contention: 1787.683 ns/iter
=> std::mutex
No contention: 12.403 ns/iter
2 thread contention: 157.122 ns/iter
3 thread contention: 186.791 ns/iter
4 thread contention: 265.073 ns/iter
5 thread contention: 283.778 ns/iter
6 thread contention: 270.687 ns/iter
=> std::shared_timed_mutex
No contention: 21.509 ns/iter
2 thread contention: 150.179 ns/iter
3 thread contention: 256.574 ns/iter
4 thread contention: 415.351 ns/iter
5 thread contention: 611.532 ns/iter
6 thread contention: 944.695 ns/iter
=> std::shared_mutex
No contention: 20.805 ns/iter
2 thread contention: 157.034 ns/iter
3 thread contention: 244.025 ns/iter
4 thread contention: 406.269 ns/iter
5 thread contention: 387.985 ns/iter
6 thread contention: 468.550 ns/iter
Linux (arm64):
=== Lock test, 6 threads ===
=> NonRecursiveBenaphore
No contention: 20.891 ns/iter
2 thread contention: 211.037 ns/iter
3 thread contention: 409.962 ns/iter
4 thread contention: 657.441 ns/iter
5 thread contention: 828.405 ns/iter
6 thread contention: 1131.827 ns/iter
=> std::mutex
No contention: 50.884 ns/iter
2 thread contention: 103.620 ns/iter
3 thread contention: 332.429 ns/iter
4 thread contention: 620.802 ns/iter
5 thread contention: 783.943 ns/iter
6 thread contention: 834.002 ns/iter
=> std::shared_timed_mutex
No contention: 64.948 ns/iter
2 thread contention: 173.191 ns/iter
3 thread contention: 490.352 ns/iter
4 thread contention: 660.668 ns/iter
5 thread contention: 1014.546 ns/iter
6 thread contention: 1451.553 ns/iter
=> std::shared_mutex
No contention: 64.521 ns/iter
2 thread contention: 195.222 ns/iter
3 thread contention: 490.819 ns/iter
4 thread contention: 654.786 ns/iter
5 thread contention: 955.759 ns/iter
6 thread contention: 1282.544 ns/iter
2018-07-14 00:39:01 +02:00
Bartosz Taudul
a26ab263dd
Select/unselect all plot visibility.
2018-07-14 00:10:38 +02:00
Bartosz Taudul
f4f7e58e88
Add select/unselect all threads visibility option.
2018-07-14 00:08:37 +02:00
Arvid Gerstmann
0b1c2ebc8f
Define M_PI_2 if not already done
2018-07-13 23:41:12 +02:00
Bartosz Taudul
96042891f7
Reintroduce explicit template type for std::lock_guard.
...
Requested in issue #4 for support of older MSVC versions.
2018-07-13 12:30:29 +02:00
Bartosz Taudul
fe449f366f
Use frame offset for frame count and missed frames display.
2018-07-10 22:51:24 +02:00
Bartosz Taudul
a5381337f6
Don't use obsolete function.
2018-07-10 20:49:29 +02:00
Bartosz Taudul
045f792e84
Keep one profiler window size for all captures.
2018-07-10 20:47:09 +02:00
Bartosz Taudul
c7952e4d4f
Move "without profiling" to tooltip in zone info window.
2018-06-29 19:02:44 +02:00
Bartosz Taudul
4ae317109d
Improve compare menu histogram tooltip.
2018-06-29 18:57:49 +02:00
Bartosz Taudul
b190a15ef6
Display numerical thread id in memory plot tooltip.
2018-06-29 18:54:19 +02:00
Bartosz Taudul
9329c761f6
Improve plot tooltips.
2018-06-29 18:52:28 +02:00
Bartosz Taudul
bcd2fc027d
Improve lock tooltips.
2018-06-29 18:49:47 +02:00
Bartosz Taudul
a918d9a401
Improve compressed zones tooltips.
2018-06-29 18:47:33 +02:00
Bartosz Taudul
c8361205da
Improve timeline tooltips.
2018-06-29 18:46:05 +02:00
Bartosz Taudul
8228f4131b
Improve frame header tooltip.
2018-06-29 18:44:07 +02:00
Bartosz Taudul
c92d8cf7a3
Improve frame list tooltips.
2018-06-29 18:43:23 +02:00
Bartosz Taudul
201a40fb04
Improve readability of callstack tooltips.
2018-06-29 18:41:06 +02:00
Bartosz Taudul
400ee1c752
Improve readability of zone tooltips.
2018-06-29 18:39:20 +02:00
Bartosz Taudul
fbe0ad437e
Remove "without profiling" entry from zone tooltip.
2018-06-29 18:36:58 +02:00
Bartosz Taudul
d01c14c2f3
Improve readability of compare menu.
2018-06-29 18:35:40 +02:00
Bartosz Taudul
91dd8f5d52
Improve readability of find zone menu.
2018-06-29 18:33:01 +02:00
Bartosz Taudul
8f4b09edc3
Improve zone info windows readability.
2018-06-29 18:27:34 +02:00
Bartosz Taudul
275a79e1c9
Display custom zone name in find zone results list.
2018-06-29 16:20:24 +02:00
Bartosz Taudul
ab18869ce6
Display custom zone name in zone tooltip.
2018-06-29 16:15:59 +02:00
Bartosz Taudul
09c38f17e6
Display custom zone name in zone info window.
2018-06-29 16:14:31 +02:00
Bartosz Taudul
865e8d8506
Extract zone name getting functionality.
2018-06-29 15:14:20 +02:00
Bartosz Taudul
2866cafda5
Adapt histogram height to font size.
2018-06-29 00:44:05 +02:00
Bartosz Taudul
f82e8aa98f
Adapt plot height to font size.
2018-06-29 00:38:56 +02:00
Bartosz Taudul
cc196ff0a8
Adapt frames view to font size.
2018-06-29 00:35:44 +02:00
Bartosz Taudul
41e8648701
Adjust GPU zones to set time drift.
2018-06-28 01:12:25 +02:00
Bartosz Taudul
0b9559c05b
Retrieval of GPU context from GPU zone.
2018-06-28 01:07:21 +02:00
Bartosz Taudul
c3238a496d
No need to check for frame function name match.
...
Firstly, the match is not necessarily possible (e.g. on Linux the source
location function names and callstack frame names are two completely
different things).
Secondly, the first current zone callstack frame (which is matched to
some callstack frame of previous zone) is the frame in which a zone was
captured, and it will already be present in the zone trace. The
callstack frame omission should be therefore unconditional.
2018-06-24 17:38:32 +02:00
Bartosz Taudul
77e139e900
Insert true call stack frames into zone trace.
2018-06-24 16:57:57 +02:00
Bartosz Taudul
fa62603c77
Move zone trace loop handler to a separate function.
2018-06-24 15:54:36 +02:00
Bartosz Taudul
17194cb591
Allow copying callstack frames name/file to clipboard.
2018-06-22 20:44:57 +02:00
Bartosz Taudul
b8f7a4daac
Mention purple line indicating middle of timeline.
2018-06-22 20:34:08 +02:00
Bartosz Taudul
9c2aab733d
Allow centering timeline on memory alloc/free time.
2018-06-22 20:32:38 +02:00
Bartosz Taudul
5f5fe7c6aa
Add tip about centering timeline on message.
2018-06-22 20:23:56 +02:00
Bartosz Taudul
39eccd5b08
Extract "center view at time" function.
2018-06-22 20:21:02 +02:00
Bartosz Taudul
d13fc2413f
Highlight callstack button in zone info windows.
2018-06-22 02:24:36 +02:00
Bartosz Taudul
e5f673eaa0
Allow viewing callstack from gpu zone info window.
2018-06-22 01:58:25 +02:00
Bartosz Taudul
e40c5068c9
Allow viewing callstack from zone info window.
2018-06-22 01:21:51 +02:00
Bartosz Taudul
3404d191f0
Fix non-unique child ids in memory window.
2018-06-22 00:10:00 +02:00
Bartosz Taudul
3f7ab10323
Don't show line number if it's 0.
2018-06-21 13:26:04 +02:00
Bartosz Taudul
cef972fe25
Remove parenthesis from callstack location.
2018-06-20 17:07:48 +02:00
Bartosz Taudul
e95ca3930d
Make all allocation list alloc/free buttons clickable.
2018-06-20 14:50:07 +02:00
Bartosz Taudul
a9fa8f966b
Fix "zone free" indentation in allocation list.
2018-06-20 14:44:24 +02:00
Bartosz Taudul
bc565e65d1
Better callstack info window layout.
2018-06-20 14:41:00 +02:00
Bartosz Taudul
0d509ea3a6
Add missing EndColumns() call.
2018-06-20 14:37:55 +02:00
Bartosz Taudul
be0a70a5c1
Highlight actively inspected callstack.
2018-06-20 13:49:23 +02:00
Bartosz Taudul
15ff98b64a
Push detailed callstack to a separate window.
...
Only show function names (no source files or line numbers) in callstack
tooltip.
2018-06-20 13:23:08 +02:00
Bartosz Taudul
56479b86fa
Display frame details in callstack tooltip.
2018-06-20 01:19:10 +02:00
Bartosz Taudul
4ba95145da
Display raw callstack payload.
2018-06-19 22:19:33 +02:00
Bartosz Taudul
021dd853b9
Differentiate Vulkan/OpenGL in options menu.
2018-06-18 01:08:56 +02:00
Bartosz Taudul
6e1ab9ae7a
Display per-GPU-event threads.
2018-06-17 19:09:56 +02:00
Bartosz Taudul
f33584516b
Fix yet another regression.
2018-06-17 18:37:38 +02:00
Bartosz Taudul
cc973a5091
Differentiate Vulkan and OpenGL contexts.
2018-06-17 18:33:05 +02:00
Bartosz Taudul
6956aed769
Fix selecting last bin with log time in find zone.
2018-06-06 23:36:21 +02:00
Bartosz Taudul
b4ce0c281b
Total time is also already known in compare view.
2018-06-06 23:17:13 +02:00
Bartosz Taudul
d49be792ba
Cache bin containers in compare view.
2018-06-06 23:09:46 +02:00
Bartosz Taudul
da5d35c364
Cache bin containers in find zone.
2018-06-06 23:06:00 +02:00
Bartosz Taudul
2950f3c70c
Total time is already known.
2018-06-06 23:00:18 +02:00
Bartosz Taudul
8a4d88f2b3
tmin and tmax don't change.
2018-06-06 23:00:03 +02:00
Bartosz Taudul
be8d3f47cd
Use fast log10.
2018-06-06 01:59:31 +02:00
Bartosz Taudul
8696c81e7d
Implement fast frexpf.
2018-06-06 01:59:31 +02:00
Bartosz Taudul
60b24249d3
Use explicit value for 1/log2(10).
2018-06-06 01:52:46 +02:00
Bartosz Taudul
39c1b20184
Don't care about previous values.
2018-06-06 01:23:49 +02:00
Bartosz Taudul
1c47e22eca
Add log10f approximation.
...
Based on https://community.arm.com/tools/f/discussions/4292/cmsis-dsp-new-functionality-proposal/22621#22621
2018-06-06 01:23:29 +02:00
Bartosz Taudul
859bf01992
Support displaying self times in statistics view.
2018-06-06 00:47:16 +02:00
Bartosz Taudul
e5d35d443d
Missing initializer.
2018-06-06 00:47:11 +02:00
Bartosz Taudul
785a30a68b
Implement going to next/previous frame.
2018-06-02 22:27:35 +02:00
Bartosz Taudul
1cddf8436c
ZoomToRange() already enables pause.
2018-06-02 22:09:07 +02:00
Bartosz Taudul
5a7304171d
Fix allocation times displayed in plot tooltip.
2018-05-27 20:22:58 +02:00
Bartosz Taudul
8ed59c261b
Open memory address info after clicking on mem plot item.
2018-05-27 20:17:20 +02:00
Bartosz Taudul
9898066a7a
Display additional memory event info in mem plot tooltips.
2018-05-27 20:11:33 +02:00
Bartosz Taudul
3ea5fd93ed
Simple and not so simple draw plot point functions.
2018-05-27 19:51:45 +02:00
Bartosz Taudul
0a79243332
Display thread from which message originated on msg list.
2018-05-25 21:14:15 +02:00
Bartosz Taudul
8118e41559
Use columns to display message list.
2018-05-25 21:10:38 +02:00
Bartosz Taudul
dbc963d55c
Drop template argument from std::lock_guard.
2018-05-08 01:25:16 +02:00
Bartosz Taudul
7d32ef8c8b
Restrict mem events list size.
2018-05-02 19:40:35 +02:00
Bartosz Taudul
f2cb04ea8d
Allow going back to the previous zone info.
2018-05-02 19:25:52 +02:00
Bartosz Taudul
1cc798cea3
Construct zone info stack.
2018-05-02 19:23:46 +02:00
Bartosz Taudul
e28022f735
Don't display alloc, free threads on two lines.
2018-05-02 19:07:34 +02:00
Bartosz Taudul
f2f712b8db
Optional display of each mem event in zone info window.
2018-05-02 19:03:34 +02:00
Bartosz Taudul
dac6a65156
Infer total mem usage change from alloc and free changes.
2018-05-02 18:41:11 +02:00
Bartosz Taudul
bbf1e9f111
Only include memory events from zone thread.
2018-05-02 18:13:13 +02:00
Bartosz Taudul
4584ef9e88
Use memory events to calculate zone memory changes.
2018-05-02 18:06:27 +02:00
Bartosz Taudul
ce1f56ea0f
Display zone memory statistics.
...
Note that this information is incorrect, as it accounts for memory
events in all threads.
2018-05-02 17:46:09 +02:00
Bartosz Taudul
fd59ac0125
Only calculate zone child data if child list is displayed.
2018-05-02 17:23:32 +02:00
Bartosz Taudul
1512f3584c
Show appropriate message when there's no memory data collected.
2018-05-01 17:28:02 +02:00
Bartosz Taudul
e5934b409a
Don't use Vector for memory pages storage.
...
Vector has POT data size and we know exactly how much is needed.
2018-05-01 17:26:34 +02:00
Bartosz Taudul
76f0c8fafe
Sort source location zones on a separate thread.
2018-04-30 03:54:09 +02:00
Bartosz Taudul
4c521ce92a
Loaded traces may be unloaded.
2018-04-30 01:16:08 +02:00
Bartosz Taudul
925b6c2617
Display y-range of plots.
2018-04-28 16:44:36 +02:00
Bartosz Taudul
afa432a087
Non-user plots must have predefined names.
2018-04-28 16:26:45 +02:00
Bartosz Taudul
2a427ba87a
Fix typo.
2018-04-22 02:24:34 +02:00
Bartosz Taudul
ecabf24c4e
Optional normalization of compared data.
2018-04-22 02:19:22 +02:00
Bartosz Taudul
d06890b55d
Add missing tree pop.
2018-04-22 01:28:55 +02:00
Bartosz Taudul
470bfb5c02
Don't load unneeded data.
2018-04-22 01:00:17 +02:00
Bartosz Taudul
41738469f1
Add trace compare window.
2018-04-22 00:52:33 +02:00
Bartosz Taudul
1d044b494b
Don't enforce main window buttons width.
2018-04-21 22:42:32 +02:00
Bartosz Taudul
880eb7cbdd
Don't display zone names in find zone menu zones list.
2018-04-21 22:34:19 +02:00
Bartosz Taudul
adf8a126c6
More space for text on main window buttons.
2018-04-21 19:30:49 +02:00
Bartosz Taudul
a4e1bb05f3
Use proper format strings.
2018-04-21 19:26:55 +02:00
Bartosz Taudul
ade97b7ab6
Add hours to time-to-string conversion.
2018-04-21 17:01:10 +02:00
Bartosz Taudul
ad91b9b002
Expand maximum view span from 1 minute to 1 hour.
2018-04-21 16:53:17 +02:00
Bartosz Taudul
3793a37b2b
Use small buttons in statistics window.
2018-04-21 14:17:42 +02:00
Bartosz Taudul
6c2d7628ee
Don't draw off-screen gpu zones.
2018-04-20 23:28:19 +02:00
Bartosz Taudul
a2779eccaf
Don't draw off-screen zones.
2018-04-20 23:19:04 +02:00
Bartosz Taudul
9fc14d2faf
Don't draw off-screen plots.
2018-04-20 23:00:26 +02:00
Bartosz Taudul
cd7a1cffe8
Don't draw off-screen locks.
2018-04-20 22:53:31 +02:00
Bartosz Taudul
723fad84a7
Don't draw off-screen zone timeline labels.
2018-04-20 22:45:29 +02:00
Bartosz Taudul
6120b3e922
Change -1 comparisons to "0" comparisons.
2018-04-14 16:50:04 +02:00
Bartosz Taudul
d0d5528e99
Disable histogram highlight using right mouse button.
2018-04-14 15:21:22 +02:00
Bartosz Taudul
fd41b4927a
Allow selecting/unselecting all locks for display.
2018-04-09 16:15:40 +02:00
Bartosz Taudul
d4bfbc2797
Allow displaying global statistics of a zone.
2018-04-05 19:31:04 +02:00
Bartosz Taudul
093787b3e8
Move find zone setup to a dedicated function.
2018-04-05 19:30:32 +02:00
Bartosz Taudul
0f95d7fd21
Use lookup table to get memory decay color.
2018-04-05 12:14:26 +02:00
Bartosz Taudul
bb299a5074
Desaturate older allocations on memory map.
2018-04-03 20:38:50 +02:00
Bartosz Taudul
189a4a2e32
Page chunk mask is not needed anymore.
2018-04-03 19:41:11 +02:00
Bartosz Taudul
1182a3fcb8
Stop processing allocations if already at time end.
2018-04-03 19:40:06 +02:00
Bartosz Taudul
b78dc70b70
No need to split address into page and chunk.
2018-04-03 19:39:19 +02:00
Bartosz Taudul
22bd2923eb
Keep mem.low in a register.
2018-04-03 19:35:43 +02:00
Bartosz Taudul
a3dd90529c
Rearrange memory reads.
2018-04-03 19:35:28 +02:00
Bartosz Taudul
197e513727
Add a separate time restriction code path.
2018-04-03 19:34:48 +02:00
Bartosz Taudul
f0573d68bd
Store memory pages in a contiguous memory area.
2018-04-03 19:17:32 +02:00