forked from eden-emu/eden
		
	shaders: Add U64->U32x2 Atomic fallback functions
This commit is contained in:
		
							parent
							
								
									b7d23543b4
								
							
						
					
					
						commit
						0c5e641757
					
				
					 9 changed files with 469 additions and 1 deletions
				
			
		|  | @ -82,6 +82,17 @@ Id StorageAtomicU64(EmitContext& ctx, const IR::Value& binding, const IR::Value& | |||
|     ctx.OpStore(pointer, ctx.OpBitcast(ctx.U32[2], result)); | ||||
|     return original_value; | ||||
| } | ||||
| 
 | ||||
| Id StorageAtomicU32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, Id value, | ||||
|                       Id (Sirit::Module::*non_atomic_func)(Id, Id, Id)) { | ||||
|     LOG_WARNING(Shader_SPIRV, "Int64 atomics not supported, fallback to non-atomic"); | ||||
|     const Id pointer{StoragePointer(ctx, ctx.storage_types.U32x2, &StorageDefinitions::U32x2, | ||||
|                                     binding, offset, sizeof(u32[2]))}; | ||||
|     const Id original_value{ctx.OpLoad(ctx.U32[2], pointer)}; | ||||
|     const Id result{(ctx.*non_atomic_func)(ctx.U32[2], value, original_value)}; | ||||
|     ctx.OpStore(pointer, result); | ||||
|     return original_value; | ||||
| } | ||||
| } // Anonymous namespace
 | ||||
| 
 | ||||
