sched/deadline: Don't count nr_running for dl_server proxy tasks

On CPU offline the kernel stalled with below call trace:

INFO: task kworker/0:1:11 blocked for more than 120 seconds.

cpuhp hold the cpu hotplug lock endless and stalled vmstat_shepherd.
This is because we count nr_running twice on cpuhp enqueuing and failed
the wait condition of cpuhp:

enqueue_task_fair() // pick cpuhp from idle, rq->nr_running = 0
dl_server_start()
[...]
add_nr_running() // rq->nr_running = 1
add_nr_running() // rq->nr_running = 2
[switch to cpuhp, waiting on balance_hotplug_wait()]
rcuwait_wait_event(rq->nr_running == 1 && ...) // failed, rq->nr_running=2
schedule() // wait again

It doesn't make sense to count the dl_server towards runnable tasks,
since it runs other tasks.

Fixes: 63ba8422f876 ("sched/deadline: Introduce deadline servers")
Signed-off-by: Yicong Yang <yangyicong@hisilicon.com>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Link: https://lore.kernel.org/r/20250627035420.37712-1-yangyicong@huawei.com

authored by Yicong Yang and committed by Peter Zijlstra 52d15521 421fc59c

Changed files
+6 -2
kernel
sched
+6 -2
kernel/sched/deadline.c
··· 1851 1851 u64 deadline = dl_se->deadline; 1852 1852 1853 1853 dl_rq->dl_nr_running++; 1854 - add_nr_running(rq_of_dl_rq(dl_rq), 1); 1854 + 1855 + if (!dl_server(dl_se)) 1856 + add_nr_running(rq_of_dl_rq(dl_rq), 1); 1855 1857 1856 1858 inc_dl_deadline(dl_rq, deadline); 1857 1859 } ··· 1863 1861 { 1864 1862 WARN_ON(!dl_rq->dl_nr_running); 1865 1863 dl_rq->dl_nr_running--; 1866 - sub_nr_running(rq_of_dl_rq(dl_rq), 1); 1864 + 1865 + if (!dl_server(dl_se)) 1866 + sub_nr_running(rq_of_dl_rq(dl_rq), 1); 1867 1867 1868 1868 dec_dl_deadline(dl_rq, dl_se->deadline); 1869 1869 }