Mesa (master): nvfx: set magic bit to round NPOT mipmap sizes down and not up
Luca Barbieri
lb at kemper.freedesktop.org
Sat Sep 4 00:17:36 UTC 2010
Module: Mesa
Branch: master
Commit: fa82ad84fbe2be2bbfe9de7cda3e901a069ae16c
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=fa82ad84fbe2be2bbfe9de7cda3e901a069ae16c
Author: Luca Barbieri <luca at luca-barbieri.com>
Date: Sat Sep 4 02:05:14 2010 +0200
nvfx: set magic bit to round NPOT mipmap sizes down and not up
Does any API even use rounding-up?
---
src/gallium/drivers/nouveau/nouveau_class.h | 3 +++
src/gallium/drivers/nvfx/nvfx_screen.c | 3 +++
2 files changed, 6 insertions(+), 0 deletions(-)
diff --git a/src/gallium/drivers/nouveau/nouveau_class.h b/src/gallium/drivers/nouveau/nouveau_class.h
index 20941f3..3c2248b 100644
--- a/src/gallium/drivers/nouveau/nouveau_class.h
+++ b/src/gallium/drivers/nouveau/nouveau_class.h
@@ -6877,6 +6877,9 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
#define NV40TCL_COLOR_LOGIC_OP_SET 0x0000150f
#define NV40TCL_DEPTH_RANGE_NEAR 0x00000394
#define NV40TCL_DEPTH_RANGE_FAR 0x00000398
+#define NV40TCL_MIPMAP_ROUNDING 0x000003b0
+#define NV40TCL_MIPMAP_ROUNDING_UP 0x00000000
+#define NV40TCL_MIPMAP_ROUNDING_DOWN 0x00100000
#define NV40TCL_LINE_WIDTH 0x000003b8
#define NV40TCL_LINE_SMOOTH_ENABLE 0x000003bc
#define NV40TCL_UNK03C0(x) (0x000003c0+((x)*4))
diff --git a/src/gallium/drivers/nvfx/nvfx_screen.c b/src/gallium/drivers/nvfx/nvfx_screen.c
index e6ba7bc..b5b7a34 100644
--- a/src/gallium/drivers/nvfx/nvfx_screen.c
+++ b/src/gallium/drivers/nvfx/nvfx_screen.c
@@ -328,6 +328,9 @@ static void nv40_screen_init(struct nvfx_screen *screen)
OUT_RING(chan, 0x00d30000);
OUT_RING(chan, RING_3D(0x1e94, 1));
OUT_RING(chan, 0x00000001);
+
+ OUT_RING(chan, RING_3D(NV40TCL_MIPMAP_ROUNDING, 1));
+ OUT_RING(chan, NV40TCL_MIPMAP_ROUNDING_DOWN);
}
static unsigned
More information about the mesa-commit
mailing list