| Id EmitSharedAtomicIAdd32(EmitContext& ctx, Id offset, Id value) { | ||||
|  | @ -141,7 +152,7 @@ Id EmitSharedAtomicExchange64(EmitContext& ctx, Id offset, Id value) { | |||
|         const auto [scope, semantics]{AtomicArgs(ctx)}; | ||||
|         return ctx.OpAtomicExchange(ctx.U64, pointer, scope, semantics, value); | ||||
|     } | ||||
|     LOG_ERROR(Shader_SPIRV, "Int64 atomics not supported, fallback to non-atomic"); | ||||
|     LOG_WARNING(Shader_SPIRV, "Int64 atomics not supported, fallback to non-atomic"); | ||||
|     const Id pointer_1{SharedPointer(ctx, offset, 0)}; | ||||
|     const Id pointer_2{SharedPointer(ctx, offset, 1)}; | ||||
|     const Id value_1{ctx.OpLoad(ctx.U32[1], pointer_1)}; | ||||
|  | @ -152,6 +163,18 @@ Id EmitSharedAtomicExchange64(EmitContext& ctx, Id offset, Id value) { | |||
|     return ctx.OpBitcast(ctx.U64, ctx.OpCompositeConstruct(ctx.U32[2], value_1, value_2)); | ||||
| } | ||||
| 
 | ||||
| Id EmitSharedAtomicExchange32x2(EmitContext& ctx, Id offset, Id value) { | ||||
|     LOG_WARNING(Shader_SPIRV, "Int64 atomics not supported, fallback to non-atomic"); | ||||
|     const Id pointer_1{SharedPointer(ctx, offset, 0)}; | ||||
|     const Id pointer_2{SharedPointer(ctx, offset, 1)}; | ||||
|     const Id value_1{ctx.OpLoad(ctx.U32[1], pointer_1)}; | ||||
|     const Id value_2{ctx.OpLoad(ctx.U32[1], pointer_2)}; | ||||
|     const Id new_vector{ctx.OpBitcast(ctx.U32[2], value)}; | ||||
|     ctx.OpStore(pointer_1, ctx.OpCompositeExtract(ctx.U32[1], new_vector, 0U)); | ||||
|     ctx.OpStore(pointer_2, ctx.OpCompositeExtract(ctx.U32[1], new_vector, 1U)); | ||||
|     return ctx.OpCompositeConstruct(ctx.U32[2], value_1, value_2); | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicIAdd32(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                            Id value) { | ||||
|     return StorageAtomicU32(ctx, binding, offset, value, &Sirit::Module::OpAtomicIAdd); | ||||
|  | @ -275,6 +298,56 @@ Id EmitStorageAtomicExchange64(EmitContext& ctx, const IR::Value& binding, const | |||
|     return original; | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicIAdd32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                              Id value) { | ||||
|     return StorageAtomicU32x2(ctx, binding, offset, value, &Sirit::Module::OpIAdd); | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicSMin32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                              Id value) { | ||||
|     return StorageAtomicU32x2(ctx, binding, offset, value, &Sirit::Module::OpSMin); | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicUMin32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                              Id value) { | ||||
|     return StorageAtomicU32x2(ctx, binding, offset, value, &Sirit::Module::OpUMin); | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicSMax32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                              Id value) { | ||||
|     return StorageAtomicU32x2(ctx, binding, offset, value, &Sirit::Module::OpSMax); | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicUMax32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                              Id value) { | ||||
|     return StorageAtomicU32x2(ctx, binding, offset, value, &Sirit::Module::OpUMax); | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicAnd32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                             Id value) { | ||||
|     return StorageAtomicU32x2(ctx, binding, offset, value, &Sirit::Module::OpBitwiseAnd); | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicOr32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                            Id value) { | ||||
|     return StorageAtomicU32x2(ctx, binding, offset, value, &Sirit::Module::OpBitwiseOr); | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicXor32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                             Id value) { | ||||
|     return StorageAtomicU32x2(ctx, binding, offset, value, &Sirit::Module::OpBitwiseXor); | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicExchange32x2(EmitContext& ctx, const IR::Value& binding, | ||||
|                                  const IR::Value& offset, Id value) { | ||||
|     LOG_WARNING(Shader_SPIRV, "Int64 atomics not supported, fallback to non-atomic"); | ||||
|     const Id pointer{StoragePointer(ctx, ctx.storage_types.U32x2, &StorageDefinitions::U32x2, | ||||
|                                     binding, offset, sizeof(u32[2]))}; | ||||
|     const Id original{ctx.OpLoad(ctx.U32[2], pointer)}; | ||||
|     ctx.OpStore(pointer, value); | ||||
|     return original; | ||||
| } | ||||
| 
 | ||||
| Id EmitStorageAtomicAddF32(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                            Id value) { | ||||
|     const Id ssbo{ctx.ssbos[binding.U32()].U32}; | ||||
|  | @ -418,6 +491,50 @@ Id EmitGlobalAtomicExchange64(EmitContext&) { | |||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicIAdd32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicSMin32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicUMin32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicSMax32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicUMax32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicInc32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicDec32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicAnd32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicOr32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicXor32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicExchange32x2(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
| 
 | ||||
| Id EmitGlobalAtomicAddF32(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
|  |  | |||
|  | @ -335,6 +335,7 @@ Id EmitSharedAtomicOr32(EmitContext& ctx, Id pointer_offset, Id value); | |||
| Id EmitSharedAtomicXor32(EmitContext& ctx, Id pointer_offset, Id value); | ||||
| Id EmitSharedAtomicExchange32(EmitContext& ctx, Id pointer_offset, Id value); | ||||
| Id EmitSharedAtomicExchange64(EmitContext& ctx, Id pointer_offset, Id value); | ||||
| Id EmitSharedAtomicExchange32x2(EmitContext& ctx, Id pointer_offset, Id value); | ||||
| Id EmitStorageAtomicIAdd32(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                            Id value); | ||||
| Id EmitStorageAtomicSMin32(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|  | @ -375,6 +376,24 @@ Id EmitStorageAtomicXor64(EmitContext& ctx, const IR::Value& binding, const IR:: | |||
|                           Id value); | ||||
| Id EmitStorageAtomicExchange64(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                                Id value); | ||||
| Id EmitStorageAtomicIAdd32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                              Id value); | ||||
| Id EmitStorageAtomicSMin32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                              Id value); | ||||
| Id EmitStorageAtomicUMin32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                              Id value); | ||||
| Id EmitStorageAtomicSMax32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                              Id value); | ||||
| Id EmitStorageAtomicUMax32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                              Id value); | ||||
| Id EmitStorageAtomicAnd32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                             Id value); | ||||
| Id EmitStorageAtomicOr32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                            Id value); | ||||
| Id EmitStorageAtomicXor32x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                             Id value); | ||||
| Id EmitStorageAtomicExchange32x2(EmitContext& ctx, const IR::Value& binding, | ||||
|                                  const IR::Value& offset, Id value); | ||||
| Id EmitStorageAtomicAddF32(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|                            Id value); | ||||
| Id EmitStorageAtomicAddF16x2(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||
|  | @ -411,6 +430,17 @@ Id EmitGlobalAtomicAnd64(EmitContext& ctx); | |||
| Id EmitGlobalAtomicOr64(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicXor64(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicExchange64(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicIAdd32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicSMin32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicUMin32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicSMax32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicUMax32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicInc32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicDec32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicAnd32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicOr32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicXor32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicExchange32x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicAddF32(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicAddF16x2(EmitContext& ctx); | ||||
| Id EmitGlobalAtomicAddF32x2(EmitContext& ctx); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ameerj
						ameerj