1 /* SPDX-License-Identifier: GPL-2.0-only */ 1 /* SPDX-License-Identifier: GPL-2.0-only */ 2 /* 2 /* 3 * sched_clock.h: support for extending counte 3 * sched_clock.h: support for extending counters to full 64-bit ns counter 4 */ 4 */ 5 #ifndef LINUX_SCHED_CLOCK 5 #ifndef LINUX_SCHED_CLOCK 6 #define LINUX_SCHED_CLOCK 6 #define LINUX_SCHED_CLOCK 7 7 8 #include <linux/types.h> << 9 << 10 #ifdef CONFIG_GENERIC_SCHED_CLOCK 8 #ifdef CONFIG_GENERIC_SCHED_CLOCK 11 /** 9 /** 12 * struct clock_read_data - data required to r 10 * struct clock_read_data - data required to read from sched_clock() 13 * 11 * 14 * @epoch_ns: sched_clock() value at 12 * @epoch_ns: sched_clock() value at last update 15 * @epoch_cyc: Clock cycle value at l 13 * @epoch_cyc: Clock cycle value at last update. 16 * @sched_clock_mask: Bitmask for two's comp 14 * @sched_clock_mask: Bitmask for two's complement subtraction of non 64bit 17 * clocks. 15 * clocks. 18 * @read_sched_clock: Current clock source ( 16 * @read_sched_clock: Current clock source (or dummy source when suspended). 19 * @mult: Multiplier for scaled 17 * @mult: Multiplier for scaled math conversion. 20 * @shift: Shift value for scaled 18 * @shift: Shift value for scaled math conversion. 21 * 19 * 22 * Care must be taken when updating this struc 20 * Care must be taken when updating this structure; it is read by 23 * some very hot code paths. It occupies <=40 21 * some very hot code paths. It occupies <=40 bytes and, when combined 24 * with the seqcount used to synchronize acces 22 * with the seqcount used to synchronize access, comfortably fits into 25 * a 64 byte cache line. 23 * a 64 byte cache line. 26 */ 24 */ 27 struct clock_read_data { 25 struct clock_read_data { 28 u64 epoch_ns; 26 u64 epoch_ns; 29 u64 epoch_cyc; 27 u64 epoch_cyc; 30 u64 sched_clock_mask; 28 u64 sched_clock_mask; 31 u64 (*read_sched_clock)(void); 29 u64 (*read_sched_clock)(void); 32 u32 mult; 30 u32 mult; 33 u32 shift; 31 u32 shift; 34 }; 32 }; 35 33 36 extern struct clock_read_data *sched_clock_rea 34 extern struct clock_read_data *sched_clock_read_begin(unsigned int *seq); 37 extern int sched_clock_read_retry(unsigned int 35 extern int sched_clock_read_retry(unsigned int seq); 38 36 39 extern void generic_sched_clock_init(void); 37 extern void generic_sched_clock_init(void); 40 38 41 extern void sched_clock_register(u64 (*read)(v 39 extern void sched_clock_register(u64 (*read)(void), int bits, 42 unsigned long 40 unsigned long rate); 43 #else 41 #else 44 static inline void generic_sched_clock_init(vo 42 static inline void generic_sched_clock_init(void) { } 45 43 46 static inline void sched_clock_register(u64 (* 44 static inline void sched_clock_register(u64 (*read)(void), int bits, 47 unsign 45 unsigned long rate) 48 { 46 { 49 } 47 } 50 #endif 48 #endif 51 49 52 #endif 50 #endif 53 51
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.