diff --git a/.pick_status.json b/.pick_status.json index 24cb5077409..f5d88fbad4f 100644 --- a/.pick_status.json +++ b/.pick_status.json @@ -418,7 +418,7 @@ "description": "lavapipe: fix depth bias offset flag enables.", "nominated": true, "nomination_type": 0, - "resolution": 0, + "resolution": 1, "main_sha": null, "because_sha": null }, diff --git a/src/gallium/drivers/zink/ci/zink-lvp-fails.txt b/src/gallium/drivers/zink/ci/zink-lvp-fails.txt index c99024d6aae..d65b97c77c2 100644 --- a/src/gallium/drivers/zink/ci/zink-lvp-fails.txt +++ b/src/gallium/drivers/zink/ci/zink-lvp-fails.txt @@ -160,7 +160,6 @@ spec@!opengl 1.1@linestipple@Factor 2x,Fail spec@!opengl 1.1@linestipple@Factor 3x,Fail spec@!opengl 1.1@linestipple@Line loop,Fail spec@!opengl 1.1@linestipple@Line strip,Fail -spec@!opengl 1.1@polygon-offset,Fail spec@!opengl 1.1@polygon-mode,Fail spec@!opengl 1.1@polygon-mode-facing,Fail spec@!opengl 1.1@polygon-mode-offset,Fail diff --git a/src/gallium/frontends/lavapipe/lvp_execute.c b/src/gallium/frontends/lavapipe/lvp_execute.c index eb53253b45b..2a57bdad612 100644 --- a/src/gallium/frontends/lavapipe/lvp_execute.c +++ b/src/gallium/frontends/lavapipe/lvp_execute.c @@ -329,8 +329,14 @@ static void emit_state(struct rendering_state *state) assert(offsetof(struct pipe_rasterizer_state, offset_clamp) - offsetof(struct pipe_rasterizer_state, offset_units) == sizeof(float) * 2); if (state->depth_bias.enabled) { memcpy(&state->rs_state.offset_units, &state->depth_bias, sizeof(float) * 3); + state->rs_state.offset_tri = true; + state->rs_state.offset_line = true; + state->rs_state.offset_point = true; } else { memset(&state->rs_state.offset_units, 0, sizeof(float) * 3); + state->rs_state.offset_tri = false; + state->rs_state.offset_line = false; + state->rs_state.offset_point = false; } cso_set_rasterizer(state->cso, &state->rs_state); state->rs_dirty = false;