drm/radeon/kms: fix tiled db height calculation on 6xx/7xx

Calculate height based on the slice bitfield rather than the size.
Same as Dave's CB fix.

Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
This commit is contained in:
Alex Deucher 2010-10-27 01:44:35 -04:00 committed by Dave Airlie
parent 43b93fbffc
commit 2c7d81acf4

View File

@ -310,7 +310,7 @@ static int r600_cs_track_check(struct radeon_cs_parser *p)
/* Check depth buffer */ /* Check depth buffer */
if (G_028800_STENCIL_ENABLE(track->db_depth_control) || if (G_028800_STENCIL_ENABLE(track->db_depth_control) ||
G_028800_Z_ENABLE(track->db_depth_control)) { G_028800_Z_ENABLE(track->db_depth_control)) {
u32 nviews, bpe, ntiles, pitch, pitch_align, height, size; u32 nviews, bpe, ntiles, pitch, pitch_align, height, size, slice_tile_max;
if (track->db_bo == NULL) { if (track->db_bo == NULL) {
dev_warn(p->dev, "z/stencil with no depth buffer\n"); dev_warn(p->dev, "z/stencil with no depth buffer\n");
return -EINVAL; return -EINVAL;
@ -354,11 +354,11 @@ static int r600_cs_track_check(struct radeon_cs_parser *p)
} else { } else {
size = radeon_bo_size(track->db_bo); size = radeon_bo_size(track->db_bo);
pitch = G_028000_PITCH_TILE_MAX(track->db_depth_size) + 1; pitch = G_028000_PITCH_TILE_MAX(track->db_depth_size) + 1;
height = size / (pitch * 8 * bpe); slice_tile_max = G_028000_SLICE_TILE_MAX(track->db_depth_size) + 1;
height &= ~0x7; slice_tile_max *= 64;
if (!height) height = slice_tile_max / (pitch * 8);
height = 8; if (height > 8192)
height = 8192;
switch (G_028010_ARRAY_MODE(track->db_depth_info)) { switch (G_028010_ARRAY_MODE(track->db_depth_info)) {
case V_028010_ARRAY_1D_TILED_THIN1: case V_028010_ARRAY_1D_TILED_THIN1:
pitch_align = (max((u32)8, (u32)(track->group_size / (8 * bpe))) / 8); pitch_align = (max((u32)8, (u32)(track->group_size / (8 * bpe))) / 8);
@ -367,6 +367,8 @@ static int r600_cs_track_check(struct radeon_cs_parser *p)
__func__, __LINE__, pitch); __func__, __LINE__, pitch);
return -EINVAL; return -EINVAL;
} }
/* don't break userspace */
height &= ~0x7;
if (!IS_ALIGNED(height, 8)) { if (!IS_ALIGNED(height, 8)) {
dev_warn(p->dev, "%s:%d db height (%d) invalid\n", dev_warn(p->dev, "%s:%d db height (%d) invalid\n",
__func__, __LINE__, height); __func__, __LINE__, height);