1 /*
2 * Copyright (c) 2018 Intel Corporation
3 * Copyright (c) 2016 Wind River Systems, Inc.
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
8 #include <zephyr/kernel.h>
9
z_work_user_q_main(void * work_q_ptr,void * p2,void * p3)10 static void z_work_user_q_main(void *work_q_ptr, void *p2, void *p3)
11 {
12 struct k_work_user_q *work_q = work_q_ptr;
13
14 ARG_UNUSED(p2);
15 ARG_UNUSED(p3);
16
17 while (true) {
18 struct k_work_user *work;
19 k_work_user_handler_t handler;
20
21 work = k_queue_get(&work_q->queue, K_FOREVER);
22 if (work == NULL) {
23 continue;
24 }
25
26 handler = work->handler;
27 __ASSERT(handler != NULL, "handler must be provided");
28
29 /* Reset pending state so it can be resubmitted by handler */
30 if (atomic_test_and_clear_bit(&work->flags,
31 K_WORK_USER_STATE_PENDING)) {
32 handler(work);
33 }
34
35 /* Make sure we don't hog up the CPU if the FIFO never (or
36 * very rarely) gets empty.
37 */
38 k_yield();
39 }
40 }
41
k_work_user_queue_start(struct k_work_user_q * work_q,k_thread_stack_t * stack,size_t stack_size,int prio,const char * name)42 void k_work_user_queue_start(struct k_work_user_q *work_q, k_thread_stack_t *stack,
43 size_t stack_size, int prio, const char *name)
44 {
45 k_queue_init(&work_q->queue);
46
47 /* Created worker thread will inherit object permissions and memory
48 * domain configuration of the caller
49 */
50 k_thread_create(&work_q->thread, stack, stack_size, z_work_user_q_main,
51 work_q, NULL, NULL, prio, K_USER | K_INHERIT_PERMS,
52 K_FOREVER);
53 k_object_access_grant(&work_q->queue, &work_q->thread);
54 if (name != NULL) {
55 k_thread_name_set(&work_q->thread, name);
56 }
57
58 k_thread_start(&work_q->thread);
59 }
60