diff options
author | Dave Airlie <airlied@linux.ie> | 2008-07-15 01:48:05 -0400 |
---|---|---|
committer | Dave Airlie <airlied@linux.ie> | 2008-07-15 01:48:05 -0400 |
commit | 242e3df80b8d25ed681c278512df0993725f25dd (patch) | |
tree | 28dcd053d5c5203d8a952f0c1b5f354c3c7d06f7 /drivers/gpu | |
parent | 50515af207d410c9f228380e529c56f43c3de0bd (diff) |
drm/radeon: fixup issue with radeon and PAT support.
With new userspace libpciaccess we can get a conflicting mapping
on the PCIE GART table in the video RAM. Always try and map it _wc.
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu')
-rw-r--r-- | drivers/gpu/drm/drm_memory.c | 5 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_cp.c | 2 |
2 files changed, 6 insertions, 1 deletions
diff --git a/drivers/gpu/drm/drm_memory.c b/drivers/gpu/drm/drm_memory.c index 845081b44f63..0177012845c6 100644 --- a/drivers/gpu/drm/drm_memory.c +++ b/drivers/gpu/drm/drm_memory.c | |||
@@ -167,6 +167,11 @@ void drm_core_ioremap(struct drm_map *map, struct drm_device *dev) | |||
167 | } | 167 | } |
168 | EXPORT_SYMBOL(drm_core_ioremap); | 168 | EXPORT_SYMBOL(drm_core_ioremap); |
169 | 169 | ||
170 | void drm_core_ioremap_wc(struct drm_map *map, struct drm_device *dev) | ||
171 | { | ||
172 | map->handle = ioremap_wc(map->offset, map->size); | ||
173 | } | ||
174 | EXPORT_SYMBOL(drm_core_ioremap_wc); | ||
170 | void drm_core_ioremapfree(struct drm_map *map, struct drm_device *dev) | 175 | void drm_core_ioremapfree(struct drm_map *map, struct drm_device *dev) |
171 | { | 176 | { |
172 | if (!map->handle || !map->size) | 177 | if (!map->handle || !map->size) |
diff --git a/drivers/gpu/drm/radeon/radeon_cp.c b/drivers/gpu/drm/radeon/radeon_cp.c index e53158f0ecb5..f0de81a5689d 100644 --- a/drivers/gpu/drm/radeon/radeon_cp.c +++ b/drivers/gpu/drm/radeon/radeon_cp.c | |||
@@ -1154,7 +1154,7 @@ static int radeon_do_init_cp(struct drm_device * dev, drm_radeon_init_t * init) | |||
1154 | dev_priv->gart_info.mapping.size = | 1154 | dev_priv->gart_info.mapping.size = |
1155 | dev_priv->gart_info.table_size; | 1155 | dev_priv->gart_info.table_size; |
1156 | 1156 | ||
1157 | drm_core_ioremap(&dev_priv->gart_info.mapping, dev); | 1157 | drm_core_ioremap_wc(&dev_priv->gart_info.mapping, dev); |
1158 | dev_priv->gart_info.addr = | 1158 | dev_priv->gart_info.addr = |
1159 | dev_priv->gart_info.mapping.handle; | 1159 | dev_priv->gart_info.mapping.handle; |
1160 | 1160 | ||