[Bf-blender-cvs] [1287965089a] blender2.8: GPU module: Initial implementation of the `gpu.shader` submodule.

mano-wii noreply at git.blender.org
Fri Sep 14 15:09:08 CEST 2018


Commit: 1287965089a851c46e9a1a23c55ebc90b00b4e14
Author: mano-wii
Date:   Fri Sep 14 09:32:19 2018 -0300
Branches: blender2.8
https://developer.blender.org/rB1287965089a851c46e9a1a23c55ebc90b00b4e14

GPU module: Initial implementation of the `gpu.shader` submodule.

Differential Revision: https://developer.blender.org/D3688

===================================================================

M	source/blender/gpu/GPU_shader.h
M	source/blender/gpu/intern/gpu_shader.c
M	source/blender/python/gpu/CMakeLists.txt
M	source/blender/python/gpu/gpu_py_api.c
M	source/blender/python/gpu/gpu_py_batch.c
A	source/blender/python/gpu/gpu_py_shader.c
A	source/blender/python/gpu/gpu_py_shader.h
M	source/blender/python/gpu/gpu_py_types.c
M	source/blender/python/gpu/gpu_py_types.h

===================================================================

diff --git a/source/blender/gpu/GPU_shader.h b/source/blender/gpu/GPU_shader.h
index c9a87a7e187..8b0a1b2b51f 100644
--- a/source/blender/gpu/GPU_shader.h
+++ b/source/blender/gpu/GPU_shader.h
@@ -366,6 +366,11 @@ typedef enum GPUInterlaceShader {
 
 GPUShader *GPU_shader_get_builtin_shader(GPUBuiltinShader shader);
 
+void GPU_shader_get_builtin_shader_code(
+        GPUBuiltinShader shader,
+        const char **vert, const char **frag,
+        const char **geom, const char **defines);
+
 void GPU_shader_free_builtin_shaders(void);
 
 /* Vertex attributes for shaders */
diff --git a/source/blender/gpu/intern/gpu_shader.c b/source/blender/gpu/intern/gpu_shader.c
index 55ba862548e..5c3776fc7b7 100644
--- a/source/blender/gpu/intern/gpu_shader.c
+++ b/source/blender/gpu/intern/gpu_shader.c
@@ -648,251 +648,352 @@ int GPU_shader_get_attribute(GPUShader *shader, const char *name)
 	return attrib ? attrib->location : -1;
 }
 
