fix sampler configuration, thanks to Marcos for his investigation
This commit is contained in:
parent
b312cca756
commit
81a9c5fe6f
|
@ -735,9 +735,8 @@ void RasterizerOpenGL::SamplerInfo::Create() {
|
||||||
glSamplerParameteri(sampler.handle, GL_TEXTURE_COMPARE_FUNC, GL_NEVER);
|
glSamplerParameteri(sampler.handle, GL_TEXTURE_COMPARE_FUNC, GL_NEVER);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RasterizerOpenGL::SamplerInfo::SyncWithConfig(const Tegra::Texture::FullTextureInfo& info) {
|
void RasterizerOpenGL::SamplerInfo::SyncWithConfig(const Tegra::Texture::TSCEntry& config) {
|
||||||
const GLuint s = sampler.handle;
|
const GLuint s = sampler.handle;
|
||||||
const Tegra::Texture::TSCEntry& config = info.tsc;
|
|
||||||
if (mag_filter != config.mag_filter) {
|
if (mag_filter != config.mag_filter) {
|
||||||
mag_filter = config.mag_filter;
|
mag_filter = config.mag_filter;
|
||||||
glSamplerParameteri(
|
glSamplerParameteri(
|
||||||
|
@ -779,28 +778,50 @@ void RasterizerOpenGL::SamplerInfo::SyncWithConfig(const Tegra::Texture::FullTex
|
||||||
MaxwellToGL::DepthCompareFunc(depth_compare_func));
|
MaxwellToGL::DepthCompareFunc(depth_compare_func));
|
||||||
}
|
}
|
||||||
|
|
||||||
const GLvec4 new_border_color = {{config.border_color_r, config.border_color_g,
|
GLvec4 new_border_color;
|
||||||
config.border_color_b, config.border_color_a}};
|
if (config.srgb_conversion) {
|
||||||
|
new_border_color[0] = config.srgb_border_color_r / 255.0f;
|
||||||
|
new_border_color[1] = config.srgb_border_color_g / 255.0f;
|
||||||
|
new_border_color[2] = config.srgb_border_color_g / 255.0f;
|
||||||
|
} else {
|
||||||
|
new_border_color[0] = config.border_color_r;
|
||||||
|
new_border_color[1] = config.border_color_g;
|
||||||
|
new_border_color[2] = config.border_color_b;
|
||||||
|
}
|
||||||
|
new_border_color[3] = config.border_color_a;
|
||||||
|
|
||||||
if (border_color != new_border_color) {
|
if (border_color != new_border_color) {
|
||||||
border_color = new_border_color;
|
border_color = new_border_color;
|
||||||
glSamplerParameterfv(s, GL_TEXTURE_BORDER_COLOR, border_color.data());
|
glSamplerParameterfv(s, GL_TEXTURE_BORDER_COLOR, border_color.data());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (info.tic.use_header_opt_control == 0) {
|
const float anisotropic_max = static_cast<float>(1 << config.max_anisotropy.Value());
|
||||||
|
if (anisotropic_max != max_anisotropic) {
|
||||||
|
max_anisotropic = anisotropic_max;
|
||||||
if (GLAD_GL_ARB_texture_filter_anisotropic) {
|
if (GLAD_GL_ARB_texture_filter_anisotropic) {
|
||||||
glSamplerParameterf(s, GL_TEXTURE_MAX_ANISOTROPY,
|
glSamplerParameterf(s, GL_TEXTURE_MAX_ANISOTROPY, max_anisotropic);
|
||||||
static_cast<float>(1 << info.tic.max_anisotropy.Value()));
|
|
||||||
} else if (GLAD_GL_EXT_texture_filter_anisotropic) {
|
} else if (GLAD_GL_EXT_texture_filter_anisotropic) {
|
||||||
glSamplerParameterf(s, GL_TEXTURE_MAX_ANISOTROPY_EXT,
|
glSamplerParameterf(s, GL_TEXTURE_MAX_ANISOTROPY_EXT, max_anisotropic);
|
||||||
static_cast<float>(1 << info.tic.max_anisotropy.Value()));
|
|
||||||
}
|
}
|
||||||
glSamplerParameterf(s, GL_TEXTURE_MIN_LOD,
|
}
|
||||||
static_cast<float>(info.tic.res_min_mip_level.Value()));
|
const float lod_min = static_cast<float>(config.min_lod_clamp.Value()) / 256.0f;
|
||||||
glSamplerParameterf(s, GL_TEXTURE_MAX_LOD,
|
if (lod_min != min_lod) {
|
||||||
static_cast<float>(info.tic.res_max_mip_level.Value() == 0
|
min_lod = lod_min;
|
||||||
? 16
|
glSamplerParameterf(s, GL_TEXTURE_MIN_LOD, min_lod);
|
||||||
: info.tic.res_max_mip_level.Value()));
|
}
|
||||||
glSamplerParameterf(s, GL_TEXTURE_LOD_BIAS, info.tic.mip_lod_bias.Value() / 256.f);
|
|
||||||
|
const float lod_max = static_cast<float>(config.max_lod_clamp.Value()) / 256.0f;
|
||||||
|
if (lod_max != max_lod) {
|
||||||
|
max_lod = lod_max;
|
||||||
|
glSamplerParameterf(s, GL_TEXTURE_MAX_LOD, max_lod);
|
||||||
|
}
|
||||||
|
const u32 bias = config.mip_lod_bias.Value();
|
||||||
|
// Sign extend the 13-bit value.
|
||||||
|
const u32 mask = 1U << (13 - 1);
|
||||||
|
const float bias_lod = static_cast<s32>((bias ^ mask) - mask) / 256.f;
|
||||||
|
if (lod_bias != bias_lod) {
|
||||||
|
lod_bias = bias_lod;
|
||||||
|
glSamplerParameterf(s, GL_TEXTURE_LOD_BIAS, lod_bias);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -899,7 +920,7 @@ u32 RasterizerOpenGL::SetupTextures(Maxwell::ShaderStage stage, Shader& shader,
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
texture_samplers[current_bindpoint].SyncWithConfig(texture);
|
texture_samplers[current_bindpoint].SyncWithConfig(texture.tsc);
|
||||||
Surface surface = res_cache.GetTextureSurface(texture, entry);
|
Surface surface = res_cache.GetTextureSurface(texture, entry);
|
||||||
if (surface != nullptr) {
|
if (surface != nullptr) {
|
||||||
state.texture_units[current_bindpoint].texture = surface->Texture().handle;
|
state.texture_units[current_bindpoint].texture = surface->Texture().handle;
|
||||||
|
|
|
@ -88,7 +88,7 @@ private:
|
||||||
/// SamplerInfo struct.
|
/// SamplerInfo struct.
|
||||||
void Create();
|
void Create();
|
||||||
/// Syncs the sampler object with the config, updating any necessary state.
|
/// Syncs the sampler object with the config, updating any necessary state.
|
||||||
void SyncWithConfig(const Tegra::Texture::FullTextureInfo& info);
|
void SyncWithConfig(const Tegra::Texture::TSCEntry& info);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Tegra::Texture::TextureFilter mag_filter;
|
Tegra::Texture::TextureFilter mag_filter;
|
||||||
|
@ -100,6 +100,10 @@ private:
|
||||||
bool uses_depth_compare;
|
bool uses_depth_compare;
|
||||||
Tegra::Texture::DepthCompareFunc depth_compare_func;
|
Tegra::Texture::DepthCompareFunc depth_compare_func;
|
||||||
GLvec4 border_color;
|
GLvec4 border_color;
|
||||||
|
float min_lod;
|
||||||
|
float max_lod;
|
||||||
|
float lod_bias;
|
||||||
|
float max_anisotropic;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -190,6 +190,7 @@ struct TICEntry {
|
||||||
union {
|
union {
|
||||||
BitField<0, 4, u32> res_min_mip_level;
|
BitField<0, 4, u32> res_min_mip_level;
|
||||||
BitField<4, 4, u32> res_max_mip_level;
|
BitField<4, 4, u32> res_max_mip_level;
|
||||||
|
BitField<12, 12, u32> min_lod_clamp;
|
||||||
};
|
};
|
||||||
|
|
||||||
GPUVAddr Address() const {
|
GPUVAddr Address() const {
|
||||||
|
@ -284,13 +285,25 @@ struct TSCEntry {
|
||||||
BitField<6, 3, WrapMode> wrap_p;
|
BitField<6, 3, WrapMode> wrap_p;
|
||||||
BitField<9, 1, u32> depth_compare_enabled;
|
BitField<9, 1, u32> depth_compare_enabled;
|
||||||
BitField<10, 3, DepthCompareFunc> depth_compare_func;
|
BitField<10, 3, DepthCompareFunc> depth_compare_func;
|
||||||
|
BitField<13, 1, u32> srgb_conversion;
|
||||||
|
BitField<20, 3, u32> max_anisotropy;
|
||||||
};
|
};
|
||||||
union {
|
union {
|
||||||
BitField<0, 2, TextureFilter> mag_filter;
|
BitField<0, 2, TextureFilter> mag_filter;
|
||||||
BitField<4, 2, TextureFilter> min_filter;
|
BitField<4, 2, TextureFilter> min_filter;
|
||||||
BitField<6, 2, TextureMipmapFilter> mip_filter;
|
BitField<6, 2, TextureMipmapFilter> mip_filter;
|
||||||
|
BitField<9, 1, u32> cubemap_interface_filtering;
|
||||||
|
BitField<12, 13, u32> mip_lod_bias;
|
||||||
|
};
|
||||||
|
union {
|
||||||
|
BitField<0, 12, u32> min_lod_clamp;
|
||||||
|
BitField<12, 12, u32> max_lod_clamp;
|
||||||
|
BitField<24, 8, u32> srgb_border_color_r;
|
||||||
|
};
|
||||||
|
union {
|
||||||
|
BitField<12, 8, u32> srgb_border_color_g;
|
||||||
|
BitField<20, 8, u32> srgb_border_color_b;
|
||||||
};
|
};
|
||||||
INSERT_PADDING_BYTES(8);
|
|
||||||
float border_color_r;
|
float border_color_r;
|
||||||
float border_color_g;
|
float border_color_g;
|
||||||
float border_color_b;
|
float border_color_b;
|
||||||
|
|
Reference in New Issue