r600g: don't run with scissors.
This could probably be done much nicer, I've spent a day chasing a coherency problem in the kernel, that turned out to be incorrect scissor setup.
This commit is contained in:
parent
ef2702fb20
commit
3322416de4
|
@ -899,6 +899,51 @@ static void evergreen_set_framebuffer_state(struct pipe_context *ctx,
|
|||
r600_pipe_state_add_reg(rstate,
|
||||
R_028254_PA_SC_VPORT_SCISSOR_0_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028030_PA_SC_SCREEN_SCISSOR_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028034_PA_SC_SCREEN_SCISSOR_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028204_PA_SC_WINDOW_SCISSOR_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028208_PA_SC_WINDOW_SCISSOR_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028210_PA_SC_CLIPRECT_0_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028214_PA_SC_CLIPRECT_0_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028218_PA_SC_CLIPRECT_1_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_02821C_PA_SC_CLIPRECT_1_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028220_PA_SC_CLIPRECT_2_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028224_PA_SC_CLIPRECT_2_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028228_PA_SC_CLIPRECT_3_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_02822C_PA_SC_CLIPRECT_3_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028200_PA_SC_WINDOW_OFFSET, 0x00000000,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_02820C_PA_SC_CLIPRECT_RULE, 0x0000FFFF,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028230_PA_SC_EDGERULE, 0xAAAAAAAA,
|
||||
0xFFFFFFFF, NULL);
|
||||
|
||||
r600_pipe_state_add_reg(rstate, R_028238_CB_TARGET_MASK,
|
||||
0x00000000, target_mask, NULL);
|
||||
|
|
|
@ -1074,6 +1074,18 @@ static void r600_set_framebuffer_state(struct pipe_context *ctx,
|
|||
tl = S_028240_TL_X(0) | S_028240_TL_Y(0) | S_028240_WINDOW_OFFSET_DISABLE(1);
|
||||
br = S_028244_BR_X(state->width) | S_028244_BR_Y(state->height);
|
||||
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028030_PA_SC_SCREEN_SCISSOR_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028034_PA_SC_SCREEN_SCISSOR_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028204_PA_SC_WINDOW_SCISSOR_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028208_PA_SC_WINDOW_SCISSOR_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028240_PA_SC_GENERIC_SCISSOR_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
|
@ -1086,6 +1098,41 @@ static void r600_set_framebuffer_state(struct pipe_context *ctx,
|
|||
r600_pipe_state_add_reg(rstate,
|
||||
R_028254_PA_SC_VPORT_SCISSOR_0_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028210_PA_SC_CLIPRECT_0_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028214_PA_SC_CLIPRECT_0_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028218_PA_SC_CLIPRECT_1_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_02821C_PA_SC_CLIPRECT_1_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028220_PA_SC_CLIPRECT_2_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028224_PA_SC_CLIPRECT_2_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028228_PA_SC_CLIPRECT_3_TL, tl,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_02822C_PA_SC_CLIPRECT_3_BR, br,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028200_PA_SC_WINDOW_OFFSET, 0x00000000,
|
||||
0xFFFFFFFF, NULL);
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_02820C_PA_SC_CLIPRECT_RULE, 0x0000FFFF,
|
||||
0xFFFFFFFF, NULL);
|
||||
if (rctx->family >= CHIP_RV770) {
|
||||
r600_pipe_state_add_reg(rstate,
|
||||
R_028230_PA_SC_EDGERULE, 0xAAAAAAAA,
|
||||
0xFFFFFFFF, NULL);
|
||||
}
|
||||
|
||||
r600_pipe_state_add_reg(rstate, R_0287A0_CB_SHADER_CONTROL,
|
||||
shader_control, 0xFFFFFFFF, NULL);
|
||||
|
|
Loading…
Reference in New Issue