summaryrefslogtreecommitdiffstats
path: root/drivers/gpu
diff options
context:
space:
mode:
authorAlex Deucher <alexander.deucher@amd.com>2014-10-15 23:20:55 +0200
committerAlex Deucher <alexander.deucher@amd.com>2014-10-17 00:34:09 +0200
commit8e66e134e20b936179ea1535dd4ed19ec4f99dba (patch)
tree72d79bcfa0252136570760964444792ecfb17a5e /drivers/gpu
parentdrm/ttm: Don't evict BOs outside of the requested placement range (diff)
downloadlinux-8e66e134e20b936179ea1535dd4ed19ec4f99dba.tar.xz
linux-8e66e134e20b936179ea1535dd4ed19ec4f99dba.zip
drm/radeon: fix vm page table block size calculation
The page offset is 12 bits. For example if we have an 8 GB VM, we'd need 33 bits. The number of bits needed for PD + PT is 21 (33 - 12 or log2(8) + 18), not 20 (log2(8) + 17). Noticed by Alexey during code review. Signed-off-by: Alex Deucher <alexander.deucher@amd.com> Cc: stable@vger.kernel.org
Diffstat (limited to 'drivers/gpu')
-rw-r--r--drivers/gpu/drm/radeon/radeon_device.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_device.c b/drivers/gpu/drm/radeon/radeon_device.c
index 6fbab1582112..55065d844205 100644
--- a/drivers/gpu/drm/radeon/radeon_device.c
+++ b/drivers/gpu/drm/radeon/radeon_device.c
@@ -1126,7 +1126,7 @@ static void radeon_check_arguments(struct radeon_device *rdev)
if (radeon_vm_block_size == -1) {
/* Total bits covered by PD + PTs */
- unsigned bits = ilog2(radeon_vm_size) + 17;
+ unsigned bits = ilog2(radeon_vm_size) + 18;
/* Make sure the PD is 4K in size up to 8GB address space.
Above that split equal between PD and PTs */