drm/selftests/mm: Insert cond_resched() between insert modes
authorChris Wilson <chris@chris-wilson.co.uk>
Tue, 7 Nov 2017 10:41:31 +0000 (10:41 +0000)
committerJoonas Lahtinen <joonas.lahtinen@linux.intel.com>
Tue, 7 Nov 2017 13:58:07 +0000 (15:58 +0200)
kbuilder has begun running the selftests and reported a soft-lockup
inside __igt_insert(), so break up the test loop over different modes
with another call to cond_resched().

Reported-by: Fengguang Wu <fengguang.wu@intel.com>
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Reviewed-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Signed-off-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20171107104131.5923-1-chris@chris-wilson.co.uk
drivers/gpu/drm/selftests/test-drm_mm.c

index 86eb4c185a28547589fb4b8a53433351a6738536..7cc935d7b7aaaa36c3767a9c4ae01685037cc1fa 100644 (file)
@@ -682,6 +682,8 @@ static int __igt_insert(unsigned int count, u64 size, bool replace)
                drm_mm_for_each_node_safe(node, next, &mm)
                        drm_mm_remove_node(node);
                DRM_MM_BUG_ON(!drm_mm_clean(&mm));
+
+               cond_resched();
        }
 
        ret = 0;
@@ -944,6 +946,8 @@ static int __igt_insert_range(unsigned int count, u64 size, u64 start, u64 end)
                drm_mm_for_each_node_safe(node, next, &mm)
                        drm_mm_remove_node(node);
                DRM_MM_BUG_ON(!drm_mm_clean(&mm));
+
+               cond_resched();
        }
 
        ret = 0;
@@ -1068,6 +1072,7 @@ static int igt_align(void *ignored)
                drm_mm_for_each_node_safe(node, next, &mm)
                        drm_mm_remove_node(node);
                DRM_MM_BUG_ON(!drm_mm_clean(&mm));
+
                cond_resched();
        }