diff options
| author | Christian König <deathsimple@vodafone.de> | 2012-07-31 07:48:51 -0400 |
|---|---|---|
| committer | Alex Deucher <alexander.deucher@amd.com> | 2012-08-13 10:50:50 -0400 |
| commit | dca571a6a4edda1f61ba7ecb47431a22245490a3 (patch) | |
| tree | 0fdc726307dfe7084c8c8f07f4777b8601605f61 /drivers | |
| parent | 6c0ae2ab85fc4a95cae82047a7db1f688a7737ab (diff) | |
drm/radeon: fix bank tiling parameters on SI
The sixteen bank case wasn't handled here, leading to GPU
crashes because of userspace miscalculation.
Signed-off-by: Christian König <deathsimple@vodafone.de>
Cc: stable@vger.kernel.org
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers')
| -rw-r--r-- | drivers/gpu/drm/radeon/si.c | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/drivers/gpu/drm/radeon/si.c b/drivers/gpu/drm/radeon/si.c index c053f8193771..c153a7f359c8 100644 --- a/drivers/gpu/drm/radeon/si.c +++ b/drivers/gpu/drm/radeon/si.c | |||
| @@ -1639,11 +1639,19 @@ static void si_gpu_init(struct radeon_device *rdev) | |||
| 1639 | /* XXX what about 12? */ | 1639 | /* XXX what about 12? */ |
| 1640 | rdev->config.si.tile_config |= (3 << 0); | 1640 | rdev->config.si.tile_config |= (3 << 0); |
| 1641 | break; | 1641 | break; |
| 1642 | } | 1642 | } |
| 1643 | if ((mc_arb_ramcfg & NOOFBANK_MASK) >> NOOFBANK_SHIFT) | 1643 | switch ((mc_arb_ramcfg & NOOFBANK_MASK) >> NOOFBANK_SHIFT) { |
| 1644 | rdev->config.si.tile_config |= 1 << 4; | 1644 | case 0: /* four banks */ |
| 1645 | else | ||
| 1646 | rdev->config.si.tile_config |= 0 << 4; | 1645 | rdev->config.si.tile_config |= 0 << 4; |
| 1646 | break; | ||
| 1647 | case 1: /* eight banks */ | ||
| 1648 | rdev->config.si.tile_config |= 1 << 4; | ||
| 1649 | break; | ||
| 1650 | case 2: /* sixteen banks */ | ||
| 1651 | default: | ||
| 1652 | rdev->config.si.tile_config |= 2 << 4; | ||
| 1653 | break; | ||
| 1654 | } | ||
| 1647 | rdev->config.si.tile_config |= | 1655 | rdev->config.si.tile_config |= |
| 1648 | ((gb_addr_config & PIPE_INTERLEAVE_SIZE_MASK) >> PIPE_INTERLEAVE_SIZE_SHIFT) << 8; | 1656 | ((gb_addr_config & PIPE_INTERLEAVE_SIZE_MASK) >> PIPE_INTERLEAVE_SIZE_SHIFT) << 8; |
| 1649 | rdev->config.si.tile_config |= | 1657 | rdev->config.si.tile_config |= |
