mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-02-12 23:22:21 +00:00
softirq: Consolidate common code in __tasklet_[hi]_schedule()
__tasklet_schedule() and __tasklet_hi_schedule() are almost identical. Move the common code from both function into __tasklet_schedule_common() and let both functions invoke it with different arguments. [ bigeasy: Splitted out from RT's "tasklet: Prevent tasklets from going into infinite spin in RT" and added commit message. Use this_cpu_ptr(headp) in __tasklet_schedule_common() as suggested by Julia Cartwright ] Signed-off-by: Ingo Molnar <mingo@kernel.org> Signed-off-by: Steven Rostedt <rostedt@goodmis.org> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de> Cc: Julia Cartwright <juliac@eso.teric.us> Link: https://lkml.kernel.org/r/20180227164808.10093-2-bigeasy@linutronix.de
This commit is contained in:
parent
f09777fa89
commit
6498ddad30
@ -460,29 +460,33 @@ struct tasklet_head {
|
|||||||
static DEFINE_PER_CPU(struct tasklet_head, tasklet_vec);
|
static DEFINE_PER_CPU(struct tasklet_head, tasklet_vec);
|
||||||
static DEFINE_PER_CPU(struct tasklet_head, tasklet_hi_vec);
|
static DEFINE_PER_CPU(struct tasklet_head, tasklet_hi_vec);
|
||||||
|
|
||||||
void __tasklet_schedule(struct tasklet_struct *t)
|
static void __tasklet_schedule_common(struct tasklet_struct *t,
|
||||||
|
struct tasklet_head __percpu *headp,
|
||||||
|
unsigned int softirq_nr)
|
||||||
{
|
{
|
||||||
|
struct tasklet_head *head;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
local_irq_save(flags);
|
local_irq_save(flags);
|
||||||
|
head = this_cpu_ptr(headp);
|
||||||
t->next = NULL;
|
t->next = NULL;
|
||||||
*__this_cpu_read(tasklet_vec.tail) = t;
|
*head->tail = t;
|
||||||
__this_cpu_write(tasklet_vec.tail, &(t->next));
|
head->tail = &(t->next);
|
||||||
raise_softirq_irqoff(TASKLET_SOFTIRQ);
|
raise_softirq_irqoff(softirq_nr);
|
||||||
local_irq_restore(flags);
|
local_irq_restore(flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void __tasklet_schedule(struct tasklet_struct *t)
|
||||||
|
{
|
||||||
|
__tasklet_schedule_common(t, &tasklet_vec,
|
||||||
|
TASKLET_SOFTIRQ);
|
||||||
|
}
|
||||||
EXPORT_SYMBOL(__tasklet_schedule);
|
EXPORT_SYMBOL(__tasklet_schedule);
|
||||||
|
|
||||||
void __tasklet_hi_schedule(struct tasklet_struct *t)
|
void __tasklet_hi_schedule(struct tasklet_struct *t)
|
||||||
{
|
{
|
||||||
unsigned long flags;
|
__tasklet_schedule_common(t, &tasklet_hi_vec,
|
||||||
|
HI_SOFTIRQ);
|
||||||
local_irq_save(flags);
|
|
||||||
t->next = NULL;
|
|
||||||
*__this_cpu_read(tasklet_hi_vec.tail) = t;
|
|
||||||
__this_cpu_write(tasklet_hi_vec.tail, &(t->next));
|
|
||||||
raise_softirq_irqoff(HI_SOFTIRQ);
|
|
||||||
local_irq_restore(flags);
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(__tasklet_hi_schedule);
|
EXPORT_SYMBOL(__tasklet_hi_schedule);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user