mirror of
https://github.com/torvalds/linux.git
synced 2025-08-15 22:21:42 +02:00
hrtimers: Make callback function pointer private
Make the struct hrtimer::function field private, to prevent users from changing this field in an unsafe way. hrtimer_update_function() should be used if the callback function needs to be changed. Signed-off-by: Nam Cao <namcao@linutronix.de> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Ingo Molnar <mingo@kernel.org> Link: https://lore.kernel.org/all/7d0e6e0c5c59a64a9bea940051aac05d750bc0c2.1738746927.git.namcao@linutronix.de
This commit is contained in:
parent
87d82cff38
commit
04257da0c9
4 changed files with 8 additions and 8 deletions
|
@ -39,7 +39,7 @@ enum hrtimer_restart {
|
||||||
struct hrtimer {
|
struct hrtimer {
|
||||||
struct timerqueue_node node;
|
struct timerqueue_node node;
|
||||||
ktime_t _softexpires;
|
ktime_t _softexpires;
|
||||||
enum hrtimer_restart (*function)(struct hrtimer *);
|
enum hrtimer_restart (*__private function)(struct hrtimer *);
|
||||||
struct hrtimer_clock_base *base;
|
struct hrtimer_clock_base *base;
|
||||||
u8 state;
|
u8 state;
|
||||||
u8 is_rel;
|
u8 is_rel;
|
||||||
|
|
|
@ -235,7 +235,7 @@ TRACE_EVENT(hrtimer_start,
|
||||||
|
|
||||||
TP_fast_assign(
|
TP_fast_assign(
|
||||||
__entry->hrtimer = hrtimer;
|
__entry->hrtimer = hrtimer;
|
||||||
__entry->function = hrtimer->function;
|
__entry->function = ACCESS_PRIVATE(hrtimer, function);
|
||||||
__entry->expires = hrtimer_get_expires(hrtimer);
|
__entry->expires = hrtimer_get_expires(hrtimer);
|
||||||
__entry->softexpires = hrtimer_get_softexpires(hrtimer);
|
__entry->softexpires = hrtimer_get_softexpires(hrtimer);
|
||||||
__entry->mode = mode;
|
__entry->mode = mode;
|
||||||
|
@ -271,7 +271,7 @@ TRACE_EVENT(hrtimer_expire_entry,
|
||||||
TP_fast_assign(
|
TP_fast_assign(
|
||||||
__entry->hrtimer = hrtimer;
|
__entry->hrtimer = hrtimer;
|
||||||
__entry->now = *now;
|
__entry->now = *now;
|
||||||
__entry->function = hrtimer->function;
|
__entry->function = ACCESS_PRIVATE(hrtimer, function);
|
||||||
),
|
),
|
||||||
|
|
||||||
TP_printk("hrtimer=%p function=%ps now=%llu",
|
TP_printk("hrtimer=%p function=%ps now=%llu",
|
||||||
|
|
|
@ -1316,7 +1316,7 @@ void hrtimer_start_range_ns(struct hrtimer *timer, ktime_t tim,
|
||||||
struct hrtimer_clock_base *base;
|
struct hrtimer_clock_base *base;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
if (WARN_ON_ONCE(!timer->function))
|
if (WARN_ON_ONCE(!ACCESS_PRIVATE(timer, function)))
|
||||||
return;
|
return;
|
||||||
/*
|
/*
|
||||||
* Check whether the HRTIMER_MODE_SOFT bit and hrtimer.is_soft
|
* Check whether the HRTIMER_MODE_SOFT bit and hrtimer.is_soft
|
||||||
|
@ -1629,9 +1629,9 @@ static void __hrtimer_setup(struct hrtimer *timer,
|
||||||
timerqueue_init(&timer->node);
|
timerqueue_init(&timer->node);
|
||||||
|
|
||||||
if (WARN_ON_ONCE(!function))
|
if (WARN_ON_ONCE(!function))
|
||||||
timer->function = hrtimer_dummy_timeout;
|
ACCESS_PRIVATE(timer, function) = hrtimer_dummy_timeout;
|
||||||
else
|
else
|
||||||
timer->function = function;
|
ACCESS_PRIVATE(timer, function) = function;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1743,7 +1743,7 @@ static void __run_hrtimer(struct hrtimer_cpu_base *cpu_base,
|
||||||
raw_write_seqcount_barrier(&base->seq);
|
raw_write_seqcount_barrier(&base->seq);
|
||||||
|
|
||||||
__remove_hrtimer(timer, base, HRTIMER_STATE_INACTIVE, 0);
|
__remove_hrtimer(timer, base, HRTIMER_STATE_INACTIVE, 0);
|
||||||
fn = timer->function;
|
fn = ACCESS_PRIVATE(timer, function);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Clear the 'is relative' flag for the TIME_LOW_RES case. If the
|
* Clear the 'is relative' flag for the TIME_LOW_RES case. If the
|
||||||
|
|
|
@ -46,7 +46,7 @@ static void
|
||||||
print_timer(struct seq_file *m, struct hrtimer *taddr, struct hrtimer *timer,
|
print_timer(struct seq_file *m, struct hrtimer *taddr, struct hrtimer *timer,
|
||||||
int idx, u64 now)
|
int idx, u64 now)
|
||||||
{
|
{
|
||||||
SEQ_printf(m, " #%d: <%p>, %ps", idx, taddr, timer->function);
|
SEQ_printf(m, " #%d: <%p>, %ps", idx, taddr, ACCESS_PRIVATE(timer, function));
|
||||||
SEQ_printf(m, ", S:%02x", timer->state);
|
SEQ_printf(m, ", S:%02x", timer->state);
|
||||||
SEQ_printf(m, "\n");
|
SEQ_printf(m, "\n");
|
||||||
SEQ_printf(m, " # expires at %Lu-%Lu nsecs [in %Ld to %Ld nsecs]\n",
|
SEQ_printf(m, " # expires at %Lu-%Lu nsecs [in %Ld to %Ld nsecs]\n",
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue