mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-07 13:43:51 +00:00
Misc timer fixes:
- fix a potential use-after-free bug in posix timers - correct a prototype - address a build warning Signed-off-by: Ingo Molnar <mingo@kernel.org> -----BEGIN PGP SIGNATURE----- iQJFBAABCgAvFiEEBpT5eoXrXCwVQwEKEnMQ0APhK1gFAmL3epQRHG1pbmdvQGtl cm5lbC5vcmcACgkQEnMQ0APhK1iPZw/+I/9GXcf3SzbG5M6Nf21SJpSjC4hAHHgb eyv5MUNxKvCHU5iT2SrCvgKjESl5I/E70kubeRHJnvarBPUzGnHHzGlYIYOaJPQ7 irJpUj/6R8ps4UsMBJ8vj5f3b7163zhBJVP8egDW6roT1HUrYTFeIjIli/SOCxpY H1/DqHlbEALE5o5xykg3zuqAbywym+hNRleIVls4wqjZNnfqiTElSuW9xqw9xt3n 9xYmOKZaztdv5Lp2JCm7QOu2byGzeHje72ppsDcBZ3EBvHUBLSndhfe5NQUGhtxy UlBqAELA653uPgPnNKLRMqt/kop8emHqvAx8T0RawPwoUS6XGDVxRX+my8+HKklg P8KsM/8W7+3KTHz0bf72DEHTFiXCzlswRzdOSvP5bR4xw1G4ychzvuxAiPDFR3zT v7uPgykxxCrEexVCBCdPmrl4WikwLJtcrSXtJ4bsisxQFlq7WWd2/osZkTffI3pN IIxDXuHFHC78lrUMk2OQ+ITBz01z4nCFSlgMGZ6ZY6ppS1Rndy1HG/B2NgjW1zGP Y/1xq/nWaql0QO7RmyoJXt1ZSMJYCyKFocRDh9nBmtBSlYm3A8aIA8b4i1VRRG1G 8HOkdS8ef2eOWj8wqk0NvoTbiGjV7YM5pf0g1dmRLA+aGCBD1P9/iFcBv5b6Uxaq qZ7ZtuQzsyc= =Plg8 -----END PGP SIGNATURE----- Merge tag 'timers-urgent-2022-08-13' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip Pull timer fixes from Ingo Molnar: "Misc timer fixes: - fix a potential use-after-free bug in posix timers - correct a prototype - address a build warning" * tag 'timers-urgent-2022-08-13' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: posix-cpu-timers: Cleanup CPU timers before freeing them during exec time: Correct the prototype of ns_to_kernel_old_timeval and ns_to_timespec64 posix-timers: Make do_clock_gettime() static
This commit is contained in:
commit
f6eb0fed6a
@ -1304,6 +1304,9 @@ int begin_new_exec(struct linux_binprm * bprm)
|
|||||||
bprm->mm = NULL;
|
bprm->mm = NULL;
|
||||||
|
|
||||||
#ifdef CONFIG_POSIX_TIMERS
|
#ifdef CONFIG_POSIX_TIMERS
|
||||||
|
spin_lock_irq(&me->sighand->siglock);
|
||||||
|
posix_cpu_timers_exit(me);
|
||||||
|
spin_unlock_irq(&me->sighand->siglock);
|
||||||
exit_itimers(me);
|
exit_itimers(me);
|
||||||
flush_itimer_signals();
|
flush_itimer_signals();
|
||||||
#endif
|
#endif
|
||||||
|
@ -145,7 +145,7 @@ static inline s64 timespec64_to_ns(const struct timespec64 *ts)
|
|||||||
*
|
*
|
||||||
* Returns the timespec64 representation of the nsec parameter.
|
* Returns the timespec64 representation of the nsec parameter.
|
||||||
*/
|
*/
|
||||||
extern struct timespec64 ns_to_timespec64(const s64 nsec);
|
extern struct timespec64 ns_to_timespec64(s64 nsec);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* timespec64_add_ns - Adds nanoseconds to a timespec64
|
* timespec64_add_ns - Adds nanoseconds to a timespec64
|
||||||
|
@ -70,7 +70,7 @@ SYSCALL_DEFINE2(clock_settime, const clockid_t, which_clock,
|
|||||||
return do_sys_settimeofday64(&new_tp, NULL);
|
return do_sys_settimeofday64(&new_tp, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_clock_gettime(clockid_t which_clock, struct timespec64 *tp)
|
static int do_clock_gettime(clockid_t which_clock, struct timespec64 *tp)
|
||||||
{
|
{
|
||||||
switch (which_clock) {
|
switch (which_clock) {
|
||||||
case CLOCK_REALTIME:
|
case CLOCK_REALTIME:
|
||||||
@ -90,6 +90,7 @@ int do_clock_gettime(clockid_t which_clock, struct timespec64 *tp)
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
SYSCALL_DEFINE2(clock_gettime, const clockid_t, which_clock,
|
SYSCALL_DEFINE2(clock_gettime, const clockid_t, which_clock,
|
||||||
struct __kernel_timespec __user *, tp)
|
struct __kernel_timespec __user *, tp)
|
||||||
{
|
{
|
||||||
|
@ -449,7 +449,7 @@ time64_t mktime64(const unsigned int year0, const unsigned int mon0,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(mktime64);
|
EXPORT_SYMBOL(mktime64);
|
||||||
|
|
||||||
struct __kernel_old_timeval ns_to_kernel_old_timeval(const s64 nsec)
|
struct __kernel_old_timeval ns_to_kernel_old_timeval(s64 nsec)
|
||||||
{
|
{
|
||||||
struct timespec64 ts = ns_to_timespec64(nsec);
|
struct timespec64 ts = ns_to_timespec64(nsec);
|
||||||
struct __kernel_old_timeval tv;
|
struct __kernel_old_timeval tv;
|
||||||
@ -503,7 +503,7 @@ EXPORT_SYMBOL(set_normalized_timespec64);
|
|||||||
*
|
*
|
||||||
* Returns the timespec64 representation of the nsec parameter.
|
* Returns the timespec64 representation of the nsec parameter.
|
||||||
*/
|
*/
|
||||||
struct timespec64 ns_to_timespec64(const s64 nsec)
|
struct timespec64 ns_to_timespec64(s64 nsec)
|
||||||
{
|
{
|
||||||
struct timespec64 ts = { 0, 0 };
|
struct timespec64 ts = { 0, 0 };
|
||||||
s32 rem;
|
s32 rem;
|
||||||
|
Loading…
Reference in New Issue
Block a user