mirror of
				https://git.suyu.dev/suyu/suyu
				synced 2025-11-04 00:49:02 -06:00 
			
		
		
		
	glsl: Track S32 atomics
This commit is contained in:
		@@ -110,9 +110,12 @@ void EmitContext::DefineHelperFunctions() {
 | 
				
			|||||||
        code += "uint CasFloatMax16x2(uint op_a,f16vec2 op_b){return "
 | 
					        code += "uint CasFloatMax16x2(uint op_a,f16vec2 op_b){return "
 | 
				
			||||||
                "packFloat2x16(max(unpackFloat2x16(op_a),op_b));}\n";
 | 
					                "packFloat2x16(max(unpackFloat2x16(op_a),op_b));}\n";
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    // TODO: Track this usage
 | 
					    if (info.uses_atomic_s32_min) {
 | 
				
			||||||
    code += "uint CasMinS32(uint op_a,uint op_b){return uint(min(int(op_a),int(op_b)));}";
 | 
					        code += "uint CasMinS32(uint op_a,uint op_b){return uint(min(int(op_a),int(op_b)));}";
 | 
				
			||||||
    code += "uint CasMaxS32(uint op_a,uint op_b){return uint(max(int(op_a),int(op_b)));}";
 | 
					    }
 | 
				
			||||||
 | 
					    if (info.uses_atomic_s32_max) {
 | 
				
			||||||
 | 
					        code += "uint CasMaxS32(uint op_a,uint op_b){return uint(max(int(op_a),int(op_b)));}";
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
} // namespace Shader::Backend::GLSL
 | 
					} // namespace Shader::Backend::GLSL
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -687,9 +687,7 @@ void VisitUsages(Info& info, IR::Inst& inst) {
 | 
				
			|||||||
    case IR::Opcode::LoadStorage32:
 | 
					    case IR::Opcode::LoadStorage32:
 | 
				
			||||||
    case IR::Opcode::WriteStorage32:
 | 
					    case IR::Opcode::WriteStorage32:
 | 
				
			||||||
    case IR::Opcode::StorageAtomicIAdd32:
 | 
					    case IR::Opcode::StorageAtomicIAdd32:
 | 
				
			||||||
    case IR::Opcode::StorageAtomicSMin32:
 | 
					 | 
				
			||||||
    case IR::Opcode::StorageAtomicUMin32:
 | 
					    case IR::Opcode::StorageAtomicUMin32:
 | 
				
			||||||
    case IR::Opcode::StorageAtomicSMax32:
 | 
					 | 
				
			||||||
    case IR::Opcode::StorageAtomicUMax32:
 | 
					    case IR::Opcode::StorageAtomicUMax32:
 | 
				
			||||||
    case IR::Opcode::StorageAtomicAnd32:
 | 
					    case IR::Opcode::StorageAtomicAnd32:
 | 
				
			||||||
    case IR::Opcode::StorageAtomicOr32:
 | 
					    case IR::Opcode::StorageAtomicOr32:
 | 
				
			||||||
@@ -759,6 +757,14 @@ void VisitUsages(Info& info, IR::Inst& inst) {
 | 
				
			|||||||
        info.used_storage_buffer_types |= IR::Type::U32;
 | 
					        info.used_storage_buffer_types |= IR::Type::U32;
 | 
				
			||||||
        info.uses_atomic_f32x2_max = true;
 | 
					        info.uses_atomic_f32x2_max = true;
 | 
				
			||||||
        break;
 | 
					        break;
 | 
				
			||||||
 | 
					    case IR::Opcode::StorageAtomicSMin32:
 | 
				
			||||||
 | 
					        info.used_storage_buffer_types |= IR::Type::U32;
 | 
				
			||||||
 | 
					        info.uses_atomic_s32_min = true;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case IR::Opcode::StorageAtomicSMax32:
 | 
				
			||||||
 | 
					        info.used_storage_buffer_types |= IR::Type::U32;
 | 
				
			||||||
 | 
					        info.uses_atomic_s32_max = true;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
    case IR::Opcode::GlobalAtomicIAdd64:
 | 
					    case IR::Opcode::GlobalAtomicIAdd64:
 | 
				
			||||||
    case IR::Opcode::GlobalAtomicSMin64:
 | 
					    case IR::Opcode::GlobalAtomicSMin64:
 | 
				
			||||||
    case IR::Opcode::GlobalAtomicUMin64:
 | 
					    case IR::Opcode::GlobalAtomicUMin64:
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -189,8 +189,9 @@ struct Info {
 | 
				
			|||||||
    bool uses_atomic_f32x2_add{};
 | 
					    bool uses_atomic_f32x2_add{};
 | 
				
			||||||
    bool uses_atomic_f32x2_min{};
 | 
					    bool uses_atomic_f32x2_min{};
 | 
				
			||||||
    bool uses_atomic_f32x2_max{};
 | 
					    bool uses_atomic_f32x2_max{};
 | 
				
			||||||
 | 
					    bool uses_atomic_s32_min{};
 | 
				
			||||||
 | 
					    bool uses_atomic_s32_max{};
 | 
				
			||||||
    bool uses_int64_bit_atomics{};
 | 
					    bool uses_int64_bit_atomics{};
 | 
				
			||||||
    bool uses_s32_atomics{};
 | 
					 | 
				
			||||||
    bool uses_global_memory{};
 | 
					    bool uses_global_memory{};
 | 
				
			||||||
    bool uses_atomic_image_u32{};
 | 
					    bool uses_atomic_image_u32{};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user