aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mm/huge_memory.c35
1 files changed, 21 insertions, 14 deletions
diff --git a/mm/huge_memory.c b/mm/huge_memory.c
index 46e3f150a6ca..a94c07a1b3c5 100644
--- a/mm/huge_memory.c
+++ b/mm/huge_memory.c
@@ -154,8 +154,6 @@ static int start_khugepaged(void)
154 154
155 set_recommended_min_free_kbytes(); 155 set_recommended_min_free_kbytes();
156 } else if (khugepaged_thread) { 156 } else if (khugepaged_thread) {
157 /* wakeup to exit */
158 wake_up_interruptible(&khugepaged_wait);
159 kthread_stop(khugepaged_thread); 157 kthread_stop(khugepaged_thread);
160 khugepaged_thread = NULL; 158 khugepaged_thread = NULL;
161 } 159 }
@@ -2221,7 +2219,7 @@ static int khugepaged_has_work(void)
2221static int khugepaged_wait_event(void) 2219static int khugepaged_wait_event(void)
2222{ 2220{
2223 return !list_empty(&khugepaged_scan.mm_head) || 2221 return !list_empty(&khugepaged_scan.mm_head) ||
2224 !khugepaged_enabled(); 2222 kthread_should_stop();
2225} 2223}
2226 2224
2227static void khugepaged_do_scan(struct page **hpage) 2225static void khugepaged_do_scan(struct page **hpage)
@@ -2288,6 +2286,24 @@ static struct page *khugepaged_alloc_hugepage(void)
2288} 2286}
2289#endif 2287#endif
2290 2288
2289static void khugepaged_wait_work(void)
2290{
2291 try_to_freeze();
2292
2293 if (khugepaged_has_work()) {
2294 if (!khugepaged_scan_sleep_millisecs)
2295 return;
2296
2297 wait_event_freezable_timeout(khugepaged_wait,
2298 kthread_should_stop(),
2299 msecs_to_jiffies(khugepaged_scan_sleep_millisecs));
2300 return;
2301 }
2302
2303 if (khugepaged_enabled())
2304 wait_event_freezable(khugepaged_wait, khugepaged_wait_event());
2305}
2306
2291static void khugepaged_loop(void) 2307static void khugepaged_loop(void)
2292{ 2308{
2293 struct page *hpage; 2309 struct page *hpage;
@@ -2312,17 +2328,8 @@ static void khugepaged_loop(void)
2312 if (hpage) 2328 if (hpage)
2313 put_page(hpage); 2329 put_page(hpage);
2314#endif 2330#endif
2315 try_to_freeze(); 2331
2316 if (unlikely(kthread_should_stop())) 2332 khugepaged_wait_work();
2317 break;
2318 if (khugepaged_has_work()) {
2319 if (!khugepaged_scan_sleep_millisecs)
2320 continue;
2321 wait_event_freezable_timeout(khugepaged_wait, false,
2322 msecs_to_jiffies(khugepaged_scan_sleep_millisecs));
2323 } else if (khugepaged_enabled())
2324 wait_event_freezable(khugepaged_wait,
2325 khugepaged_wait_event());
2326 } 2333 }
2327} 2334}
2328 2335