Re: [PATCH v2] sched: pick_next_rt_entity(): checked list_entry

From: Steven Rostedt
Date: Mon Feb 06 2023 - 11:24:15 EST


On Tue, 31 Jan 2023 13:01:16 +0000
Pietro Borrello <borrello@xxxxxxxxxxxxxxxx> wrote:

> index ed2a47e4ddae..c024529d8416 100644
> --- a/kernel/sched/rt.c
> +++ b/kernel/sched/rt.c
> @@ -1777,6 +1777,7 @@ static struct sched_rt_entity *pick_next_rt_entity(struct rt_rq *rt_rq)
> BUG_ON(idx >= MAX_RT_PRIO);
>
> queue = array->queue + idx;
> + SCHED_WARN_ON(list_empty(queue));

I wonder if we should make this:

if (SCHED_WARN_ON(list_empty(queue)))
return NULL;

> next = list_entry(queue->next, struct sched_rt_entity, run_list);
>
> return next;
> @@ -1789,7 +1790,6 @@ static struct task_struct *_pick_next_task_rt(struct rq *rq)
>
> do {
> rt_se = pick_next_rt_entity(rt_rq);
> - BUG_ON(!rt_se);

if (unlikely(!rt_se))
return NULL;

-- Steve

> rt_rq = group_rt_rq(rt_se);
> } while (rt_rq);
>