Merge pull request #2700 from ZhiqianXia/u2i
Support Uint to Int implicit conversions at #extension GL_ARB_gpu_shader5.
This commit is contained in:
		
						commit
						ba540202cd
					
				
							
								
								
									
										11
									
								
								Test/GL_ARB_gpu_shader5.u2i.vert
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								Test/GL_ARB_gpu_shader5.u2i.vert
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| #version 150 | ||||
| #extension GL_ARB_gpu_shader5 : require | ||||
| 
 | ||||
| uniform int u1; | ||||
| uniform int u2; | ||||
| out   vec4 result; | ||||
| void main() | ||||
| { | ||||
|     uint v = 0; | ||||
|     v = uint(u2) - u1;  // implicit conversions | ||||
| } | ||||
							
								
								
									
										57
									
								
								Test/baseResults/GL_ARB_gpu_shader5.u2i.vert.out
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								Test/baseResults/GL_ARB_gpu_shader5.u2i.vert.out
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,57 @@ | ||||
| GL_ARB_gpu_shader5.u2i.vert | ||||
| WARNING: 0:2: '#extension' : extension is only partially supported: GL_ARB_gpu_shader5 | ||||
| 
 | ||||
| Shader version: 150 | ||||
| Requested GL_ARB_gpu_shader5 | ||||
| 0:? Sequence | ||||
| 0:7  Function Definition: main( ( global void) | ||||
| 0:7    Function Parameters:  | ||||
| 0:9    Sequence | ||||
| 0:9      Sequence | ||||
| 0:9        move second child to first child ( temp uint) | ||||
| 0:9          'v' ( temp uint) | ||||
| 0:9          Constant: | ||||
| 0:9            0 (const uint) | ||||
| 0:10      move second child to first child ( temp uint) | ||||
| 0:10        'v' ( temp uint) | ||||
| 0:10        subtract ( temp uint) | ||||
| 0:10          Convert int to uint ( temp uint) | ||||
| 0:10            'u2' ( uniform int) | ||||
| 0:10          Convert int to uint ( temp uint) | ||||
| 0:10            'u1' ( uniform int) | ||||
| 0:?   Linker Objects | ||||
| 0:?     'u1' ( uniform int) | ||||
| 0:?     'u2' ( uniform int) | ||||
| 0:?     'result' ( smooth out 4-component vector of float) | ||||
| 0:?     'gl_VertexID' ( gl_VertexId int VertexId) | ||||
| 0:?     'gl_InstanceID' ( gl_InstanceId int InstanceId) | ||||
| 
 | ||||
| 
 | ||||
| Linked vertex stage: | ||||
| 
 | ||||
| 
 | ||||
| Shader version: 150 | ||||
| Requested GL_ARB_gpu_shader5 | ||||
| 0:? Sequence | ||||
| 0:7  Function Definition: main( ( global void) | ||||
| 0:7    Function Parameters:  | ||||
| 0:9    Sequence | ||||
| 0:9      Sequence | ||||
| 0:9        move second child to first child ( temp uint) | ||||
| 0:9          'v' ( temp uint) | ||||
| 0:9          Constant: | ||||
| 0:9            0 (const uint) | ||||
| 0:10      move second child to first child ( temp uint) | ||||
| 0:10        'v' ( temp uint) | ||||
| 0:10        subtract ( temp uint) | ||||
| 0:10          Convert int to uint ( temp uint) | ||||
| 0:10            'u2' ( uniform int) | ||||
| 0:10          Convert int to uint ( temp uint) | ||||
| 0:10            'u1' ( uniform int) | ||||
| 0:?   Linker Objects | ||||
| 0:?     'u1' ( uniform int) | ||||
| 0:?     'u2' ( uniform int) | ||||
| 0:?     'result' ( smooth out 4-component vector of float) | ||||
| 0:?     'gl_VertexID' ( gl_VertexId int VertexId) | ||||
| 0:?     'gl_InstanceID' ( gl_InstanceId int InstanceId) | ||||
| 
 | ||||
| @ -1739,7 +1739,7 @@ bool TIntermediate::canImplicitlyPromote(TBasicType from, TBasicType to, TOperat | ||||
|         case EbtUint: | ||||
|             switch (from) { | ||||
|             case EbtInt: | ||||
|                 return version >= 400 || getSource() == EShSourceHlsl; | ||||
|                 return version >= 400 || getSource() == EShSourceHlsl || IsRequestedExtension(E_GL_ARB_gpu_shader5); | ||||
|             case EbtBool: | ||||
|                 return getSource() == EShSourceHlsl; | ||||
|             case EbtInt16: | ||||
|  | ||||
| @ -926,6 +926,11 @@ public: | ||||
|         return false; | ||||
|     } | ||||
| 
 | ||||
|     bool IsRequestedExtension(const char* extension) const | ||||
|     { | ||||
|         return (requestedExtensions.find(extension) != requestedExtensions.end()); | ||||
|     } | ||||
| 
 | ||||
|     void addToCallGraph(TInfoSink&, const TString& caller, const TString& callee); | ||||
|     void merge(TInfoSink&, TIntermediate&); | ||||
|     void finalCheck(TInfoSink&, bool keepUncalled); | ||||
|  | ||||
| @ -282,6 +282,7 @@ INSTANTIATE_TEST_SUITE_P( | ||||
|         "terminate.vert", | ||||
|         "negativeWorkGroupSize.comp", | ||||
|         "textureoffset_sampler2darrayshadow.vert", | ||||
|         "GL_ARB_gpu_shader5.u2i.vert", | ||||
|     })), | ||||
|     FileNameAsCustomTestSuffix | ||||
| ); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Greg Fischer
						Greg Fischer