<div dir="auto"><div><br><div class="gmail_extra"><br><div class="gmail_quote">On May 11, 2017 2:30 AM, "Timothy Arceri" <<a href="mailto:tarceri@itsqueeze.com">tarceri@itsqueeze.com</a>> wrote:<br type="attribution"><blockquote class="quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="elided-text">On 11/05/17 08:45, Marek Olšák wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Hi,<br>
<br>
This series adds an optional module into gallium/util that wraps<br>
around pipe_context and moves execution of all pipe_context calls into<br>
a separate thread.<br>
<br>
It puts a lot of new requirements on the driver, especially on thread-<br>
safetiness of pipe_context functions, and even expects different<br>
behavior from pipe_context in some cases, so it may be non-trivial<br>
to enable. All of it is necessary to have a perfectly scalable<br>
threaded execution. (Any new drivers should be built around it from<br>
the beginning)<br>
<br>
The performance improvement isn't very high (it's just hiding overhead<br>
of pipe_context only), but I can tell you and I have tested a lot of<br>
apps with this, it really doesn't sync the thread with majority of<br>
apps except for SwapBuffers.<br>
<br>
It can do these:<br>
- unsychronized buffer mappings don't sync<br>
- ordinary buffer mappings are promoted to unsynchronized when it's safe<br>
- full buffer invalidations are implemented as reallocations and don't sync<br>
- partial buffer invalidations are implemented as copy_buffer and don't sync<br>
- get_query_result doesn't sync when the threaded context has seen flush()<br>
   (i.e. get_query_result is contextless in that case)<br>
<br>
Missing:<br>
- deferred fences - mainly Bioshock Infinite might benefit<br>
- texture mappings (meaning CPU access) always sync, texture_subdata<br>
   doesn't sync for small uploads only, but we can make all texture<br>
   uploads asynchronous by simply copying what is done for buffers<br>
<br>
Note that it has a very low overhead when it's always synchronous<br>
(i.e. not multithreaded), because it's really fast to enqueue and<br>
execute calls. The worst case scenario might be -3% performance (just<br>
guessing here).<br>
<br>
All requirements on Gallium drivers and other information can be found<br>
in the header file:<br>
<a href="https://cgit.freedesktop.org/~mareko/mesa/tree/src/gallium/auxiliary/util/u_threaded_context.h?h=gallium-threaded2#n26" rel="noreferrer" target="_blank">https://cgit.freedesktop.org/~<wbr>mareko/mesa/tree/src/gallium/a<wbr>uxiliary/util/u_threaded_conte<wbr>xt.h?h=gallium-threaded2#n26</a><br>
<br>
RadeonSI enables threaded Gallium by default for OpenGL Core and<br>
Compatibility profiles and all OpenGL ES variants.<br>
<br>
There is a small performance concern for RadeonSI: If non-contiguous<br>
VRAM mappings are not supported (amdgpu - kernel 4.11 and older,<br>
radeon - all kernels), the performance difference might be negative,<br>
because buffer invalidations are done unconditionally, meaning that<br>
there can be more live and mapped VRAM buffers. It's difficult to tell<br>
whether any real apps are affected in a measurable way.<br>
<br>
Here are performance numbers:<br>
<br>
APPS: MORE IS BETTER<br>
Alien Isolation: +16%<br>
Bioshock Infinite: +13%<br>
Borderlands 2: +12%<br>
Civilization 5: +12%<br>
Civilization 6: +10%<br>
CS:GO: +8%<br>
ET Legacy: +12%<br>
Openarena: +27%<br>
Talos Principle (high details, 1680x1050 internal resolution): +17%<br>
glmark2: no change in the final score<br>
<br>
When games are GPU-bound: no change<br>
<br>
Because of not taking advantage of deferred fences, Bioshock runs<br>
80% of time asynchronously and 20% of time synchronously.<br>
All other games run 100% of time asynchronously.<br>
<br>
x11perf: MORE IS BETTER<br>
x11perf: Test: 500px PutImage Square: -3%<br>
x11perf: Test: Scrolling 500 x 500 px: +16%<br>
x11perf: Test: Char in 80-char aa line: +13%<br>
x11perf: Test: PutImage XY 500x500 Square: +1%<br>
x11perf: Test: Fill 300 x 300px AA Trapezoid: NO CHANGE<br>
x11perf: Test: 500px Copy From Window To Window: +14%<br>
x11perf: Test: Copy 500x500 From Pixmap To Pixmap: -1%<br>
x11perf: Test: 500px Compositing From Pixmap To Window: +21%<br>
x11perf: Test: 500px Compositing From Window To Window: +18%<br>
<br>
gtkperf: LESS IS BETTER<br>
gtkperf: GTK Widget: Total Time: -2%<br>
gtkperf: GTK Widget: GtkComboBox: +7%<br>
gtkperf: GTK Widget: GtkCheckButton: -15%<br>
gtkperf: GTK Widget: GtkRadioButton: -13%<br>
gtkperf: GTK Widget: GtkToggleButton: -2%<br>
gtkperf: GTK Widget: GtkComboBoxEntry: -1%<br>
gtkperf: GTK Widget: GtkTextView - Scroll: NO CHANGE<br>
gtkperf: GTK Widget: GtkTextView - Add Text: NO CHANGE<br>
gtkperf: GTK Widget: GtkDrawingArea - Circles: -9%<br>
gtkperf: GTK Widget: GtkDrawingArea - Pixbufs: -3%<br>
<br>
Hence the decision to enable it by default.<br>
</blockquote>
<br></div>
Hi Marek,<br>
<br>
Are you able to provide details of the system (CPU/GPU) used for testing? Should we not try to get more results of different combinations before enabling by default? Or maybe at least add an environment var allow disabling it so that community members can easily provide results over the 17.2 development process?<br></blockquote></div></div></div><div dir="auto"><br></div><div dir="auto">Core i5 3570, Radeon Fury.</div><div dir="auto"><br></div><div dir="auto">There is an environment variable to disable it.</div><div dir="auto"><br></div><div dir="auto">The goal was to enable it by default from the beginning. Since it never syncs the thread with most apps, which can be observed easily via the exposed counters for HUD, it's a no-brainer.</div><div dir="auto"><br></div><div dir="auto">Marek</div><div dir="auto"><br></div><div dir="auto"><div class="gmail_extra"><div class="gmail_quote"><blockquote class="quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Please review.<br>
<br>
Marek<br>
______________________________<wbr>_________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org" target="_blank">mesa-dev@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/mesa-dev" rel="noreferrer" target="_blank">https://lists.freedesktop.org/<wbr>mailman/listinfo/mesa-dev</a><br>
<br>
</blockquote>
______________________________<wbr>_________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org" target="_blank">mesa-dev@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/mesa-dev" rel="noreferrer" target="_blank">https://lists.freedesktop.org/<wbr>mailman/listinfo/mesa-dev</a><br>
</blockquote></div><br></div></div></div>