On Monday, December 9th, 2024 at 7:29 AM, David Vernet <void@xxxxxxxxxxxxx> wrote: > > > maximal.bpf.c is still dispatching to and consuming from SCX_DSQ_GLOBAL. > Let's have it use its own DSQ to avoid any runtime errors. > > Signed-off-by: David Vernet void@xxxxxxxxxxxxx > > --- > tools/testing/selftests/sched_ext/maximal.bpf.c | 8 +++++--- > 1 file changed, 5 insertions(+), 3 deletions(-) Hi David, thanks for looking into the test failures. I ran BPF CI on kernel with this change on top of bpf-next (6e8ba494d87d) + tests build fix [1]. I ran the workflow twice. A second run on aarch64 failed: https://github.com/kernel-patches/vmtest/actions/runs/12263276418/job/34217056880 Failed tests are "dsp_local_on" and "exit". The difference in comparison to a successful run is a deadlock, which happens on attempt to attach a scheduler, assuming I read the log correctly. See a paste below. I'd like to note that the selftests/sched_ext/runner log is very verbose (~23M), although I can't tell how necessary this is for debugging. [1] https://lore.kernel.org/bpf/20241121214014.3346203-1-ihor.solodrai@xxxxx/ 2024-12-10T20:20:55.6921607Z ##[group]selftests/sched_ext - Executing selftests/sched_ext/runner 2024-12-10T20:20:55.7556144Z 2024-12-10T20:20:55.7558626Z ================================ 2024-12-10T20:20:55.7560796Z WARNING: inconsistent lock state 2024-12-10T20:20:55.7564132Z 6.13.0-rc2-gb23d77932777-dirty #1 Not tainted 2024-12-10T20:20:55.7566359Z -------------------------------- 2024-12-10T20:20:55.7570239Z inconsistent {IN-HARDIRQ-W} -> {HARDIRQ-ON-W} usage. 2024-12-10T20:20:55.7573094Z runner/96 [HC0[0]:SC0[0]:HE1:SE1] takes: 2024-12-10T20:20:55.7579001Z ffff0000fb5f4858 (&rq->__lock){?.-.}-{2:2}, at: raw_spin_rq_lock_nested+0x2c/0x50 2024-12-10T20:20:55.7581586Z {IN-HARDIRQ-W} state was registered at: 2024-12-10T20:20:55.7583722Z __lock_acquire+0x3c0/0xb18 2024-12-10T20:20:55.7586124Z lock_acquire.part.0+0xe0/0x250 2024-12-10T20:20:55.7588061Z lock_acquire+0x88/0x160 2024-12-10T20:20:55.7590605Z _raw_spin_lock_nested+0x5c/0xb0 2024-12-10T20:20:55.7592640Z try_to_wake_up+0x244/0x560 2024-12-10T20:20:55.7594719Z wake_up_process+0x20/0x38 2024-12-10T20:20:55.7596673Z hrtimer_wakeup+0x28/0x48 2024-12-10T20:20:55.7598757Z __run_hrtimer+0x32c/0x3a0 2024-12-10T20:20:55.7601330Z __hrtimer_run_queues+0xb4/0x140 2024-12-10T20:20:55.7603618Z hrtimer_run_queues+0xe4/0x1d8 2024-12-10T20:20:55.7606009Z update_process_times+0x3c/0x160 2024-12-10T20:20:55.7607957Z tick_periodic+0x44/0x140 2024-12-10T20:20:55.7610565Z tick_handle_periodic+0x34/0xa8 2024-12-10T20:20:55.7613159Z arch_timer_handler_virt+0x34/0x58 2024-12-10T20:20:55.7615811Z handle_percpu_devid_irq+0xb0/0x2a0 2024-12-10T20:20:55.7618562Z generic_handle_domain_irq+0x34/0x58 2024-12-10T20:20:55.7620462Z gic_handle_irq+0x5c/0xd8 2024-12-10T20:20:55.7622667Z call_on_irq_stack+0x24/0x58 2024-12-10T20:20:55.7625060Z do_interrupt_handler+0x88/0x98 2024-12-10T20:20:55.7626970Z el1_interrupt+0x34/0x50 2024-12-10T20:20:55.7629327Z el1h_64_irq_handler+0x18/0x28 2024-12-10T20:20:55.7631094Z el1h_64_irq+0x6c/0x70 2024-12-10T20:20:55.7633416Z default_idle_call+0xac/0x254 2024-12-10T20:20:55.7635665Z default_idle_call+0xa8/0x254 2024-12-10T20:20:55.7637184Z do_idle+0xc4/0x118 2024-12-10T20:20:55.7639486Z cpu_startup_entry+0x3c/0x50 2024-12-10T20:20:55.7641200Z rest_init+0x118/0x1a8 2024-12-10T20:20:55.7643382Z start_kernel+0x59c/0x678 2024-12-10T20:20:55.7645786Z __primary_switched+0x88/0x98 2024-12-10T20:20:55.7647582Z irq event stamp: 33739 2024-12-10T20:20:55.7653885Z hardirqs last enabled at (33739): [<ffff8000800b699c>] scx_ops_bypass+0x174/0x3b8 2024-12-10T20:20:55.7660311Z hardirqs last disabled at (33738): [<ffff800080d48ad4>] _raw_spin_lock_irqsave+0xb4/0xd8 2024-12-10T20:20:55.7666393Z softirqs last enabled at (32824): [<ffff800080056a34>] handle_softirqs+0x46c/0x490 2024-12-10T20:20:55.7672087Z softirqs last disabled at (32815): [<ffff8000800101bc>] __do_softirq+0x1c/0x28 2024-12-10T20:20:55.7672575Z 2024-12-10T20:20:55.7675191Z other info that might help us debug this: 2024-12-10T20:20:55.7678564Z Possible unsafe locking scenario: 2024-12-10T20:20:55.7678867Z 2024-12-10T20:20:55.7680124Z CPU0 2024-12-10T20:20:55.7680709Z ---- 2024-12-10T20:20:55.7682424Z lock(&rq->__lock); 2024-12-10T20:20:55.7683722Z <Interrupt> 2024-12-10T20:20:55.7685546Z lock(&rq->__lock); 2024-12-10T20:20:55.7685788Z 2024-12-10T20:20:55.7687156Z *** DEADLOCK *** 2024-12-10T20:20:55.7687380Z 2024-12-10T20:20:55.7689485Z 3 locks held by runner/96: 2024-12-10T20:20:55.7696730Z #0: ffff8000821226f8 (update_mutex){+.+.}-{4:4}, at: bpf_struct_ops_link_create+0x13c/0x1b0 2024-12-10T20:20:55.7703773Z #1: ffff80008207e7f0 (scx_ops_enable_mutex){+.+.}-{4:4}, at: scx_ops_enable.isra.0+0x88/0xaa8 2024-12-10T20:20:55.7709594Z #2: ffff80008207e060 (bypass_lock){+.+.}-{2:2}, at: scx_ops_bypass+0x50/0x3b8 2024-12-10T20:20:55.7710078Z 2024-12-10T20:20:55.7710895Z stack backtrace: 2024-12-10T20:20:55.7717184Z CPU: 1 UID: 0 PID: 96 Comm: runner Not tainted 6.13.0-rc2-gb23d77932777-dirty #1 2024-12-10T20:20:55.7719782Z Hardware name: linux,dummy-virt (DT) 2024-12-10T20:20:55.7722429Z Sched_ext: create_dsq (enabling) 2024-12-10T20:20:55.7723286Z Call trace: 2024-12-10T20:20:55.7725440Z show_stack+0x20/0x38 (C) 2024-12-10T20:20:55.7727531Z dump_stack_lvl+0xa0/0xf0 2024-12-10T20:20:55.7729283Z dump_stack+0x18/0x28 2024-12-10T20:20:55.7732218Z print_usage_bug.part.0+0x270/0x320 2024-12-10T20:20:55.7734277Z mark_lock_irq+0x3e0/0x538 2024-12-10T20:20:55.7736126Z mark_lock+0x1c0/0x290 2024-12-10T20:20:55.7738113Z mark_usage+0x108/0x170 2024-12-10T20:20:55.7740306Z __lock_acquire+0x3c0/0xb18 2024-12-10T20:20:55.7742923Z lock_acquire.part.0+0xe0/0x250 2024-12-10T20:20:55.7744782Z lock_acquire+0x88/0x160 2024-12-10T20:20:55.7747510Z _raw_spin_lock_nested+0x5c/0xb0 2024-12-10T20:20:55.7750224Z raw_spin_rq_lock_nested+0x2c/0x50 2024-12-10T20:20:55.7752314Z scx_ops_bypass+0xfc/0x3b8 2024-12-10T20:20:55.7755093Z scx_ops_enable.isra.0+0x2c8/0xaa8 2024-12-10T20:20:55.7756819Z bpf_scx_reg+0x18/0x30 2024-12-10T20:20:55.7760072Z bpf_struct_ops_link_create+0x154/0x1b0 2024-12-10T20:20:55.7762017Z link_create+0x14c/0x350 2024-12-10T20:20:55.7763821Z __sys_bpf+0x3fc/0xb90 2024-12-10T20:20:55.7765976Z __arm64_sys_bpf+0x2c/0x48 2024-12-10T20:20:55.7768134Z invoke_syscall+0x50/0x120 2024-12-10T20:20:55.7771191Z el0_svc_common.constprop.0+0x48/0xf0 2024-12-10T20:20:55.7772796Z do_el0_svc+0x24/0x38 2024-12-10T20:20:55.7774452Z el0_svc+0x48/0x110 2024-12-10T20:20:55.7777321Z el0t_64_sync_handler+0x10c/0x138 2024-12-10T20:20:55.7779253Z el0t_64_sync+0x198/0x1a0 2024-12-10T20:20:55.7782673Z ------------[ cut here ]------------ 2024-12-10T20:20:55.7786247Z raw_local_irq_restore() called with IRQs enabled 2024-12-10T20:20:55.7792987Z WARNING: CPU: 1 PID: 96 at kernel/locking/irqflag-debug.c:10 warn_bogus_irq_restore+0x30/0x40 2024-12-10T20:20:55.7794104Z Modules linked in: 2024-12-10T20:20:55.7799949Z CPU: 1 UID: 0 PID: 96 Comm: runner Not tainted 6.13.0-rc2-gb23d77932777-dirty #1 2024-12-10T20:20:55.7802378Z Hardware name: linux,dummy-virt (DT) 2024-12-10T20:20:55.7804767Z Sched_ext: create_dsq (enabling) 2024-12-10T20:20:55.7809450Z pstate: 60400005 (nZCv daif +PAN -UAO -TCO -DIT -SSBS BTYPE=--) 2024-12-10T20:20:55.7812011Z pc : warn_bogus_irq_restore+0x30/0x40 2024-12-10T20:20:55.7814814Z lr : warn_bogus_irq_restore+0x30/0x40 2024-12-10T20:20:55.7816303Z sp : ffff800084d53a50 2024-12-10T20:20:55.7821165Z x29: ffff800084d53a50 x28: ffff0000c0960000 x27: ffff80008205d078 2024-12-10T20:20:55.7825770Z x26: ffff800081cf6840 x25: ffff800082059350 x24: ffff800082256958 2024-12-10T20:20:55.7830346Z x23: 0000000000000000 x22: ffff0000fb5f4858 x21: ffff80008207d6b8 2024-12-10T20:20:55.7834929Z x20: 0000000000000001 x19: ffff0000fb5f4840 x18: 00000000fffffffd 2024-12-10T20:20:55.7839534Z x17: 3764333262672d32 x16: 63722d302e33312e x15: ffff800084d52c90 2024-12-10T20:20:55.7844210Z x14: 0000000000000000 x13: 64656c62616e6520 x12: 7351524920687469 2024-12-10T20:20:55.7849054Z x11: 772064656c6c6163 x10: ffff8000820da8b0 x9 : ffff800080101b00 2024-12-10T20:20:55.7854102Z x8 : 00000000ffffefff x7 : ffff8000820da8b0 x6 : 80000000fffff000 2024-12-10T20:20:55.7858669Z x5 : 000000000000017f x4 : 0000000000000000 x3 : 0000000000000000 2024-12-10T20:20:55.7863487Z x2 : 0000000000000000 x1 : 0000000000000000 x0 : ffff0000c0960000 2024-12-10T20:20:55.7864284Z Call trace: 2024-12-10T20:20:55.7867341Z warn_bogus_irq_restore+0x30/0x40 (P) 2024-12-10T20:20:55.7870193Z warn_bogus_irq_restore+0x30/0x40 (L) 2024-12-10T20:20:55.7872308Z scx_ops_bypass+0x224/0x3b8 2024-12-10T20:20:55.7875067Z scx_ops_enable.isra.0+0x2c8/0xaa8 2024-12-10T20:20:55.7876915Z bpf_scx_reg+0x18/0x30 2024-12-10T20:20:55.7880088Z bpf_struct_ops_link_create+0x154/0x1b0 2024-12-10T20:20:55.7881875Z link_create+0x14c/0x350 2024-12-10T20:20:55.7883755Z __sys_bpf+0x3fc/0xb90 2024-12-10T20:20:55.7885864Z __arm64_sys_bpf+0x2c/0x48 2024-12-10T20:20:55.7887978Z invoke_syscall+0x50/0x120 2024-12-10T20:20:55.7890961Z el0_svc_common.constprop.0+0x48/0xf0 2024-12-10T20:20:55.7892546Z do_el0_svc+0x24/0x38 2024-12-10T20:20:55.7894224Z el0_svc+0x48/0x110 2024-12-10T20:20:55.7896940Z el0t_64_sync_handler+0x10c/0x138 2024-12-10T20:20:55.7898846Z el0t_64_sync+0x198/0x1a0 2024-12-10T20:20:55.7900627Z irq event stamp: 33739 2024-12-10T20:20:55.7906972Z hardirqs last enabled at (33739): [<ffff8000800b699c>] scx_ops_bypass+0x174/0x3b8 2024-12-10T20:20:55.7913438Z hardirqs last disabled at (33738): [<ffff800080d48ad4>] _raw_spin_lock_irqsave+0xb4/0xd8 2024-12-10T20:20:55.7919488Z softirqs last enabled at (32824): [<ffff800080056a34>] handle_softirqs+0x46c/0x490 2024-12-10T20:20:55.7925161Z softirqs last disabled at (32815): [<ffff8000800101bc>] __do_softirq+0x1c/0x28 2024-12-10T20:20:55.7927698Z ---[ end trace 0000000000000000 ]--- 2024-12-10T20:20:55.8646931Z sched_ext: BPF scheduler "create_dsq" enabled 2024-12-10T20:20:55.9047921Z sched_ext: BPF scheduler "create_dsq" disabled (unregistered from user space) 2024-12-10T20:20:55.9647423Z sched_ext: BPF scheduler "enq_last_no_enq_fails" disabled (runtime error) 2024-12-10T20:20:55.9653845Z sched_ext: enq_last_no_enq_fails: SCX_OPS_ENQ_LAST requires ops.enqueue() to be implemented 2024-12-10T20:20:55.9656238Z scx_ops_enable.isra.0+0xa98/0xaa8 2024-12-10T20:20:55.9658038Z bpf_scx_reg+0x18/0x30 2024-12-10T20:20:55.9661235Z bpf_struct_ops_link_create+0x154/0x1b0 2024-12-10T20:20:55.9663113Z link_create+0x14c/0x350 2024-12-10T20:20:55.9664999Z __sys_bpf+0x3fc/0xb90 2024-12-10T20:20:55.9667216Z __arm64_sys_bpf+0x2c/0x48 2024-12-10T20:20:55.9669376Z invoke_syscall+0x50/0x120 2024-12-10T20:20:55.9672393Z el0_svc_common.constprop.0+0x48/0xf0 2024-12-10T20:20:55.9674125Z do_el0_svc+0x24/0x38 2024-12-10T20:20:55.9675781Z el0_svc+0x48/0x110 2024-12-10T20:20:55.9678659Z el0t_64_sync_handler+0x10c/0x138 2024-12-10T20:20:55.9680560Z el0t_64_sync+0x198/0x1a0 2024-12-10T20:20:55.9864103Z sched_ext: BPF scheduler "enq_select_cpu_fails" enabled 2024-12-10T20:20:56.0347550Z sched_ext: BPF scheduler "enq_select_cpu_fails" disabled (runtime error) 2024-12-10T20:20:56.0354154Z sched_ext: enq_select_cpu_fails: kfunc with mask 0x8 called from an operation only allowing 0x4 2024-12-10T20:20:56.0356414Z scx_bpf_select_cpu_dfl+0x8c/0x98 2024-12-10T20:20:56.0361395Z bpf_prog_b68dda6ca71e9089_enq_select_cpu_fails_enqueue+0x54/0xb0 2024-12-10T20:20:56.0364138Z bpf__sched_ext_ops_enqueue+0x50/0x74 2024-12-10T20:20:56.0366225Z do_enqueue_task+0xf8/0x240 2024-12-10T20:20:56.0368567Z enqueue_task_scx+0x190/0x288 2024-12-10T20:20:56.0370532Z enqueue_task+0x44/0xe8 2024-12-10T20:20:56.0372845Z ttwu_do_activate+0x88/0x298 2024-12-10T20:20:56.0375059Z try_to_wake_up+0x2b8/0x560 2024-12-10T20:20:56.0377269Z wake_up_process+0x20/0x38 2024-12-10T20:20:56.0379030Z kick_pool+0xa4/0x190 2024-12-10T20:20:56.0381198Z __queue_work+0x540/0x600 2024-12-10T20:20:56.0383276Z queue_work_on+0xb8/0x100 2024-12-10T20:20:56.0385314Z bpf_prog_free+0x90/0xa8 2024-12-10T20:20:56.0387681Z __bpf_prog_put_rcu+0x44/0x60 2024-12-10T20:20:56.0389757Z rcu_do_batch+0x1e8/0xa90 2024-12-10T20:20:56.0391541Z rcu_core+0x174/0x378 2024-12-10T20:20:56.0393744Z rcu_core_si+0x18/0x30 2024-12-10T20:20:56.0395820Z handle_softirqs+0x12c/0x490 2024-12-10T20:20:56.0397644Z __do_softirq+0x1c/0x28 2024-12-10T20:20:56.0399798Z ____do_softirq+0x18/0x30 2024-12-10T20:20:56.0402104Z call_on_irq_stack+0x24/0x58 2024-12-10T20:20:56.0404662Z do_softirq_own_stack+0x24/0x38 2024-12-10T20:20:56.0406780Z __irq_exit_rcu+0x140/0x180 2024-12-10T20:20:56.0408766Z irq_exit_rcu+0x18/0x48 2024-12-10T20:20:56.0410801Z el1_interrupt+0x38/0x50 2024-12-10T20:20:56.0413210Z el1h_64_irq_handler+0x18/0x28 2024-12-10T20:20:56.0415052Z el1h_64_irq+0x6c/0x70 2024-12-10T20:20:56.0417472Z default_idle_call+0xac/0x254 2024-12-10T20:20:56.0419830Z default_idle_call+0xa8/0x254 2024-12-10T20:20:56.0421507Z do_idle+0xc4/0x118 2024-12-10T20:20:56.0423811Z cpu_startup_entry+0x3c/0x50 2024-12-10T20:20:56.0426578Z secondary_start_kernel+0xdc/0x108 2024-12-10T20:20:56.0428987Z __secondary_switched+0xc0/0xc8 2024-12-10T20:20:57.1047514Z sched_ext: BPF scheduler "ddsp_bogus_dsq_fail" enabled 2024-12-10T20:20:57.1647261Z sched_ext: BPF scheduler "ddsp_bogus_dsq_fail" disabled (runtime error) 2024-12-10T20:20:57.1652666Z sched_ext: ddsp_bogus_dsq_fail: non-existent DSQ 0xcafef00d for rcu_sched[16] 2024-12-10T20:20:57.1655003Z find_dsq_for_dispatch+0xf4/0x158 2024-12-10T20:20:57.1657196Z direct_dispatch+0x58/0x228 2024-12-10T20:20:57.1659464Z do_enqueue_task+0x17c/0x240 2024-12-10T20:20:57.1661801Z enqueue_task_scx+0x190/0x288 2024-12-10T20:20:57.1663937Z enqueue_task+0x44/0xe8 2024-12-10T20:20:57.1666068Z ttwu_do_activate+0x88/0x298 2024-12-10T20:20:57.1668231Z try_to_wake_up+0x2b8/0x560 2024-12-10T20:20:57.1670117Z swake_up_one+0x4c/0x98 2024-12-10T20:20:57.1672701Z swake_up_one_online+0x54/0xc0 2024-12-10T20:20:57.1674986Z rcu_gp_kthread_wake+0x68/0x98 2024-12-10T20:20:57.1678136Z rcu_accelerate_cbs_unlocked+0xf0/0x128 2024-12-10T20:20:57.1679813Z rcu_core+0x350/0x378 2024-12-10T20:20:57.1681646Z rcu_core_si+0x18/0x30 2024-12-10T20:20:57.1683953Z handle_softirqs+0x12c/0x490 2024-12-10T20:20:57.1685841Z __do_softirq+0x1c/0x28 2024-12-10T20:20:57.1687901Z ____do_softirq+0x18/0x30 2024-12-10T20:20:57.1690172Z call_on_irq_stack+0x24/0x58 2024-12-10T20:20:57.1692602Z do_softirq_own_stack+0x24/0x38 2024-12-10T20:20:57.1694778Z __irq_exit_rcu+0x140/0x180 2024-12-10T20:20:57.1696640Z irq_exit_rcu+0x18/0x48 2024-12-10T20:20:57.1698672Z el1_interrupt+0x38/0x50 2024-12-10T20:20:57.1701082Z el1h_64_irq_handler+0x18/0x28 2024-12-10T20:20:57.1702858Z el1h_64_irq+0x6c/0x70 2024-12-10T20:20:57.1705280Z default_idle_call+0xac/0x254 2024-12-10T20:20:57.1707600Z default_idle_call+0xa8/0x254 2024-12-10T20:20:57.1709171Z do_idle+0xc4/0x118 2024-12-10T20:20:57.1711481Z cpu_startup_entry+0x40/0x50 2024-12-10T20:20:57.1714251Z secondary_start_kernel+0xdc/0x108 2024-12-10T20:20:57.1716568Z __secondary_switched+0xc0/0xc8 2024-12-10T20:20:58.2547951Z sched_ext: BPF scheduler "ddsp_vtimelocal_fail" enabled 2024-12-10T20:20:58.3147251Z sched_ext: BPF scheduler "ddsp_vtimelocal_fail" disabled (runtime error) 2024-12-10T20:20:58.3152469Z sched_ext: ddsp_vtimelocal_fail: cannot use vtime ordering for built-in DSQs 2024-12-10T20:20:58.3154552Z dispatch_enqueue+0x350/0x360 2024-12-10T20:20:58.3156792Z direct_dispatch+0x144/0x228 2024-12-10T20:20:58.3159057Z do_enqueue_task+0x17c/0x240 2024-12-10T20:20:58.3161402Z enqueue_task_scx+0x190/0x288 2024-12-10T20:20:58.3163484Z enqueue_task+0x44/0xe8 2024-12-10T20:20:58.3165655Z ttwu_do_activate+0x88/0x298 2024-12-10T20:20:58.3167841Z try_to_wake_up+0x2b8/0x560 2024-12-10T20:20:58.3169741Z swake_up_one+0x4c/0x98 2024-12-10T20:20:58.3172304Z swake_up_one_online+0x54/0xc0 2024-12-10T20:20:58.3174591Z rcu_gp_kthread_wake+0x68/0x98 2024-12-10T20:20:58.3177003Z rcu_report_qs_rsp+0xc0/0x110 2024-12-10T20:20:58.3179438Z rcu_report_qs_rnp+0x324/0x380 2024-12-10T20:20:58.3181831Z rcu_report_qs_rdp+0x1ac/0x1c8 2024-12-10T20:20:58.3183880Z rcu_core+0x264/0x378 2024-12-10T20:20:58.3185468Z rcu_core_si+0x18/0x30 2024-12-10T20:20:58.3187895Z handle_softirqs+0x12c/0x490 2024-12-10T20:20:58.3189738Z __do_softirq+0x1c/0x28 2024-12-10T20:20:58.3191821Z ____do_softirq+0x18/0x30 2024-12-10T20:20:58.3194130Z call_on_irq_stack+0x24/0x58 2024-12-10T20:20:58.3196588Z do_softirq_own_stack+0x24/0x38 2024-12-10T20:20:58.3198745Z __irq_exit_rcu+0x140/0x180 2024-12-10T20:20:58.3200627Z irq_exit_rcu+0x18/0x48 2024-12-10T20:20:58.3202698Z el1_interrupt+0x38/0x50 2024-12-10T20:20:58.3205112Z el1h_64_irq_handler+0x18/0x28 2024-12-10T20:20:58.3206944Z el1h_64_irq+0x6c/0x70 2024-12-10T20:20:58.3209342Z default_idle_call+0xac/0x254 2024-12-10T20:20:58.3211702Z default_idle_call+0xa8/0x254 2024-12-10T20:20:58.3213312Z do_idle+0xc4/0x118 2024-12-10T20:20:58.3215643Z cpu_startup_entry+0x40/0x50 2024-12-10T20:20:58.3218478Z secondary_start_kernel+0xdc/0x108 2024-12-10T20:20:58.3220846Z __secondary_switched+0xc0/0xc8 2024-12-10T20:20:59.3646877Z sched_ext: BPF scheduler "dsp_local_on" enabled 2024-12-10T20:21:00.3650453Z ERR: dsp_local_on.c:37 2024-12-10T20:21:00.3652199Z Expected skel->data->uei.kind == EXIT_KIND(SCX_EXIT_ERROR) (0 == 1024) 2024-12-10T20:21:00.3873220Z ERR: exit.c:30 2024-12-10T20:21:00.3873570Z Failed to attach scheduler 2024-12-10T20:21:00.4746585Z psci: CPU1 killed (polled 0 ms) 2024-12-10T20:21:00.4946799Z sched_ext: BPF scheduler "dsp_local_on" disabled (runtime error) 2024-12-10T20:21:00.4953445Z sched_ext: dsp_local_on: SCX_DSQ_LOCAL[_ON] verdict target cpu 0 not allowed for ksoftirqd/1[23] 2024-12-10T20:21:00.4955934Z task_can_run_on_remote_rq+0xdc/0x108 2024-12-10T20:21:00.4958580Z dispatch_to_local_dsq+0x74/0x1d0 2024-12-10T20:21:00.4960911Z flush_dispatch_buf+0x18c/0x1d8 2024-12-10T20:21:00.4962903Z balance_one+0x154/0x2f8 2024-12-10T20:21:00.4964749Z balance_scx+0x58/0x98 2024-12-10T20:21:00.4966663Z __schedule+0x390/0x838 2024-12-10T20:21:00.4968348Z schedule+0x54/0x138 2024-12-10T20:21:00.4970453Z worker_thread+0xec/0x360 2024-12-10T20:21:00.4972076Z kthread+0x100/0x110 2024-12-10T20:21:00.4974136Z ret_from_fork+0x10/0x20 2024-12-10T20:21:00.5545933Z sched_ext: BPF scheduler "hotplug_cbs" enabled 2024-12-10T20:21:00.6145106Z Detected PIPT I-cache on CPU1 2024-12-10T20:21:00.6149673Z GICv3: CPU1: found redistributor 1 region 0:0x00000000080c0000 2024-12-10T20:21:00.6154461Z CPU1: Booted secondary processor 0x0000000001 [0x413fd0c1] 2024-12-10T20:21:00.8046976Z sched_ext: BPF scheduler "hotplug_cbs" disabled (unregistered from BPF) 2024-12-10T20:21:00.8047755Z EXIT: unregistered from BPF (hotplug event detected (1 going online)) 2024-12-10T20:21:00.9246328Z sched_ext: BPF scheduler "hotplug_cbs" enabled 2024-12-10T20:21:01.0246233Z psci: CPU1 killed (polled 0 ms) 2024-12-10T20:21:01.0946840Z sched_ext: BPF scheduler "hotplug_cbs" disabled (unregistered from BPF) 2024-12-10T20:21:01.0947621Z EXIT: unregistered from BPF (hotplug event detected (1 going offline)) 2024-12-10T20:21:01.1545076Z Detected PIPT I-cache on CPU1 2024-12-10T20:21:01.1549600Z GICv3: CPU1: found redistributor 1 region 0:0x00000000080c0000 2024-12-10T20:21:01.1554406Z CPU1: Booted secondary processor 0x0000000001 [0x413fd0c1] 2024-12-10T20:21:01.2245966Z psci: CPU1 killed (polled 0 ms) > > diff --git a/tools/testing/selftests/sched_ext/maximal.bpf.c b/tools/testing/selftests/sched_ext/maximal.bpf.c > index 4c005fa71810..430f5e13bf55 100644 > --- a/tools/testing/selftests/sched_ext/maximal.bpf.c > +++ b/tools/testing/selftests/sched_ext/maximal.bpf.c > @@ -12,6 +12,8 @@ > > char _license[] SEC("license") = "GPL"; > > +#define DSQ_ID 0 > + > s32 BPF_STRUCT_OPS(maximal_select_cpu, struct task_struct *p, s32 prev_cpu, > u64 wake_flags) > { > @@ -20,7 +22,7 @@ s32 BPF_STRUCT_OPS(maximal_select_cpu, struct task_struct *p, s32 prev_cpu, > > void BPF_STRUCT_OPS(maximal_enqueue, struct task_struct *p, u64 enq_flags) > { > - scx_bpf_dsq_insert(p, SCX_DSQ_GLOBAL, SCX_SLICE_DFL, enq_flags); > + scx_bpf_dsq_insert(p, DSQ_ID, SCX_SLICE_DFL, enq_flags); > } > > void BPF_STRUCT_OPS(maximal_dequeue, struct task_struct *p, u64 deq_flags) > @@ -28,7 +30,7 @@ void BPF_STRUCT_OPS(maximal_dequeue, struct task_struct *p, u64 deq_flags) > > void BPF_STRUCT_OPS(maximal_dispatch, s32 cpu, struct task_struct *prev) > { > - scx_bpf_dsq_move_to_local(SCX_DSQ_GLOBAL); > + scx_bpf_dsq_move_to_local(DSQ_ID); > } > > void BPF_STRUCT_OPS(maximal_runnable, struct task_struct *p, u64 enq_flags) > @@ -123,7 +125,7 @@ void BPF_STRUCT_OPS(maximal_cgroup_set_weight, struct cgroup *cgrp, u32 weight) > > s32 BPF_STRUCT_OPS_SLEEPABLE(maximal_init) > { > - return 0; > + return scx_bpf_create_dsq(DSQ_ID, -1); > } > > void BPF_STRUCT_OPS(maximal_exit, struct scx_exit_info *info) > -- > 2.46.1