|
|
|
@ -143,10 +143,19 @@ void ComputePipeline::Configure() {
|
|
|
|
|
}
|
|
|
|
|
texture_cache.FillComputeImageViews(std::span(views.data(), views.size()));
|
|
|
|
|
|
|
|
|
|
const bool is_rescaling{texture_cache.IsRescaling()};
|
|
|
|
|
const f32 config_down_factor{Settings::values.resolution_info.down_factor};
|
|
|
|
|
const f32 down_factor{is_rescaling ? config_down_factor : 1.0f};
|
|
|
|
|
if (assembly_program.handle != 0) {
|
|
|
|
|
program_manager.BindComputeAssemblyProgram(assembly_program.handle);
|
|
|
|
|
if (info.uses_rescaling_uniform) {
|
|
|
|
|
glProgramEnvParameter4fARB(GL_COMPUTE_PROGRAM_NV, 0, down_factor, 0.0f, 0.0f, 1.0f);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
program_manager.BindComputeProgram(source_program.handle);
|
|
|
|
|
if (info.uses_rescaling_uniform) {
|
|
|
|
|
glProgramUniform1f(source_program.handle, 0, down_factor);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
buffer_cache.UnbindComputeTextureBuffers();
|
|
|
|
|
size_t texbuf_index{};
|
|
|
|
|