From: Jonathan Marek Date: Mon, 10 Dec 2018 04:14:41 +0000 (-0500) Subject: freedreno: a2xx: fix gmem2mem viewport X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=0286a11b7e5ecb7f428a0eaab014a33bd444ea0d;p=mesa.git freedreno: a2xx: fix gmem2mem viewport Fixes cases where previous viewport values might case gmem2mem to fail. Signed-off-by: Jonathan Marek Reviewed-by: Rob Clark --- diff --git a/src/gallium/drivers/freedreno/a2xx/fd2_gmem.c b/src/gallium/drivers/freedreno/a2xx/fd2_gmem.c index 199bf948b92..6ffeefb3784 100644 --- a/src/gallium/drivers/freedreno/a2xx/fd2_gmem.c +++ b/src/gallium/drivers/freedreno/a2xx/fd2_gmem.c @@ -160,6 +160,13 @@ fd2_emit_tile_gmem2mem(struct fd_batch *batch, struct fd_tile *tile) OUT_RING(ring, CP_REG(REG_A2XX_PA_CL_CLIP_CNTL)); OUT_RING(ring, 0x00000000); + OUT_PKT3(ring, CP_SET_CONSTANT, 5); + OUT_RING(ring, CP_REG(REG_A2XX_PA_CL_VPORT_XSCALE)); + OUT_RING(ring, fui((float) tile->bin_w / 2.0)); /* XSCALE */ + OUT_RING(ring, fui((float) tile->bin_w / 2.0)); /* XOFFSET */ + OUT_RING(ring, fui((float) tile->bin_h / 2.0)); /* YSCALE */ + OUT_RING(ring, fui((float) tile->bin_h / 2.0)); /* YOFFSET */ + OUT_PKT3(ring, CP_SET_CONSTANT, 2); OUT_RING(ring, CP_REG(REG_A2XX_RB_MODECONTROL)); OUT_RING(ring, A2XX_RB_MODECONTROL_EDRAM_MODE(EDRAM_COPY));