[Mesa-dev] [PATCH 10/10] r600g, radeonsi: convert TGSI shader type to LLVM shader type

Marek Olšák maraeo at gmail.com
Thu Oct 16 08:34:08 PDT 2014


From: Marek Olšák <marek.olsak at amd.com>

The values are hardcoded in the LLVM backend, but the TGSI definitions are
going to be changed with tessellation, e.g. TGSI_PROCESSOR_COMPUTE will be
increased by 2.

We'll use VS for LS and HS, because there's nothing special about them
from the LLVM backend point of view, even though the hardware side is
different. We do the same for ES.
---
 src/gallium/drivers/radeon/radeon_llvm_emit.c | 31 ++++++++++++++++++++++++++-
 1 file changed, 30 insertions(+), 1 deletion(-)

diff --git a/src/gallium/drivers/radeon/radeon_llvm_emit.c b/src/gallium/drivers/radeon/radeon_llvm_emit.c
index 53694b7..dc871d7 100644
--- a/src/gallium/drivers/radeon/radeon_llvm_emit.c
+++ b/src/gallium/drivers/radeon/radeon_llvm_emit.c
@@ -41,6 +41,16 @@
 #define TRIPLE_STRING_LEN 7
 
 /**
+ * Shader types for the LLVM backend.
+ */
+enum radeon_llvm_shader_type {
+	RADEON_LLVM_SHADER_PS = 0,
+	RADEON_LLVM_SHADER_VS = 1,
+	RADEON_LLVM_SHADER_GS = 2,
+	RADEON_LLVM_SHADER_CS = 3,
+};
+
+/**
  * Set the shader type we want to compile
  *
  * @param type shader type to set
@@ -48,7 +58,26 @@
 void radeon_llvm_shader_type(LLVMValueRef F, unsigned type)
 {
 	char Str[2];
-	sprintf(Str, "%1d", type);
+	enum radeon_llvm_shader_type llvm_type;
+
+	switch (type) {
+	case TGSI_PROCESSOR_VERTEX:
+		llvm_type = RADEON_LLVM_SHADER_VS;
+		break;
+	case TGSI_PROCESSOR_GEOMETRY:
+		llvm_type = RADEON_LLVM_SHADER_GS;
+		break;
+	case TGSI_PROCESSOR_FRAGMENT:
+		llvm_type = RADEON_LLVM_SHADER_PS;
+		break;
+	case TGSI_PROCESSOR_COMPUTE:
+		llvm_type = RADEON_LLVM_SHADER_CS;
+		break;
+	default:
+		assert(0);
+	}
+
+	sprintf(Str, "%1d", llvm_type);
 
 	LLVMAddTargetDependentFunctionAttr(F, "ShaderType", Str);
 
-- 
1.9.1



More information about the mesa-dev mailing list