On Sun, 11 Dec 2022, Tejun Heo wrote: > Hello, Julia. > > On Sun, Dec 11, 2022 at 11:33:50PM +0100, Julia Lawall wrote: > > > diff --git a/kernel/sched/ext.c b/kernel/sched/ext.c > > > new file mode 100644 > > > index 000000000000..f42464d66de4 > > > --- /dev/null > > > +++ b/kernel/sched/ext.c > > > @@ -0,0 +1,2780 @@ > > > +/* SPDX-License-Identifier: GPL-2.0 */ > > > +/* > > > + * Copyright (c) 2022 Meta Platforms, Inc. and affiliates. > > > + * Copyright (c) 2022 Tejun Heo <tj@xxxxxxxxxx> > > > + * Copyright (c) 2022 David Vernet <dvernet@xxxxxxxx> > > > + */ > > > +#define SCX_OP_IDX(op) (offsetof(struct sched_ext_ops, op) / sizeof(void (*)(void))) > > > + > > > +enum scx_internal_consts { > > > + SCX_NR_ONLINE_OPS = SCX_OP_IDX(init), > > > + SCX_DSP_DFL_MAX_BATCH = 32, > > > > This definition of SCX_DSP_DFL_MAX_BATCH makes the dispatch queue have size > > 32. The example central policy thus aborts if more than 32 tasks are woken > > up at once. > > Yeah, scx_exampl_central needs to either set ops.dispatch_max_batch higher > according to number of CPUs or flush and exit the loop and retry when > scx_bpf_dispatch_nr_slots() reaches zero. Will update. Since there could be any number of waking threads, maybe some kind of flush and retry solution would be better? julia > > Thanks. > > -- > tejun >