diff --git a/.pick_status.json b/.pick_status.json index 14f787ebe21..6f3ac010224 100644 --- a/.pick_status.json +++ b/.pick_status.json @@ -2964,7 +2964,7 @@ "description": "lavapipe: update cbuf count when remapping attachments", "nominated": true, "nomination_type": 1, - "resolution": 0, + "resolution": 1, "main_sha": null, "because_sha": null, "notes": null diff --git a/src/gallium/frontends/lavapipe/lvp_execute.c b/src/gallium/frontends/lavapipe/lvp_execute.c index 0f8e33a31a8..f344c3b1a41 100644 --- a/src/gallium/frontends/lavapipe/lvp_execute.c +++ b/src/gallium/frontends/lavapipe/lvp_execute.c @@ -346,8 +346,10 @@ emit_fb_state(struct rendering_state *state) struct pipe_framebuffer_state fb = state->framebuffer; memset(fb.cbufs, 0, sizeof(fb.cbufs)); for (unsigned i = 0; i < fb.nr_cbufs; i++) { - if (state->fb_map[i] < PIPE_MAX_COLOR_BUFS) + if (state->fb_map[i] < PIPE_MAX_COLOR_BUFS) { fb.cbufs[state->fb_map[i]] = state->framebuffer.cbufs[i]; + fb.nr_cbufs = MAX2(fb.nr_cbufs, state->fb_map[i] + 1); + } } state->pctx->set_framebuffer_state(state->pctx, &fb); } else {