xref: /nrf52832-nimble/packages/NimBLE-latest/porting/npl/linux/src/os_task.c (revision 042d53a763ad75cb1465103098bb88c245d95138)
1*042d53a7SEvalZero /*
2*042d53a7SEvalZero  * Licensed to the Apache Software Foundation (ASF) under one
3*042d53a7SEvalZero  * or more contributor license agreements.  See the NOTICE file
4*042d53a7SEvalZero  * distributed with this work for additional information
5*042d53a7SEvalZero  * regarding copyright ownership.  The ASF licenses this file
6*042d53a7SEvalZero  * to you under the Apache License, Version 2.0 (the
7*042d53a7SEvalZero  * "License"); you may not use this file except in compliance
8*042d53a7SEvalZero  * with the License.  You may obtain a copy of the License at
9*042d53a7SEvalZero  *
10*042d53a7SEvalZero  *  http://www.apache.org/licenses/LICENSE-2.0
11*042d53a7SEvalZero  *
12*042d53a7SEvalZero  * Unless required by applicable law or agreed to in writing,
13*042d53a7SEvalZero  * software distributed under the License is distributed on an
14*042d53a7SEvalZero  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15*042d53a7SEvalZero  * KIND, either express or implied.  See the License for the
16*042d53a7SEvalZero  * specific language governing permissions and limitations
17*042d53a7SEvalZero  * under the License.
18*042d53a7SEvalZero  */
19*042d53a7SEvalZero 
20*042d53a7SEvalZero #include "os/os.h"
21*042d53a7SEvalZero #include "nimble/nimble_npl.h"
22*042d53a7SEvalZero 
23*042d53a7SEvalZero #ifdef __cplusplus
24*042d53a7SEvalZero extern "C" {
25*042d53a7SEvalZero #endif
26*042d53a7SEvalZero 
27*042d53a7SEvalZero /**
28*042d53a7SEvalZero  * Initialize a task.
29*042d53a7SEvalZero  *
30*042d53a7SEvalZero  * This function initializes the task structure pointed to by t,
31*042d53a7SEvalZero  * clearing and setting it's stack pointer, provides sane defaults
32*042d53a7SEvalZero  * and sets the task as ready to run, and inserts it into the operating
33*042d53a7SEvalZero  * system scheduler.
34*042d53a7SEvalZero  *
35*042d53a7SEvalZero  * @param t The task to initialize
36*042d53a7SEvalZero  * @param name The name of the task to initialize
37*042d53a7SEvalZero  * @param func The task function to call
38*042d53a7SEvalZero  * @param arg The argument to pass to this task function
39*042d53a7SEvalZero  * @param prio The priority at which to run this task
40*042d53a7SEvalZero  * @param sanity_itvl The time at which this task should check in with the
41*042d53a7SEvalZero  *                    sanity task.  OS_WAIT_FOREVER means never check in
42*042d53a7SEvalZero  *                    here.
43*042d53a7SEvalZero  * @param stack_bottom A pointer to the bottom of a task's stack
44*042d53a7SEvalZero  * @param stack_size The overall size of the task's stack.
45*042d53a7SEvalZero  *
46*042d53a7SEvalZero  * @return 0 on success, non-zero on failure.
47*042d53a7SEvalZero  */
48*042d53a7SEvalZero int
ble_npl_task_init(struct ble_npl_task * t,const char * name,ble_npl_task_func_t func,void * arg,uint8_t prio,ble_npl_time_t sanity_itvl,ble_npl_stack_t * stack_bottom,uint16_t stack_size)49*042d53a7SEvalZero ble_npl_task_init(struct ble_npl_task *t, const char *name, ble_npl_task_func_t func,
50*042d53a7SEvalZero         void *arg, uint8_t prio, ble_npl_time_t sanity_itvl,
51*042d53a7SEvalZero         ble_npl_stack_t *stack_bottom, uint16_t stack_size)
52*042d53a7SEvalZero {
53*042d53a7SEvalZero     int err;
54*042d53a7SEvalZero     if ((t == NULL) || (func == NULL)) {
55*042d53a7SEvalZero         return OS_INVALID_PARM;
56*042d53a7SEvalZero     }
57*042d53a7SEvalZero 
58*042d53a7SEvalZero     pthread_attr_t attr;
59*042d53a7SEvalZero     struct sched_param param;
60*042d53a7SEvalZero     err = pthread_attr_init(&attr);
61*042d53a7SEvalZero     if (err) return err;
62*042d53a7SEvalZero     err = pthread_attr_getschedparam (&attr, &param);
63*042d53a7SEvalZero     if (err) return err;
64*042d53a7SEvalZero     err = pthread_attr_setschedpolicy(&attr, SCHED_RR);
65*042d53a7SEvalZero     if (err) return err;
66*042d53a7SEvalZero     param.sched_priority = prio;
67*042d53a7SEvalZero     err = pthread_attr_setschedparam (&attr, &param);
68*042d53a7SEvalZero     if (err) return err;
69*042d53a7SEvalZero 
70*042d53a7SEvalZero     t->name = name;
71*042d53a7SEvalZero     err = pthread_create(&t->handle, &attr, func, arg);
72*042d53a7SEvalZero 
73*042d53a7SEvalZero     return err;
74*042d53a7SEvalZero }
75*042d53a7SEvalZero 
76*042d53a7SEvalZero /*
77*042d53a7SEvalZero  * Removes specified task
78*042d53a7SEvalZero  * XXX
79*042d53a7SEvalZero  * NOTE: This interface is currently experimental and not ready for common use
80*042d53a7SEvalZero  */
81*042d53a7SEvalZero int
ble_npl_task_remove(struct ble_npl_task * t)82*042d53a7SEvalZero ble_npl_task_remove(struct ble_npl_task *t)
83*042d53a7SEvalZero {
84*042d53a7SEvalZero     return pthread_cancel(t->handle);
85*042d53a7SEvalZero }
86*042d53a7SEvalZero 
87*042d53a7SEvalZero /**
88*042d53a7SEvalZero  * Return the number of tasks initialized.
89*042d53a7SEvalZero  *
90*042d53a7SEvalZero  * @return number of tasks initialized
91*042d53a7SEvalZero  */
92*042d53a7SEvalZero uint8_t
ble_npl_task_count(void)93*042d53a7SEvalZero ble_npl_task_count(void)
94*042d53a7SEvalZero {
95*042d53a7SEvalZero     return 0;
96*042d53a7SEvalZero }
97*042d53a7SEvalZero 
98*042d53a7SEvalZero void *
ble_npl_get_current_task_id(void)99*042d53a7SEvalZero ble_npl_get_current_task_id(void)
100*042d53a7SEvalZero {
101*042d53a7SEvalZero     return (void *)pthread_self();
102*042d53a7SEvalZero }
103*042d53a7SEvalZero 
ble_npl_os_started(void)104*042d53a7SEvalZero bool ble_npl_os_started(void)
105*042d53a7SEvalZero {
106*042d53a7SEvalZero     return true;
107*042d53a7SEvalZero }
108*042d53a7SEvalZero 
ble_npl_task_yield(void)109*042d53a7SEvalZero void ble_npl_task_yield(void)
110*042d53a7SEvalZero {
111*042d53a7SEvalZero     pthread_yield();
112*042d53a7SEvalZero }
113*042d53a7SEvalZero 
114*042d53a7SEvalZero #ifdef __cplusplus
115*042d53a7SEvalZero }
116*042d53a7SEvalZero #endif
117