Commit 3d44cc3e01ee1b40317f79ed54324e25c4f848df
Committed by
Linus Torvalds
1 parent
ab65387243
Exists in
master
and in
7 other branches
Null pointer deref with hrtimer_try_to_cancel()
Impact: Prevent kernel crash with posix timer clockid CLOCK_MONOTONIC_RAW commit 2d42244ae71d6c7b0884b5664cf2eda30fb2ae68 (clocksource: introduce CLOCK_MONOTONIC_RAW) introduced a new clockid, which is only available to read out the raw not NTP adjusted system time. The above commit did not prevent that a posix timer can be created with that clockid. The timer_create() syscall succeeds and initializes the timer to a non existing hrtimer base. When the timer is deleted either by timer_delete() or by the exit() cleanup the kernel crashes. Prevent the creation of timers for CLOCK_MONOTONIC_RAW by setting the posix clock function to no_timer_create which returns an error code. Reported-and-tested-by: Eric Sesterhenn <snakebyte@gmx.de> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Acked-by: Oleg Nesterov <oleg@redhat.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Showing 1 changed file with 6 additions and 0 deletions Side-by-side Diff
kernel/posix-timers.c
... | ... | @@ -197,6 +197,11 @@ |
197 | 197 | return 0; |
198 | 198 | } |
199 | 199 | |
200 | +static int no_timer_create(struct k_itimer *new_timer) | |
201 | +{ | |
202 | + return -EOPNOTSUPP; | |
203 | +} | |
204 | + | |
200 | 205 | /* |
201 | 206 | * Return nonzero if we know a priori this clockid_t value is bogus. |
202 | 207 | */ |
... | ... | @@ -248,6 +253,7 @@ |
248 | 253 | .clock_getres = hrtimer_get_res, |
249 | 254 | .clock_get = posix_get_monotonic_raw, |
250 | 255 | .clock_set = do_posix_clock_nosettime, |
256 | + .timer_create = no_timer_create, | |
251 | 257 | }; |
252 | 258 | |
253 | 259 | register_posix_clock(CLOCK_REALTIME, &clock_realtime); |