mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-01-16 05:00:19 +01:00
i965: Use the correct number of threads for compute shaders.
We were programming the number of threads per subslice, when we should
have been programming the total number of threads on the GPU as a whole.
Thanks to Curro and Jordan for helping track this down!
On Skylake GT3e:
- Improves performance in Unreal's Elemental Demo by roughly 1.5-1.7x.
- Improves performance in Synmark's Gl43CSDof by roughly 3.7x.
- Improves performance in Synmark's Gl43GSCloth by roughly 1.18x.
On Broadwell GT2:
- Improves performance in Unreal's Elemental Demo by roughly 1.2-1.5x.
- Improves performance in Synmark's Gl43CSDof by roughly 2.0x.
- Improves performance in Synmark's Gl43GSCloth by 1.47035% +/-
0.255654% (n=25).
On Haswell GT3e:
- Improves performance in Unreal's Elemental Demo (in GL 4.3 mode)
by roughly 1.10x.
- Improves performance in Synmark's Gl43CSDof by roughly 1.18x.
- Decreases performance in Synmark's Gl43CSCloth by -1.99484% +/-
0.432771% (n=64).
On Ivybridge GT2:
- Improves performance in Unreal's Elemental Demo (in GL 4.2 mode)
by roughly 1.03x.
- Improves performance in Synmark's G/43CSDof by roughly 1.25x.
- No change in Synmark's Gl43CSCloth (n=28).
Cc: "12.0" <mesa-stable@lists.freedesktop.org>
Signed-off-by: Kenneth Graunke <kenneth@whitecape.org>
Reviewed-by: Francisco Jerez <currojerez@riseup.net>
Reviewed-by: Jordan Justen <jordan.l.justen@intel.com>
(cherry picked from commit 0fb85ac08d)
This commit is contained in:
parent
9a118c79e7
commit
2b6817c91c
1 changed files with 3 additions and 1 deletions
|
|
@ -95,7 +95,9 @@ brw_upload_cs_state(struct brw_context *brw)
|
|||
const uint32_t vfe_num_urb_entries = brw->gen >= 8 ? 2 : 0;
|
||||
const uint32_t vfe_gpgpu_mode =
|
||||
brw->gen == 7 ? SET_FIELD(1, GEN7_MEDIA_VFE_STATE_GPGPU_MODE) : 0;
|
||||
OUT_BATCH(SET_FIELD(brw->max_cs_threads - 1, MEDIA_VFE_STATE_MAX_THREADS) |
|
||||
const uint32_t subslices = MAX2(brw->intelScreen->subslice_total, 1);
|
||||
OUT_BATCH(SET_FIELD(brw->max_cs_threads * subslices - 1,
|
||||
MEDIA_VFE_STATE_MAX_THREADS) |
|
||||
SET_FIELD(vfe_num_urb_entries, MEDIA_VFE_STATE_URB_ENTRIES) |
|
||||
SET_FIELD(1, MEDIA_VFE_STATE_RESET_GTW_TIMER) |
|
||||
SET_FIELD(1, MEDIA_VFE_STATE_BYPASS_GTW) |
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue