]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commit
um: Simplify os_idle_sleep() and sleep longer
authorJohannes Berg <johannes.berg@intel.com>
Wed, 2 Dec 2020 19:58:04 +0000 (20:58 +0100)
committerRichard Weinberger <richard@nod.at>
Sun, 13 Dec 2020 21:22:37 +0000 (22:22 +0100)
commit49da38a3ef330b7a1643e12c51913d58158e5abe
tree80b644e00334100084a64bb455d03a68555b7c1c
parent3032b94587c78c52173a9b8488d15528481ffcdb
um: Simplify os_idle_sleep() and sleep longer

There really is no reason to pass the amount of time we should
sleep, especially since it's just hard-coded to one second.

Additionally, one second isn't really all that long, and as we
are expecting to be woken up by a signal, we can sleep longer
and avoid doing some work every second, so replace the current
clock_nanosleep() with just an empty select() that can _only_
be woken up by a signal.

We can also remove the deliver_alarm() since we don't need to
do that when we got e.g. SIGIO that woke us up, and if we got
SIGALRM the signal handler will actually (have) run, so it's
just unnecessary extra work.

Similarly, in time-travel mode, just program the wakeup event
from idle to be S64_MAX, which is basically the most you could
ever simulate to. Of course, you should already have an event
in the list that's earlier and will cause a wakeup, normally
that's the regular timer interrupt, though in suspend it may
(later) also be an RTC event. Since actually getting to this
point would be a bug and you can't ever get out again, panic()
on it in the time control code.

Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Acked-By: Anton Ivanov <anton.ivanov@cambridgegreys.com>
Signed-off-by: Richard Weinberger <richard@nod.at>
arch/um/include/linux/time-internal.h
arch/um/include/shared/os.h
arch/um/kernel/process.c
arch/um/kernel/time.c
arch/um/os-Linux/time.c