Hi, Can anyone explain the below message: kernel:BUG: workqueue lockup - pool cpus=4 node=0 flags=0x0 nice=0 stuck for 55s! Red Hat Enterprise 9.2 BR Davoud
spinlock_tlock;/*the pool lock*/---用于保护worker_pool的自旋锁intcpu;/*I: the associated cpu*/---对于unbound类型为-1;对于bound类型workqueue表示绑定的CPU ID。intnode;/*I: the associated node ID*/intid;/*I: pool ID*/---该worker_pool的ID号unsignedintflags;/*X: flags*/structlist_hea...
worker_pool是per-cpu变量,每个CPU都有worker_pool,而且有两个worker_pool。 一个用于普通优先级工作线程,另一个用于高优先级工作线程。 struct worker_pool { spinlock_t lock; /* the pool lock */---用于保护worker_pool的自旋锁 int cpu; /* I: the associated cpu */---对于unbound类型为-1;对于bo...
struct worker_pool { spinlock_t lock; /* the pool lock */---用于保护worker_pool的自旋锁 int cpu; /* I: the associated cpu */---对于unbound类型为-1;对于bound类型workqueue表示绑定的CPU ID。 int node; /* I: the associated node ID */ int id; /* I: pool ID */---该worker_pool...
一是bound型,可以理解为Per-CPU类型,每个CPU都有worker-pool; 另一种是unbound型,即不和具体CPU绑定。 这两种worker-pool都会定义两个线程池,一个给普通优先级的work使用,另一个给高优先级的work使用。 1. 初始化工作队列 1.1 工作、工作队列、工作线程池、工作线程数据结构 ...
smp_prepare_cpus(setup_max_cpus); do_pre_smp_initcalls();---此处调用的initcall是在__initcall_start~__initcall0_start之间的函数,也即early_initcall()。所以init_workqueues()在smp_init之前被调用。 lockup_detector_init(); smp_init(); sched_init_smp();---将剩余CPU1~3进行up操作。 do_basi...