mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-25 03:00:29 +00:00 
			
		
		
		
	This patch add Tint end-to-end tests for built-ins using f16 types. Bug: tint:1473, tint:1502 Change-Id: I09db6e0b7e90541fb246e11d475e27be96a6d07e Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/97340 Reviewed-by: Antonio Maiorano <amaiorano@google.com> Reviewed-by: Dan Sinclair <dsinclair@chromium.org> Kokoro: Kokoro <noreply+kokoro@google.com> Commit-Queue: Zhaoming Jiang <zhaoming.jiang@intel.com>
		
			
				
	
	
		
			89 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			GLSL
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			GLSL
		
	
	
	
	
	
| #version 310 es
 | |
| #extension GL_AMD_gpu_shader_half_float : require
 | |
| 
 | |
| struct modf_result_vec3_f16 {
 | |
|   f16vec3 fract;
 | |
|   f16vec3 whole;
 | |
| };
 | |
| 
 | |
| modf_result_vec3_f16 tint_modf(f16vec3 param_0) {
 | |
|   modf_result_vec3_f16 result;
 | |
|   result.fract = modf(param_0, result.whole);
 | |
|   return result;
 | |
| }
 | |
| 
 | |
| 
 | |
| void modf_45005f() {
 | |
|   modf_result_vec3_f16 res = tint_modf(f16vec3(0.0hf));
 | |
| }
 | |
| 
 | |
| vec4 vertex_main() {
 | |
|   modf_45005f();
 | |
|   return vec4(0.0f);
 | |
| }
 | |
| 
 | |
| void main() {
 | |
|   gl_PointSize = 1.0;
 | |
|   vec4 inner_result = vertex_main();
 | |
|   gl_Position = inner_result;
 | |
|   gl_Position.y = -(gl_Position.y);
 | |
|   gl_Position.z = ((2.0f * gl_Position.z) - gl_Position.w);
 | |
|   return;
 | |
| }
 | |
| #version 310 es
 | |
| #extension GL_AMD_gpu_shader_half_float : require
 | |
| precision mediump float;
 | |
| 
 | |
| struct modf_result_vec3_f16 {
 | |
|   f16vec3 fract;
 | |
|   f16vec3 whole;
 | |
| };
 | |
| 
 | |
| modf_result_vec3_f16 tint_modf(f16vec3 param_0) {
 | |
|   modf_result_vec3_f16 result;
 | |
|   result.fract = modf(param_0, result.whole);
 | |
|   return result;
 | |
| }
 | |
| 
 | |
| 
 | |
| void modf_45005f() {
 | |
|   modf_result_vec3_f16 res = tint_modf(f16vec3(0.0hf));
 | |
| }
 | |
| 
 | |
| void fragment_main() {
 | |
|   modf_45005f();
 | |
| }
 | |
| 
 | |
| void main() {
 | |
|   fragment_main();
 | |
|   return;
 | |
| }
 | |
| #version 310 es
 | |
| #extension GL_AMD_gpu_shader_half_float : require
 | |
| 
 | |
| struct modf_result_vec3_f16 {
 | |
|   f16vec3 fract;
 | |
|   f16vec3 whole;
 | |
| };
 | |
| 
 | |
| modf_result_vec3_f16 tint_modf(f16vec3 param_0) {
 | |
|   modf_result_vec3_f16 result;
 | |
|   result.fract = modf(param_0, result.whole);
 | |
|   return result;
 | |
| }
 | |
| 
 | |
| 
 | |
| void modf_45005f() {
 | |
|   modf_result_vec3_f16 res = tint_modf(f16vec3(0.0hf));
 | |
| }
 | |
| 
 | |
| void compute_main() {
 | |
|   modf_45005f();
 | |
| }
 | |
| 
 | |
| layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
 | |
| void main() {
 | |
|   compute_main();
 | |
|   return;
 | |
| }
 |