91d90df2a7
Currently P4WQ supports queues with sets of user-provided worked threads of arbitrary numbers. These threads are started immediately upon initialisation. This patch adds support for 3 more thread implementation options: 1. queue per thread. It adds a K_P4WQ_ARRAY_DEFINE() macro which initialises an array of queues and threads of the same number. These threads are then uniquely assigned to respective queues. 2. delayed start. With this option threads aren't started immediately upon queue initialisation. Instead a new function k_p4wq_enable_static_thread() has to be called to enable those threads individually. 3. queue per CPU. With this option the user can assign CPU masks to threads when calling k_p4wq_enable_static_thread(). Otherwise the cpu_mask parameter to that function is ignored. Currently enabling this option implies option 2 above. Also so far to enable queues per CPU the user has to use K_P4WQ_ARRAY_DEFINE(), which means this option also implies 1 above, but both these restrictions can be relaxed in the future if required. Signed-off-by: Guennadi Liakhovetski <guennadi.liakhovetski@linux.intel.com> |
||
---|---|---|
.. | ||
assert.c | ||
base64.c | ||
cbprintf.c | ||
cbprintf_complete.c | ||
cbprintf_nano.c | ||
cbprintf_packaged.c | ||
CMakeLists.txt | ||
crc7_sw.c | ||
crc8_sw.c | ||
crc16_sw.c | ||
crc32_sw.c | ||
crc32c_sw.c | ||
dec.c | ||
fdtable.c | ||
heap-validate.c | ||
heap.c | ||
heap.h | ||
hex.c | ||
json.c | ||
Kconfig | ||
Kconfig.cbprintf | ||
mpsc_pbuf.c | ||
mutex.c | ||
notify.c | ||
onoff.c | ||
p4wq.c | ||
printk.c | ||
rb.c | ||
reboot.c | ||
ring_buffer.c | ||
sem.c | ||
thread_entry.c | ||
timeutil.c | ||
user_work.c | ||
work_q.c |