mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-01-24 01:40:22 +01:00
i965/sampler_state: Set the "Base Mip Level" field on Sandy Bridge
Fixes two GL ES 3.0 CTS tests on Sandy Bridge:
ES3-CTS.functional.texture.mipmap.cube.base_level.linear_linear
ES3-CTS.functional.texture.mipmap.cube.base_level.linear_nearest
Reviewed-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com>
Reviewed-by: Kenneth Graunke <kenneth@whitecape.org>
Cc: "17.0 13.0" <mesa-stable@lists.freedesktop.org>
(cherry picked from commit c59d1ea51b)
This commit is contained in:
parent
bcd58a918b
commit
1db3cebcbd
2 changed files with 20 additions and 1 deletions
|
|
@ -88,6 +88,7 @@ brw_emit_sampler_state(struct brw_context *brw,
|
|||
unsigned wrap_s,
|
||||
unsigned wrap_t,
|
||||
unsigned wrap_r,
|
||||
unsigned base_level,
|
||||
unsigned min_lod,
|
||||
unsigned max_lod,
|
||||
int lod_bias,
|
||||
|
|
@ -132,6 +133,21 @@ brw_emit_sampler_state(struct brw_context *brw,
|
|||
ss[0] |= SET_FIELD(lod_bias & 0x7ff, GEN4_SAMPLER_LOD_BIAS) |
|
||||
SET_FIELD(shadow_function, GEN4_SAMPLER_SHADOW_FUNCTION);
|
||||
|
||||
/* This field has existed since the original i965, but is declared MBZ
|
||||
* until Sandy Bridge. According to the PRM:
|
||||
*
|
||||
* "This was added to match OpenGL semantics"
|
||||
*
|
||||
* In particular, OpenGL allowed you to offset by 0.5 in certain cases
|
||||
* to get slightly better filtering. On Ivy Bridge and above, it
|
||||
* appears that this is added to RENDER_SURFACE_STATE::SurfaceMinLOD so
|
||||
* the right value is 0.0 or 0.5 (if you want the wacky behavior). On
|
||||
* Sandy Bridge, however, this sum does not seem to occur and you have
|
||||
* to set it to the actual base level of the texture.
|
||||
*/
|
||||
if (brw->gen == 6)
|
||||
ss[0] |= SET_FIELD(base_level, BRW_SAMPLER_BASE_MIPLEVEL);
|
||||
|
||||
if (brw->gen == 6 && min_filter != mag_filter)
|
||||
ss[0] |= GEN6_SAMPLER_MIN_MAG_NOT_EQUAL;
|
||||
|
||||
|
|
@ -503,6 +519,8 @@ brw_update_sampler_state(struct brw_context *brw,
|
|||
|
||||
const int lod_bits = brw->gen >= 7 ? 8 : 6;
|
||||
const float hw_max_lod = brw->gen >= 7 ? 14 : 13;
|
||||
const unsigned base_level =
|
||||
U_FIXED(CLAMP(texObj->MinLevel + texObj->BaseLevel, 0, hw_max_lod), 1);
|
||||
const unsigned min_lod =
|
||||
U_FIXED(CLAMP(sampler->MinLod, 0, hw_max_lod), lod_bits);
|
||||
const unsigned max_lod =
|
||||
|
|
@ -532,7 +550,7 @@ brw_update_sampler_state(struct brw_context *brw,
|
|||
max_anisotropy,
|
||||
address_rounding,
|
||||
wrap_s, wrap_t, wrap_r,
|
||||
min_lod, max_lod, lod_bias,
|
||||
base_level, min_lod, max_lod, lod_bias,
|
||||
shadow_function,
|
||||
non_normalized_coords,
|
||||
border_color_offset);
|
||||
|
|
|
|||
|
|
@ -335,6 +335,7 @@ void brw_emit_sampler_state(struct brw_context *brw,
|
|||
unsigned wrap_s,
|
||||
unsigned wrap_t,
|
||||
unsigned wrap_r,
|
||||
unsigned base_level,
|
||||
unsigned min_lod,
|
||||
unsigned max_lod,
|
||||
int lod_bias,
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue