Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Thomas Gleixner | bab0aae | 2017-05-30 23:15:41 +0200 | [diff] [blame] | 2 | #define TIMER_RETRY 1 |
| 3 | |
| 4 | struct k_clock { |
Thomas Gleixner | 3080294 | 2017-05-30 23:15:45 +0200 | [diff] [blame] | 5 | int (*clock_getres)(const clockid_t which_clock, |
| 6 | struct timespec64 *tp); |
| 7 | int (*clock_set)(const clockid_t which_clock, |
| 8 | const struct timespec64 *tp); |
Andrei Vagin | 9c71a2e | 2019-11-12 01:26:58 +0000 | [diff] [blame] | 9 | /* Returns the clock value in the current time namespace. */ |
Andrei Vagin | 819a95f | 2019-11-12 01:26:54 +0000 | [diff] [blame] | 10 | int (*clock_get_timespec)(const clockid_t which_clock, |
| 11 | struct timespec64 *tp); |
Andrei Vagin | 9c71a2e | 2019-11-12 01:26:58 +0000 | [diff] [blame] | 12 | /* Returns the clock value in the root time namespace. */ |
| 13 | ktime_t (*clock_get_ktime)(const clockid_t which_clock); |
Deepa Dinamani | ead2541 | 2018-07-02 22:44:21 -0700 | [diff] [blame] | 14 | int (*clock_adj)(const clockid_t which_clock, struct __kernel_timex *tx); |
Thomas Gleixner | 3080294 | 2017-05-30 23:15:45 +0200 | [diff] [blame] | 15 | int (*timer_create)(struct k_itimer *timer); |
| 16 | int (*nsleep)(const clockid_t which_clock, int flags, |
Thomas Gleixner | 938e7cf | 2017-06-13 23:34:33 +0200 | [diff] [blame] | 17 | const struct timespec64 *); |
Thomas Gleixner | 3080294 | 2017-05-30 23:15:45 +0200 | [diff] [blame] | 18 | int (*timer_set)(struct k_itimer *timr, int flags, |
| 19 | struct itimerspec64 *new_setting, |
| 20 | struct itimerspec64 *old_setting); |
| 21 | int (*timer_del)(struct k_itimer *timr); |
| 22 | void (*timer_get)(struct k_itimer *timr, |
| 23 | struct itimerspec64 *cur_setting); |
| 24 | void (*timer_rearm)(struct k_itimer *timr); |
Thomas Gleixner | 6fec64e | 2018-06-26 15:21:31 +0200 | [diff] [blame] | 25 | s64 (*timer_forward)(struct k_itimer *timr, ktime_t now); |
Thomas Gleixner | 63841b2 | 2017-05-30 23:15:49 +0200 | [diff] [blame] | 26 | ktime_t (*timer_remaining)(struct k_itimer *timr, ktime_t now); |
Thomas Gleixner | 525b8ed | 2017-05-30 23:15:52 +0200 | [diff] [blame] | 27 | int (*timer_try_to_cancel)(struct k_itimer *timr); |
| 28 | void (*timer_arm)(struct k_itimer *timr, ktime_t expires, |
| 29 | bool absolute, bool sigev_none); |
Thomas Gleixner | ec8f954 | 2019-08-02 07:35:59 +0200 | [diff] [blame] | 30 | void (*timer_wait_running)(struct k_itimer *timr); |
Thomas Gleixner | bab0aae | 2017-05-30 23:15:41 +0200 | [diff] [blame] | 31 | }; |
| 32 | |
| 33 | extern const struct k_clock clock_posix_cpu; |
| 34 | extern const struct k_clock clock_posix_dynamic; |
| 35 | extern const struct k_clock clock_process; |
| 36 | extern const struct k_clock clock_thread; |
| 37 | extern const struct k_clock alarm_clock; |
| 38 | |
| 39 | int posix_timer_event(struct k_itimer *timr, int si_private); |
Thomas Gleixner | f2c4580 | 2017-05-30 23:15:59 +0200 | [diff] [blame] | 40 | |
| 41 | void common_timer_get(struct k_itimer *timr, struct itimerspec64 *cur_setting); |
| 42 | int common_timer_set(struct k_itimer *timr, int flags, |
| 43 | struct itimerspec64 *new_setting, |
| 44 | struct itimerspec64 *old_setting); |
| 45 | int common_timer_del(struct k_itimer *timer); |