From 0286a11b7e5ecb7f428a0eaab014a33bd444ea0d Mon Sep 17 00:00:00 2001 From: Jonathan Marek Date: Sun, 9 Dec 2018 23:14:41 -0500 Subject: [PATCH] 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 --- src/gallium/drivers/freedreno/a2xx/fd2_gmem.c | 7 +++++++ 1 file changed, 7 insertions(+) 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)); -- 2.30.2