From 49b8fb937f76d49fb5d2ed0d2c99e947a389d686 Mon Sep 17 00:00:00 2001 From: Rob Clark Date: Sat, 13 Sep 2014 16:14:17 -0400 Subject: freedreno/a3xx: more texture array fixes Signed-off-by: Rob Clark --- src/gallium/drivers/freedreno/ir3/ir3_compiler.c | 33 ++++++++++++------------ 1 file changed, 17 insertions(+), 16 deletions(-) (limited to 'src/gallium/drivers/freedreno/ir3') diff --git a/src/gallium/drivers/freedreno/ir3/ir3_compiler.c b/src/gallium/drivers/freedreno/ir3/ir3_compiler.c index 5d96187b986..7c58d6f697d 100644 --- a/src/gallium/drivers/freedreno/ir3/ir3_compiler.c +++ b/src/gallium/drivers/freedreno/ir3/ir3_compiler.c @@ -1095,10 +1095,15 @@ get_tex_info(struct ir3_compile_context *ctx, .flags = IR3_INSTR_S, }; static const struct tex_info tex1da = { - .order = { 0, -1, 2, -1 }, /* coord.xz */ + .order = { 0, -1, 1, -1 }, /* coord.xy */ .src_wrmask = TGSI_WRITEMASK_XYZ, .flags = IR3_INSTR_A, }; + static const struct tex_info tex1dsa = { + .order = { 0, -1, 1, 2 }, /* coord.xyz */ + .src_wrmask = TGSI_WRITEMASK_XYZW, + .flags = IR3_INSTR_S | IR3_INSTR_A, + }; static const struct tex_info tex2d = { .order = { 0, 1, -1, -1 }, /* coord.xy */ .src_wrmask = TGSI_WRITEMASK_XY, @@ -1114,6 +1119,11 @@ get_tex_info(struct ir3_compile_context *ctx, .src_wrmask = TGSI_WRITEMASK_XYZ, .flags = IR3_INSTR_A, }; + static const struct tex_info tex2dsa = { + .order = { 0, 1, 2, 3 }, /* coord.xyzw */ + .src_wrmask = TGSI_WRITEMASK_XYZW, + .flags = IR3_INSTR_S | IR3_INSTR_A, + }; static const struct tex_info tex3d = { .order = { 0, 1, 2, -1 }, /* coord.xyz */ .src_wrmask = TGSI_WRITEMASK_XYZ, @@ -1130,15 +1140,10 @@ get_tex_info(struct ir3_compile_context *ctx, .flags = IR3_INSTR_P, }; static const struct tex_info txp1ds = { - .order = { 0, -1, 2, 3 }, /* coord.xzw */ + .order = { 0, -1, 2, 3 }, /* coord.xyz */ .src_wrmask = TGSI_WRITEMASK_XYZW, .flags = IR3_INSTR_P | IR3_INSTR_S, }; - static const struct tex_info txp1da = { - .order = { 0, -1, 2, 3 }, /* coord.xzw */ - .src_wrmask = TGSI_WRITEMASK_XYZW, - .flags = IR3_INSTR_P | IR3_INSTR_A, - }; static const struct tex_info txp2d = { .order = { 0, 1, 3, -1 }, /* coord.xyw */ .src_wrmask = TGSI_WRITEMASK_XYZ, @@ -1149,11 +1154,6 @@ get_tex_info(struct ir3_compile_context *ctx, .src_wrmask = TGSI_WRITEMASK_XYZW, .flags = IR3_INSTR_P | IR3_INSTR_S, }; - static const struct tex_info txp2da = { - .order = { 0, 1, 2, 3 }, /* coord.xyzw */ - .src_wrmask = TGSI_WRITEMASK_XYZW, - .flags = IR3_INSTR_P | IR3_INSTR_A, - }; static const struct tex_info txp3d = { .order = { 0, 1, 2, 3 }, /* coord.xyzw */ .src_wrmask = TGSI_WRITEMASK_XYZW, @@ -1173,6 +1173,8 @@ get_tex_info(struct ir3_compile_context *ctx, return &tex1ds; case TGSI_TEXTURE_1D_ARRAY: return &tex1da; + case TGSI_TEXTURE_SHADOW1D_ARRAY: + return &tex1dsa; case TGSI_TEXTURE_2D: case TGSI_TEXTURE_RECT: return &tex2d; @@ -1181,6 +1183,8 @@ get_tex_info(struct ir3_compile_context *ctx, return &tex2ds; case TGSI_TEXTURE_2D_ARRAY: return &tex2da; + case TGSI_TEXTURE_SHADOW2D_ARRAY: + return &tex2dsa; case TGSI_TEXTURE_3D: case TGSI_TEXTURE_CUBE: return &tex3d; @@ -1198,16 +1202,12 @@ get_tex_info(struct ir3_compile_context *ctx, return &txp1d; case TGSI_TEXTURE_SHADOW1D: return &txp1ds; - case TGSI_TEXTURE_1D_ARRAY: - return &txp1da; case TGSI_TEXTURE_2D: case TGSI_TEXTURE_RECT: return &txp2d; case TGSI_TEXTURE_SHADOW2D: case TGSI_TEXTURE_SHADOWRECT: return &txp2ds; - case TGSI_TEXTURE_2D_ARRAY: - return &txp2da; case TGSI_TEXTURE_3D: case TGSI_TEXTURE_CUBE: return &txp3d; @@ -1237,6 +1237,7 @@ static bool is_1d(unsigned tex) case TGSI_TEXTURE_1D: case TGSI_TEXTURE_SHADOW1D: case TGSI_TEXTURE_1D_ARRAY: + case TGSI_TEXTURE_SHADOW1D_ARRAY: return true; default: return false; -- cgit v1.2.3