+static const GPUShaderStages builtin_shader_stages[GPU_NUM_BUILTIN_SHADERS] = {
+	[GPU_SHADER_SMOKE] =
+		{ datatoc_gpu_shader_smoke_vert_glsl,
+		  datatoc_gpu_shader_smoke_frag_glsl },
+	[GPU_SHADER_SMOKE_FIRE] =
+		{ datatoc_gpu_shader_smoke_vert_glsl,
+		  datatoc_gpu_shader_smoke_frag_glsl },
+	[GPU_SHADER_SMOKE_COBA] =
+		{ datatoc_gpu_shader_smoke_vert_glsl,
+		  datatoc_gpu_shader_smoke_frag_glsl },
+
+	[GPU_SHADER_TEXT] =
+		{ datatoc_gpu_shader_text_vert_glsl,
+		  datatoc_gpu_shader_text_frag_glsl,
+		  datatoc_gpu_shader_text_geom_glsl },
+	[GPU_SHADER_TEXT_SIMPLE] =
+		{ datatoc_gpu_shader_text_simple_vert_glsl,
+		  datatoc_gpu_shader_text_frag_glsl,
+		  datatoc_gpu_shader_text_simple_geom_glsl },
+	[GPU_SHADER_KEYFRAME_DIAMOND] =
+		{ datatoc_gpu_shader_keyframe_diamond_vert_glsl,
+		  datatoc_gpu_shader_keyframe_diamond_frag_glsl },
+	[GPU_SHADER_EDGES_FRONT_BACK_PERSP] =
+		{ datatoc_gpu_shader_edges_front_back_persp_vert_glsl,
+		  datatoc_gpu_shader_flat_color_frag_glsl,               /*  this version is     */
+		  datatoc_gpu_shader_edges_front_back_persp_geom_glsl }, /*  magical but slooow  */
+	[GPU_SHADER_EDGES_FRONT_BACK_ORTHO] =
+		{ datatoc_gpu_shader_edges_front_back_ortho_vert_glsl,
+		 datatoc_gpu_shader_flat_color_frag_glsl },
+	[GPU_SHADER_EDGES_OVERLAY_SIMPLE] =
+		{ datatoc_gpu_shader_3D_vert_glsl,
+		  datatoc_gpu_shader_edges_overlay_frag_glsl,
+		  datatoc_gpu_shader_edges_overlay_simple_geom_glsl },
+	[GPU_SHADER_EDGES_OVERLAY] =
+		{ datatoc_gpu_shader_edges_overlay_vert_glsl,
+		  datatoc_gpu_shader_edges_overlay_frag_glsl,
+		  datatoc_gpu_shader_edges_overlay_geom_glsl },
+	[GPU_SHADER_SIMPLE_LIGHTING] =
+		{ datatoc_gpu_shader_3D_normal_vert_glsl,
+		  datatoc_gpu_shader_simple_lighting_frag_glsl },
+	/* Use 'USE_FLAT_NORMAL' to make flat shader from smooth  */
+	[GPU_SHADER_SIMPLE_LIGHTING_FLAT_COLOR] =
+		{ datatoc_gpu_shader_3D_normal_smooth_color_vert_glsl,
+		  datatoc_gpu_shader_simple_lighting_smooth_color_frag_glsl },
+	[GPU_SHADER_SIMPLE_LIGHTING_SMOOTH_COLOR] =
+		{ datatoc_gpu_shader_3D_normal_smooth_color_vert_glsl,
+		  datatoc_gpu_shader_simple_lighting_smooth_color_frag_glsl },
+	[GPU_SHADER_SIMPLE_LIGHTING_SMOOTH_COLOR_ALPHA] =
+		{ datatoc_gpu_shader_3D_normal_smooth_color_vert_glsl,
+		  datatoc_gpu_shader_simple_lighting_smooth_color_alpha_frag_glsl },
+
+	[GPU_SHADER_2D_IMAGE_MASK_UNIFORM_COLOR] =
+		{ datatoc_gpu_shader_3D_image_vert_glsl,
+		  datatoc_gpu_shader_image_mask_uniform_color_frag_glsl },
+	[GPU_SHADER_3D_IMAGE_MODULATE_ALPHA] =
+		{ datatoc_gpu_shader_3D_image_vert_glsl,
+		  datatoc_gpu_shader_image_modulate_alpha_frag_glsl },
+	[GPU_SHADER_3D_IMAGE_DEPTH] =
+		{ datatoc_gpu_shader_3D_image_vert_glsl,
+		  datatoc_gpu_shader_image_depth_linear_frag_glsl },
+	[GPU_SHADER_3D_IMAGE_DEPTH_COPY] =
+		{ datatoc_gpu_shader_3D_image_vert_glsl,
+		  datatoc_gpu_shader_image_depth_copy_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_MULTISAMPLE_2] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_image_multisample_resolve_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_MULTISAMPLE_4] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_image_multisample_resolve_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_MULTISAMPLE_8] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_image_multisample_resolve_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_MULTISAMPLE_16] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_image_multisample_resolve_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_MULTISAMPLE_2_DEPTH_TEST] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_image_multisample_resolve_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_MULTISAMPLE_4_DEPTH_TEST] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_image_multisample_resolve_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_MULTISAMPLE_8_DEPTH_TEST] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_image_multisample_resolve_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_MULTISAMPLE_16_DEPTH_TEST] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_image_multisample_resolve_frag_glsl },
+
+	[GPU_SHADER_2D_IMAGE_INTERLACE] =
+		{ datatoc_gpu_shader_2D_image_vert_glsl,
+		  datatoc_gpu_shader_image_interlace_frag_glsl },
+	[GPU_SHADER_2D_CHECKER] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_checker_frag_glsl },
+
+	[GPU_SHADER_2D_DIAG_STRIPES] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_diag_stripes_frag_glsl },
+
+	[GPU_SHADER_2D_UNIFORM_COLOR] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_uniform_color_frag_glsl },
+	[GPU_SHADER_2D_FLAT_COLOR] =
+		{ datatoc_gpu_shader_2D_flat_color_vert_glsl,
+		  datatoc_gpu_shader_flat_color_frag_glsl },
+	[GPU_SHADER_2D_SMOOTH_COLOR] =
+		{ datatoc_gpu_shader_2D_smooth_color_vert_glsl,
+		  datatoc_gpu_shader_2D_smooth_color_frag_glsl },
+	[GPU_SHADER_2D_SMOOTH_COLOR_DITHER] =
+		{ datatoc_gpu_shader_2D_smooth_color_vert_glsl,
+		  datatoc_gpu_shader_2D_smooth_color_dithered_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_LINEAR_TO_SRGB] =
+		{ datatoc_gpu_shader_2D_image_vert_glsl,
+		  datatoc_gpu_shader_image_linear_frag_glsl },
+	[GPU_SHADER_2D_IMAGE] =
+		{ datatoc_gpu_shader_2D_image_vert_glsl,
+		  datatoc_gpu_shader_image_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_COLOR] =
+		{ datatoc_gpu_shader_2D_image_vert_glsl,
+		  datatoc_gpu_shader_image_color_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_DESATURATE_COLOR] =
+		{ datatoc_gpu_shader_2D_image_vert_glsl,
+		  datatoc_gpu_shader_image_desaturate_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_ALPHA_COLOR] =
+		{ datatoc_gpu_shader_2D_image_vert_glsl,
+		  datatoc_gpu_shader_image_alpha_color_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_SHUFFLE_COLOR] =
+		{ datatoc_gpu_shader_2D_image_vert_glsl,
+		  datatoc_gpu_shader_image_shuffle_color_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_RECT_COLOR] =
+		{ datatoc_gpu_shader_2D_image_rect_vert_glsl,
+		  datatoc_gpu_shader_image_color_frag_glsl },
+	[GPU_SHADER_2D_IMAGE_MULTI_RECT_COLOR] =
+		{ datatoc_gpu_shader_2D_image_multi_rect_vert_glsl,
+		  datatoc_gpu_shader_image_varying_color_frag_glsl },
+
+	[GPU_SHADER_3D_UNIFORM_COLOR] =
+		{ datatoc_gpu_shader_3D_vert_glsl,
+		  datatoc_gpu_shader_uniform_color_frag_glsl },
+	[GPU_SHADER_3D_UNIFORM_COLOR_U32] =
+		{ datatoc_gpu_shader_3D_vert_glsl,
+		  datatoc_gpu_shader_uniform_color_frag_glsl },
+	[GPU_SHADER_3D_FLAT_COLOR] =
+		{ datatoc_gpu_shader_3D_flat_color_vert_glsl,
+		  datatoc_gpu_shader_flat_color_frag_glsl },
+	[GPU_SHADER_3D_FLAT_COLOR_U32] =
+		{ datatoc_gpu_shader_3D_flat_color_vert_glsl,
+		  datatoc_gpu_shader_flat_color_frag_glsl },
+	[GPU_SHADER_3D_SMOOTH_COLOR] =
+		{ datatoc_gpu_shader_3D_smooth_color_vert_glsl,
+		  datatoc_gpu_shader_3D_smooth_color_frag_glsl },
+	[GPU_SHADER_3D_DEPTH_ONLY] =
+		{ datatoc_gpu_shader_3D_vert_glsl,
+		  datatoc_gpu_shader_depth_only_frag_glsl },
+	[GPU_SHADER_3D_CLIPPED_UNIFORM_COLOR] =
+		{ datatoc_gpu_shader_3D_clipped_uniform_color_vert_glsl,
+		  datatoc_gpu_shader_uniform_color_frag_glsl },
+
+	[GPU_SHADER_3D_GROUNDPOINT] =
+		{ datatoc_gpu_shader_3D_groundpoint_vert_glsl,
+		  datatoc_gpu_shader_point_uniform_color_frag_glsl },
+	[GPU_SHADER_3D_GROUNDLINE] =
+		{ datatoc_gpu_shader_3D_passthrough_vert_glsl,
+		  datatoc_gpu_shader_uniform_color_frag_glsl,
+		  datatoc_gpu_shader_3D_groundline_geom_glsl },
+
+	[GPU_SHADER_2D_LINE_DASHED_UNIFORM_COLOR] =
+		{ datatoc_gpu_shader_2D_line_dashed_uniform_color_vert_glsl,
+		  datatoc_gpu_shader_2D_line_dashed_frag_glsl,
+		  datatoc_gpu_shader_2D_line_dashed_geom_glsl },
+	[GPU_SHADER_3D_LINE_DASHED_UNIFORM_COLOR] =
+		{ datatoc_gpu_shader_3D_line_dashed_uniform_color_vert_glsl,
+		  datatoc_gpu_shader_2D_line_dashed_frag_glsl,
+		  datatoc_gpu_shader_2D_line_dashed_geom_glsl },
+
+	[GPU_SHADER_3D_OBJECTSPACE_SIMPLE_LIGHTING_VARIYING_COLOR] =
+		{ datatoc_gpu_shader_instance_objectspace_variying_color_vert_glsl,
+		  datatoc_gpu_shader_simple_lighting_frag_glsl},
+	[GPU_SHADER_3D_OBJECTSPACE_VARIYING_COLOR] =
+		{ datatoc_gpu_shader_instance_objectspace_variying_color_vert_glsl,
+		  datatoc_gpu_shader_flat_color_frag_glsl},
+	[GPU_SHADER_3D_SCREENSPACE_VARIYING_COLOR] =
+		{ datatoc_gpu_shader_instance_screenspace_variying_color_vert_glsl,
+		  datatoc_gpu_shader_flat_color_frag_glsl},
+	[GPU_SHADER_3D_INSTANCE_SCREEN_ALIGNED_AXIS] =
+		{ datatoc_gpu_shader_instance_screen_aligned_vert_glsl,
+		  datatoc_gpu_shader_flat_color_frag_glsl},
+	[GPU_SHADER_3D_INSTANCE_SCREEN_ALIGNED] =
+		{ datatoc_gpu_shader_instance_screen_aligned_vert_glsl,
+		  datatoc_gpu_shader_flat_color_frag_glsl},
+
+	[GPU_SHADER_CAMERA] =
+		{ datatoc_gpu_shader_instance_camera_vert_glsl,
+		  datatoc_gpu_shader_flat_color_frag_glsl},
+	[GPU_SHADER_DISTANCE_LINES] =
+		{ datatoc_gpu_shader_instance_distance_line_vert_glsl,
+		  datatoc_gpu_shader_flat_color_frag_glsl},
+
+	[GPU_SHADER_2D_POINT_FIXED_SIZE_UNIFORM_COLOR] =
+		{ datatoc_gpu_shader_2D_vert_glsl,
+		  datatoc_gpu_shader_point_uniform_color_frag_glsl },
+	[GPU_SHADER_2D_POINT_VARYING_SIZE_VARYING_COLOR] =
+		{ datatoc_gpu_shader_2D_point_varying_size_varying_color_vert_glsl,
+		  datatoc_gpu_shader_point_varying_color_frag_glsl },
+	[GPU_SHADER_2D_POINT_UNIFORM_SIZE_UNIFORM_COLOR_AA] =
+		{ datatoc_gpu_shader_2D_point_uniform_size_aa_vert_glsl,
+		  datatoc_gpu_sh

@@ Diff output truncated at 10240 characters. @@



More information about the Bf-blender-cvs mailing list