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
|
18896044c4
|
Display explicit names of loaded things.
|
2018-07-29 16:56:46 +02:00 |
|
Bartosz Taudul
|
9f13475b52
|
Track trace version in worker.
|
2018-07-29 15:33:48 +02:00 |
|
Bartosz Taudul
|
13509c14f1
|
Save size of 'active' and 'frees' memory data structures.
|
2018-07-29 15:29:56 +02:00 |
|
Bartosz Taudul
|
00d07e39f7
|
Save threadExpand size to allow vector preallocation.
|
2018-07-29 15:19:44 +02:00 |
|
Bartosz Taudul
|
bff6eb4c34
|
Save source location zones counts.
This allows preallocation of zones-in-source-location vectors.
|
2018-07-29 14:58:01 +02:00 |
|
Bartosz Taudul
|
12b90d1630
|
Move tracy version to a separate header.
|
2018-07-29 14:20:44 +02:00 |
|
Bartosz Taudul
|
ccc5c37af5
|
Always count source location zones.
|
2018-07-29 14:16:13 +02:00 |
|
Bartosz Taudul
|
4456c8a454
|
Reserve space for string data.
|
2018-07-29 14:13:29 +02:00 |
|
Bartosz Taudul
|
766bf45a2b
|
Fix initialization of atomics.
|
2018-07-28 20:13:06 +02:00 |
|
Bartosz Taudul
|
8ddf32bc6b
|
Highlight zones with the same srcloc on hover.
|
2018-07-28 19:53:11 +02:00 |
|
Bartosz Taudul
|
648070e6a1
|
Include each loaded zone in sub progress.
|
2018-07-28 19:22:28 +02:00 |
|
Bartosz Taudul
|
4741dab833
|
Track sub progress.
|
2018-07-28 19:05:01 +02:00 |
|
Bartosz Taudul
|
a14238c199
|
Add sub progress display.
|
2018-07-28 18:56:52 +02:00 |
|
Bartosz Taudul
|
6a3a9c0bc5
|
Load second trace on a separate thread.
|
2018-07-28 18:47:33 +02:00 |
|
Bartosz Taudul
|
a46425f4e9
|
Adjust load stages.
|
2018-07-28 18:26:00 +02:00 |
|
Bartosz Taudul
|
0bf0ceed3d
|
Track trace loading progress.
|
2018-07-28 17:59:17 +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
|
d84d0b7754
|
Don't try to read empty timelines.
|
2018-07-22 21:15:28 +02:00 |
|
Bartosz Taudul
|
25116a8059
|
Don't try to compress invalid thread.
|
2018-07-22 21:13:42 +02:00 |
|
Bartosz Taudul
|
010cf66e43
|
Call Vector destructors.
|
2018-07-22 21:01:45 +02:00 |
|
Bartosz Taudul
|
29159069ab
|
Properly initialize child index.
|
2018-07-22 20:14:55 +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
|
eb1475ebd4
|
Add single-value Vector constructor.
|
2018-07-22 16:01:58 +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 |
|
Bartosz Taudul
|
fc310ce15a
|
Fix check.
|
2018-07-17 18:29:07 +02:00 |
|
Rokas Kupstys
|
8a8faa3d6c
|
Added __has_include(<execution>) back.
|
2018-07-17 19:25:26 +03:00 |
|
Rokas Kupstys
|
5c75fe292f
|
Fix msvc builds when required c++ standard version is set to lower than c++17.
Also use latest available c++ standard which allows using older VS versions that only support c++14.
|
2018-07-17 18:29:48 +03:00 |
|
Rokas Kupstys
|
ab8d2c553a
|
Merged in rokups/tracy/fix-unix-build (pull request #15)
Fix build errors with some compilers due to using std::max(float, double).
|
2018-07-17 14:21:20 +00:00 |
|
Rokas Kupstys
|
064385fc62
|
Define ImVec2 math operators only when IMGUI_DEFINE_MATH_OPERATORS is undefined.
|
2018-07-17 16:37:45 +03: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
|
c6ea032de3
|
GPU source location may not yet be available.
|
2018-07-15 19:00:40 +02:00 |
|
Bartosz Taudul
|
21da3bca63
|
Don't create lz4buf on stack.
|
2018-07-14 16:02:33 +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
|
90a874f311
|
Require MSVC 15.7 for <execution> support.
|
2018-07-13 12:26:02 +02:00 |
|
Bartosz Taudul
|
c8b5b9447d
|
Ignore dangling memory frees in on-demand mode.
|
2018-07-12 01:35:32 +02:00 |
|
Bartosz Taudul
|
e5064dec1e
|
Store on-demand connection state.
|
2018-07-12 01:21:04 +02:00 |
|
Bartosz Taudul
|
d1ddaa8d59
|
Store frame offset in trace dumps.
|
2018-07-10 22:56:41 +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
|
a78981e040
|
Store on-demand frame offset.
|
2018-07-10 22:42:00 +02:00 |
|
Bartosz Taudul
|
6a9caabc63
|
Send on-demand initial payload message.
|
2018-07-10 22:37:39 +02:00 |
|
Bartosz Taudul
|
c056f3be41
|
Send keep alive messages to determine if client disconnected.
|
2018-07-10 21:39:17 +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
|
cb100e261c
|
Return custom zone names.
|
2018-06-29 16:12:40 +02:00 |
|
Bartosz Taudul
|
053284b1c7
|
Process custom free-form zone names.
|
2018-06-29 16:12:17 +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
|
bab798c13c
|
GPU context time drift storage.
|
2018-06-28 01:08:08 +02:00 |
|