Ivan Avdeev
b5e5d699bc
vk: deduplicate map (re)loading code
2023-04-13 11:03:36 -07:00
Ivan Avdeev
b3ffd911bb
vk: allow dynamic surface/material patching
...
Refactor NewMap and patch loading a bit.
2023-04-13 11:03:36 -07:00
Ivan Avdeev
90591cfb3d
vk: add patching props for surface texture coordinates
2023-04-12 11:57:07 -07:00
Ivan Avdeev
1fd9e49f63
vk: add normal_scale to materials
2023-04-12 11:57:07 -07:00
Ivan Avdeev
9116b0268e
vk: scale metalness/roughness textures by m/r values in material
...
fixes #342
2023-04-12 11:57:07 -07:00
Ivan Avdeev
51318fc77f
vk: read alpha for material base_color, fixes #308
2023-04-12 11:57:07 -07:00
Ivan Avdeev
139807a559
vk: profiler: add device/driver info
2023-04-10 12:05:35 -07:00
Ivan Avdeev
c917c7a818
vk: profiler: move graphs a bit lower
2023-04-10 10:24:57 -07:00
Ivan Avdeev
93153dd87e
vk: profiler: tame the gpu scopes ladder
2023-04-10 10:24:57 -07:00
Ivan Avdeev
084874c5c8
vk: profiler: add gpu scopes for staging uploads
2023-04-10 10:24:57 -07:00
Ivan Avdeev
a38f990ef5
vk: attempt to fix 32 bit build
2023-04-10 10:24:57 -07:00
Ivan 'provod' Avdeev
fdab0f7536
vk: fix windows compilation
2023-04-10 10:24:57 -07:00
Ivan Avdeev
92ce698292
vk: profiler: cover staging with combuf scopes; add build_as time
2023-04-10 10:24:57 -07:00
Ivan Avdeev
f6201e460f
vk: profiler: register gpu scopes as metrics for graph purposes
2023-04-10 10:24:57 -07:00
Ivan Avdeev
6d43e02dd3
vk: profiler: draw internal gpu side frame structure
2023-04-10 10:24:57 -07:00
Ivan Avdeev
1bf6f6ee74
vk: profiler: extract gpu timestamps in a generic manner
2023-04-10 10:24:57 -07:00
Ivan Avdeev
73a6cf596a
vk: init combuf
...
it does just work lol
2023-04-10 10:24:57 -07:00
Ivan Avdeev
4bd62ccbc0
[draft] vk: start refactoring commandbuffer/gpu profiler
...
Consolidate VkCommandBuffer management into a single entity. (somewhat
done for framectl, not done for staging)
Make sure that we pass enough metadata to be able to timestamp scopes in
cmdbuf.
It does compile, but it won't work: not all init code paths are used.
Also, there are many changes, so other failure modes are totally
possible.
2023-04-10 10:24:57 -07:00
Ivan Avdeev
5c7bd9d285
vk: profiler: add low/hi watermarks for frame time graph
2023-03-29 11:59:22 -07:00
Ivan Avdeev
cea37acfd2
vk: profiler: add width, and other improvements
...
- r_speeds_graphs_width now can be used to limit graphs width
- tweak layout slightly
- improve range printing based on metric semantic
2023-03-29 11:59:22 -07:00
Ivan 'provod' Avdeev
b5dfef5574
vk: profiler: scale graphs properly
...
respect dpi scale
2023-03-29 11:59:22 -07:00
Ivan Avdeev
adab64b797
vk: profiler: make graphs thin, add background
2023-03-29 11:59:22 -07:00
Ivan Avdeev
33aa4bc259
vk: profiler: add cvar for selecting metrics to plot
...
also:
- invert graphs
- add text labels
- fix vertical gaps
2023-03-29 11:59:22 -07:00
Ivan Avdeev
af96609c04
vk: profiler: automatic graph range
2023-03-29 11:59:22 -07:00
Ivan Avdeev
2b2e69da72
vk: profiler: start implementing universal metric graphs
2023-03-29 11:59:22 -07:00
Ivan Avdeev
8afd23a2d4
vk: profiler: clear metrics explicitly
2023-03-25 12:03:41 -07:00
Ivan Avdeev
1ae3ae4774
vk: profiler: register scopes and cpu/frame/gpu times as metrics
...
Make all the numbers we show as universal metrics
2023-03-25 12:03:41 -07:00
Ivan Avdeev
89f49276a5
vk: profiler: add beams count metric
2023-03-25 12:03:41 -07:00
Ivan Avdeev
68761fbbbb
vk: profiler: add sprites count metric
2023-03-25 12:03:41 -07:00
Ivan Avdeev
2976f753e1
vk: profiler: add more lights metrics
2023-03-25 12:03:41 -07:00
Ivan Avdeev
2db83a22a5
vk: profiler: add studio models count metric
2023-03-25 12:03:41 -07:00
Ivan Avdeev
f2ebcd663b
vk: profiler: explicit metric types; also more metrics
2023-03-25 12:03:41 -07:00
Ivan Avdeev
8ecfae5bf0
vk: profiler: simplify metric registration
2023-03-25 12:03:41 -07:00
Ivan Avdeev
cdc2a1258a
vk: profiler: add staging stats
2023-03-25 12:03:41 -07:00
Ivan Avdeev
3b47c7315a
vk: profiler: add dynamic model count
2023-03-25 12:03:41 -07:00
Ivan Avdeev
160a69d2cc
vk: profiler: add BLAS stats
2023-03-25 12:03:41 -07:00
Ivan Avdeev
e0e9305628
vk: profiler: add a way to add arbitrary metrics to profiler
2023-03-25 12:03:41 -07:00
Ivan Avdeev
576b4163b9
vk: profiler: rename slows to speeds (enough kekage)
2023-03-25 12:03:41 -07:00
Ivan 'provod' Avdeev
5f38f3467d
rt: originate ray on the near plane
...
fixes #63
also, compute max distance based on the far plane distance
2023-03-24 14:04:30 -07:00
Ivan 'provod' Avdeev
4a5fc186ea
vk: profiler: fixup incorrect __FUNCTION__ macro usage
...
No idea how it could work before
2023-03-21 11:59:57 -07:00
Ivan Avdeev
e1afb2a9de
vk: profiler: collect and display ref cpu busy and waiting times
2023-03-21 11:59:57 -07:00
Ivan Avdeev
5d23494cfc
vk: profiler: use existing R_SpeedsMessage to display profiling data
2023-03-21 11:59:57 -07:00
Ivan Avdeev
9d8ec1bc9d
vk: profiler: control profiler with r_speeds command
...
use bits to enable particular performance data display:
0 -- off
1 -- simple frame time
2 -- more object count and sizes statistics (TODO)
4 -- overall gpu usage (TODO)
8 -- extended intra-frame data, function times graph, etc
2023-03-21 11:59:57 -07:00
Ivan Avdeev
55af70c422
vk: profiler: remove noisy printf
2023-03-21 11:59:57 -07:00
Ivan Avdeev
bcb1d367b9
vk: profiler: refactor plotting functions slightly
2023-03-21 11:59:57 -07:00
Ivan Avdeev
2b8f74ff0e
vk: profiler: minor cleanup
2023-03-21 11:59:57 -07:00
Ivan 'provod' Avdeev
b4b63492f2
vk: profiler: fixup time scaling on windows
2023-03-21 11:59:57 -07:00
Ivan Avdeev
22d4202ad9
vk: profiler: draw total gpu time
...
Use VK_EXT_calibrated_timestamps to convert to host time.
2023-03-21 11:59:57 -07:00
Ivan Avdeev
a66c44a266
vk: convert query timestamps to ns
...
also, fix linux build
2023-03-21 11:59:57 -07:00
Ivan 'provod' Avdeev
93a539df74
vk: display gpu time taken for a previous frame
...
its value will be incorrect for non-nv cards which have non-1 timestampPeriod
2023-03-21 11:59:57 -07:00