[Mesa-dev] [PATCH 1/3] r600g/llvm: Don't emit CALL_FS for vertex shaders

Tom Stellard tom at stellard.net
Fri May 3 15:54:40 PDT 2013


From: Tom Stellard <thomas.stellard at amd.com>

The LLVM backend takes care of this now.
---
 src/gallium/drivers/r600/r600_shader.c | 16 +++++++++-------
 1 file changed, 9 insertions(+), 7 deletions(-)

diff --git a/src/gallium/drivers/r600/r600_shader.c b/src/gallium/drivers/r600/r600_shader.c
index 9afd57f..b3b124e 100644
--- a/src/gallium/drivers/r600/r600_shader.c
+++ b/src/gallium/drivers/r600/r600_shader.c
@@ -1371,13 +1371,6 @@ static int r600_shader_from_tgsi(struct r600_screen *rscreen,
 	for (i = 0; i < TGSI_FILE_COUNT; i++) {
 		ctx.file_offset[i] = 0;
 	}
-	if (ctx.type == TGSI_PROCESSOR_VERTEX) {
-		ctx.file_offset[TGSI_FILE_INPUT] = 1;
-		r600_bytecode_add_cfinst(ctx.bc, CF_OP_CALL_FS);
-	}
-	if (ctx.type == TGSI_PROCESSOR_FRAGMENT && ctx.bc->chip_class >= EVERGREEN) {
-		ctx.file_offset[TGSI_FILE_INPUT] = evergreen_gpr_count(&ctx);
-	}
 
 #ifdef R600_USE_LLVM
 	if (use_llvm && ctx.info.indirect_files && (ctx.info.indirect_files & (1 << TGSI_FILE_CONSTANT)) != ctx.info.indirect_files) {
@@ -1387,6 +1380,15 @@ static int r600_shader_from_tgsi(struct r600_screen *rscreen,
 		use_llvm = 0;
 	}
 #endif
+	if (ctx.type == TGSI_PROCESSOR_VERTEX) {
+		ctx.file_offset[TGSI_FILE_INPUT] = 1;
+		if (!use_llvm) {
+			r600_bytecode_add_cfinst(ctx.bc, CF_OP_CALL_FS);
+		}
+	}
+	if (ctx.type == TGSI_PROCESSOR_FRAGMENT && ctx.bc->chip_class >= EVERGREEN) {
+		ctx.file_offset[TGSI_FILE_INPUT] = evergreen_gpr_count(&ctx);
+	}
 	ctx.use_llvm = use_llvm;
 
 	if (use_llvm) {
-- 
1.7.11.4



More information about the mesa-dev mailing list