mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-26 11:40:29 +00:00 
			
		
		
		
	This CL implements f16 in uniform and storage address space, allowing using f16 types in uniform and storage buffers on all backends. Tint uint tests and Dawn E2E tests are added to validate the f16 types work as expected. Bug: tint:1473, tint:1502 Change-Id: I15e3de1033d3727f2ea33f4657f682c5f13c2153 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/106320 Kokoro: Kokoro <noreply+kokoro@google.com> Commit-Queue: Zhaoming Jiang <zhaoming.jiang@intel.com> Reviewed-by: Ben Clayton <bclayton@google.com>
		
			
				
	
	
		
			65 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			GLSL
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			GLSL
		
	
	
	
	
	
| #version 310 es
 | |
| #extension GL_AMD_gpu_shader_half_float : require
 | |
| 
 | |
| layout(binding = 1, std430) buffer SB_RO_ssbo {
 | |
|   float16_t arg_0[];
 | |
| } sb_ro;
 | |
| 
 | |
| void arrayLength_8421b9() {
 | |
|   uint res = uint(sb_ro.arg_0.length());
 | |
| }
 | |
| 
 | |
| vec4 vertex_main() {
 | |
|   arrayLength_8421b9();
 | |
|   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;
 | |
| 
 | |
| layout(binding = 1, std430) buffer SB_RO_ssbo {
 | |
|   float16_t arg_0[];
 | |
| } sb_ro;
 | |
| 
 | |
| void arrayLength_8421b9() {
 | |
|   uint res = uint(sb_ro.arg_0.length());
 | |
| }
 | |
| 
 | |
| void fragment_main() {
 | |
|   arrayLength_8421b9();
 | |
| }
 | |
| 
 | |
| void main() {
 | |
|   fragment_main();
 | |
|   return;
 | |
| }
 | |
| #version 310 es
 | |
| #extension GL_AMD_gpu_shader_half_float : require
 | |
| 
 | |
| layout(binding = 1, std430) buffer SB_RO_ssbo {
 | |
|   float16_t arg_0[];
 | |
| } sb_ro;
 | |
| 
 | |
| void arrayLength_8421b9() {
 | |
|   uint res = uint(sb_ro.arg_0.length());
 | |
| }
 | |
| 
 | |
| void compute_main() {
 | |
|   arrayLength_8421b9();
 | |
| }
 | |
| 
 | |
| layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
 | |
| void main() {
 | |
|   compute_main();
 | |
|   return;
 | |
| }
 |