hrtimer_cpu_baseRegular
4.4: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
seqcount_t seq;
struct hrtimer *running;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
bool migration_enabled;
bool nohz_active;
unsigned int in_hrtirq;
unsigned int hres_active;
unsigned int hang_detected;
ktime_t expires_next;
struct hrtimer *next_timer;
unsigned int nr_events;
unsigned int nr_retries;
unsigned int nr_hangs;
unsigned int max_hang_time;
struct hrtimer_clock_base clock_base[4];
};
4.8: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
seqcount_t seq;
struct hrtimer *running;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
bool migration_enabled;
bool nohz_active;
unsigned int in_hrtirq;
unsigned int hres_active;
unsigned int hang_detected;
ktime_t expires_next;
struct hrtimer *next_timer;
unsigned int nr_events;
unsigned int nr_retries;
unsigned int nr_hangs;
unsigned int max_hang_time;
struct hrtimer_clock_base clock_base[4];
};
4.10: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
seqcount_t seq;
struct hrtimer *running;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
bool migration_enabled;
bool nohz_active;
unsigned int in_hrtirq;
unsigned int hres_active;
unsigned int hang_detected;
ktime_t expires_next;
struct hrtimer *next_timer;
unsigned int nr_events;
unsigned int nr_retries;
unsigned int nr_hangs;
unsigned int max_hang_time;
struct hrtimer_clock_base clock_base[4];
};
4.13: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
seqcount_t seq;
struct hrtimer *running;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
bool migration_enabled;
bool nohz_active;
unsigned int in_hrtirq;
unsigned int hres_active;
unsigned int hang_detected;
ktime_t expires_next;
struct hrtimer *next_timer;
unsigned int nr_events;
unsigned int nr_retries;
unsigned int nr_hangs;
unsigned int max_hang_time;
struct hrtimer_clock_base clock_base[4];
};
4.15: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
seqcount_t seq;
struct hrtimer *running;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
bool migration_enabled;
bool nohz_active;
unsigned int in_hrtirq;
unsigned int hres_active;
unsigned int hang_detected;
ktime_t expires_next;
struct hrtimer *next_timer;
unsigned int nr_events;
unsigned int nr_retries;
unsigned int nr_hangs;
unsigned int max_hang_time;
struct hrtimer_clock_base clock_base[4];
};
4.18: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
5.0: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
5.3: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
5.4: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
5.8: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
5.11: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
5.13: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
5.15: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
5.19: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
6.2: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
6.5: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
6.8: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int online;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
arm64: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
armhf: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
ppc64el: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
riscv64: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
aws: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
azure: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
gcp: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
lowlatency: ✅struct hrtimer_cpu_base {
raw_spinlock_t lock;
unsigned int cpu;
unsigned int active_bases;
unsigned int clock_was_set_seq;
unsigned int hres_active;
unsigned int in_hrtirq;
unsigned int hang_detected;
unsigned int softirq_activated;
unsigned int nr_events;
short unsigned int nr_retries;
short unsigned int nr_hangs;
unsigned int max_hang_time;
ktime_t expires_next;
struct hrtimer *next_timer;
ktime_t softirq_expires_next;
struct hrtimer *softirq_next_timer;
struct hrtimer_clock_base clock_base[8];
};
Regular
4.4 and 4.8 ✅
4.8 and 4.10 ✅
4.10 and 4.13 ✅
4.13 and 4.15 ✅
4.15 and 4.18 ⚠️unsigned int softirq_activated
ktime_t softirq_expires_next
struct hrtimer *softirq_next_timer
seqcount_t seq
struct hrtimer *running
bool migration_enabled
bool nohz_active
unsigned int nr_retries ➡️ short unsigned int nr_retries
unsigned int nr_hangs ➡️ short unsigned int nr_hangs
struct hrtimer_clock_base clock_base[4] ➡️ struct hrtimer_clock_base clock_base[8]
4.18 and 5.0 ✅
5.0 and 5.3 ✅
5.3 and 5.4 ✅
5.4 and 5.8 ✅
5.8 and 5.11 ✅
5.11 and 5.13 ✅
5.13 and 5.15 ✅
5.15 and 5.19 ✅
5.19 and 6.2 ✅
6.2 and 6.5 ✅
6.5 and 6.8 ⚠️unsigned int online
amd64 and arm64 ✅
amd64 and armhf ✅
amd64 and ppc64el ✅
amd64 and riscv64 ✅
generic and aws ✅
generic and azure ✅
generic and gcp ✅
generic and lowlatency ✅