aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu')
-rw-r--r--drivers/gpu/drm/drm_drv.c6
-rw-r--r--drivers/gpu/drm/drm_scatter.c10
2 files changed, 10 insertions, 6 deletions
diff --git a/drivers/gpu/drm/drm_drv.c b/drivers/gpu/drm/drm_drv.c
index dddd79988ffc..743b24d7918e 100644
--- a/drivers/gpu/drm/drm_drv.c
+++ b/drivers/gpu/drm/drm_drv.c
@@ -197,11 +197,7 @@ int drm_lastclose(struct drm_device * dev)
197 197
198 drm_agp_clear(dev); 198 drm_agp_clear(dev);
199 199
200 if (drm_core_check_feature(dev, DRIVER_SG) && dev->sg && 200 drm_legacy_sg_cleanup(dev);
201 !drm_core_check_feature(dev, DRIVER_MODESET)) {
202 drm_sg_cleanup(dev->sg);
203 dev->sg = NULL;
204 }
205 201
206 /* Clear vma list (only built for debugging) */ 202 /* Clear vma list (only built for debugging) */
207 list_for_each_entry_safe(vma, vma_temp, &dev->vmalist, head) { 203 list_for_each_entry_safe(vma, vma_temp, &dev->vmalist, head) {
diff --git a/drivers/gpu/drm/drm_scatter.c b/drivers/gpu/drm/drm_scatter.c
index a4a076ff1757..dd8a6480065c 100644
--- a/drivers/gpu/drm/drm_scatter.c
+++ b/drivers/gpu/drm/drm_scatter.c
@@ -46,7 +46,7 @@ static inline void *drm_vmalloc_dma(unsigned long size)
46#endif 46#endif
47} 47}
48 48
49void drm_sg_cleanup(struct drm_sg_mem * entry) 49static void drm_sg_cleanup(struct drm_sg_mem * entry)
50{ 50{
51 struct page *page; 51 struct page *page;
52 int i; 52 int i;
@@ -64,6 +64,14 @@ void drm_sg_cleanup(struct drm_sg_mem * entry)
64 kfree(entry); 64 kfree(entry);
65} 65}
66 66
67void drm_legacy_sg_cleanup(struct drm_device *dev)
68{
69 if (drm_core_check_feature(dev, DRIVER_SG) && dev->sg &&
70 !drm_core_check_feature(dev, DRIVER_MODESET)) {
71 drm_sg_cleanup(dev->sg);
72 dev->sg = NULL;
73 }
74}
67#ifdef _LP64 75#ifdef _LP64
68# define ScatterHandle(x) (unsigned int)((x >> 32) + (x & ((1L << 32) - 1))) 76# define ScatterHandle(x) (unsigned int)((x >> 32) + (x & ((1L << 32) - 1)))
69#else 77#else