X-Git-Url: https://git.stricted.de/?p=GitHub%2Fmt8127%2Fandroid_kernel_alcatel_ttab.git;a=blobdiff_plain;f=kernel%2Fpower%2Fprocess.c;h=396777ddd6c6c77f5233fda5d5897f21c3f5ea41;hp=1b212bee1510cb22b6e1df1c2ba00fff6b6cf4e6;hb=6fa3eb70c07b7ce2061fd6602159ac2d45a7dc3d;hpb=a8d97b1bd0c91fbc1be54d068b5f051b4f70b4f7 diff --git a/kernel/power/process.c b/kernel/power/process.c index 1b212bee1510..396777ddd6c6 100644 --- a/kernel/power/process.c +++ b/kernel/power/process.c @@ -30,9 +30,10 @@ static int try_to_freeze_tasks(bool user_only) unsigned int todo; bool wq_busy = false; struct timeval start, end; - u64 elapsed_csecs64; - unsigned int elapsed_csecs; + u64 elapsed_msecs64; + unsigned int elapsed_msecs; bool wakeup = false; + int sleep_usecs = USEC_PER_MSEC; do_gettimeofday(&start); @@ -68,22 +69,25 @@ static int try_to_freeze_tasks(bool user_only) /* * We need to retry, but first give the freezing tasks some - * time to enter the refrigerator. + * time to enter the refrigerator. Start with an initial + * 1 ms sleep followed by exponential backoff until 8 ms. */ - msleep(10); + usleep_range(sleep_usecs / 2, sleep_usecs); + if (sleep_usecs < 8 * USEC_PER_MSEC) + sleep_usecs *= 2; } do_gettimeofday(&end); - elapsed_csecs64 = timeval_to_ns(&end) - timeval_to_ns(&start); - do_div(elapsed_csecs64, NSEC_PER_SEC / 100); - elapsed_csecs = elapsed_csecs64; + elapsed_msecs64 = timeval_to_ns(&end) - timeval_to_ns(&start); + do_div(elapsed_msecs64, NSEC_PER_MSEC); + elapsed_msecs = elapsed_msecs64; if (todo) { printk("\n"); - printk(KERN_ERR "Freezing of tasks %s after %d.%02d seconds " + printk(KERN_ERR "Freezing of tasks %s after %d.%03d seconds " "(%d tasks refusing to freeze, wq_busy=%d):\n", wakeup ? "aborted" : "failed", - elapsed_csecs / 100, elapsed_csecs % 100, + elapsed_msecs / 1000, elapsed_msecs % 1000, todo - wq_busy, wq_busy); if (!wakeup) { @@ -96,8 +100,8 @@ static int try_to_freeze_tasks(bool user_only) read_unlock(&tasklist_lock); } } else { - printk("(elapsed %d.%02d seconds) ", elapsed_csecs / 100, - elapsed_csecs % 100); + printk("(elapsed %d.%03d seconds) ", elapsed_msecs / 1000, + elapsed_msecs % 1000); } return todo ? -EBUSY : 0; @@ -134,6 +138,7 @@ int freeze_processes(void) thaw_processes(); return error; } +EXPORT_SYMBOL_GPL(freeze_processes); /** * freeze_kernel_threads - Make freezable kernel threads go to the refrigerator. @@ -160,6 +165,7 @@ int freeze_kernel_threads(void) thaw_kernel_threads(); return error; } +EXPORT_SYMBOL_GPL(freeze_kernel_threads); void thaw_processes(void) { @@ -179,6 +185,7 @@ void thaw_processes(void) read_lock(&tasklist_lock); do_each_thread(g, p) { + BUG_ON(!virt_addr_valid(next_task(g))); __thaw_task(p); } while_each_thread(g, p); read_unlock(&tasklist_lock); @@ -188,6 +195,7 @@ void thaw_processes(void) schedule(); printk("done.\n"); } +EXPORT_SYMBOL_GPL(thaw_processes); void thaw_kernel_threads(void) { @@ -208,3 +216,4 @@ void thaw_kernel_threads(void) schedule(); printk("done.\n"); } +EXPORT_SYMBOL_GPL(thaw_kernel_threads);