mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-02-23 22:40:34 +01:00
radeonsi: eliminate PS color outputs when colormask kills them
Reviewed-by: Nicolai Hähnle <nicolai.haehnle@amd.com>
This commit is contained in:
parent
468c131033
commit
fb7ba68f6c
3 changed files with 6 additions and 0 deletions
|
|
@ -441,6 +441,8 @@ static void *si_create_blend_state_mode(struct pipe_context *ctx,
|
|||
blend->need_src_alpha_4bit |= 0xf;
|
||||
|
||||
blend->cb_target_mask = 0;
|
||||
blend->cb_target_enabled_4bit = 0;
|
||||
|
||||
for (int i = 0; i < 8; i++) {
|
||||
/* state->rt entries > 0 only written if independent blending */
|
||||
const int j = state->independent_blend_enable ? i : 0;
|
||||
|
|
@ -482,6 +484,8 @@ static void *si_create_blend_state_mode(struct pipe_context *ctx,
|
|||
|
||||
/* cb_render_state will disable unused ones */
|
||||
blend->cb_target_mask |= (unsigned)state->rt[j].colormask << (4 * i);
|
||||
if (state->rt[j].colormask)
|
||||
blend->cb_target_enabled_4bit |= 0xf << (4 * i);
|
||||
|
||||
if (!state->rt[j].colormask || !state->rt[j].blend_enable) {
|
||||
si_pm4_set_reg(pm4, R_028780_CB_BLEND0_CONTROL + i * 4, blend_cntl);
|
||||
|
|
|
|||
|
|
@ -55,6 +55,7 @@ struct si_state_blend {
|
|||
/* Set 0xf or 0x0 (4 bits) per render target if the following is
|
||||
* true. ANDed with spi_shader_col_format.
|
||||
*/
|
||||
unsigned cb_target_enabled_4bit;
|
||||
unsigned blend_enable_4bit;
|
||||
unsigned need_src_alpha_4bit;
|
||||
};
|
||||
|
|
|
|||
|
|
@ -1355,6 +1355,7 @@ static inline void si_shader_selector_key(struct pipe_context *ctx,
|
|||
sctx->framebuffer.spi_shader_col_format_alpha) |
|
||||
(~blend->blend_enable_4bit & ~blend->need_src_alpha_4bit &
|
||||
sctx->framebuffer.spi_shader_col_format);
|
||||
key->part.ps.epilog.spi_shader_col_format &= blend->cb_target_enabled_4bit;
|
||||
|
||||
/* The output for dual source blending should have
|
||||
* the same format as the first output.
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue