2023-05-03 22:11:05 +08:00
|
|
|
/****************************************************************************
|
2008-11-17 00:36:30 +08:00
|
|
|
* include/sched.h
|
2007-02-18 07:21:28 +08:00
|
|
|
*
|
2020-05-08 21:23:26 +08:00
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the
|
|
|
|
* License. You may obtain a copy of the License at
|
2007-02-18 07:21:28 +08:00
|
|
|
*
|
2020-05-08 21:23:26 +08:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2007-02-18 07:21:28 +08:00
|
|
|
*
|
2020-05-08 21:23:26 +08:00
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
2007-02-18 07:21:28 +08:00
|
|
|
*
|
2023-05-03 22:11:05 +08:00
|
|
|
****************************************************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2008-11-17 00:36:30 +08:00
|
|
|
#ifndef __INCLUDE_SCHED_H
|
|
|
|
#define __INCLUDE_SCHED_H
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2023-05-03 22:11:05 +08:00
|
|
|
/****************************************************************************
|
2007-02-18 07:21:28 +08:00
|
|
|
* Included Files
|
2023-05-03 22:11:05 +08:00
|
|
|
****************************************************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
2009-12-15 07:32:23 +08:00
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <stdint.h>
|
2016-06-20 21:35:38 +08:00
|
|
|
#include <stdbool.h>
|
2020-09-21 16:39:09 +08:00
|
|
|
#include <strings.h>
|
2021-05-14 10:03:23 +08:00
|
|
|
#include <time.h>
|
2020-02-01 04:25:15 +08:00
|
|
|
|
2023-05-03 22:11:05 +08:00
|
|
|
/****************************************************************************
|
2009-12-15 07:32:23 +08:00
|
|
|
* Pre-processor Definitions
|
2023-05-03 22:11:05 +08:00
|
|
|
****************************************************************************/
|
2020-02-09 21:32:52 +08:00
|
|
|
|
2023-05-03 22:11:05 +08:00
|
|
|
/* Task Management Definitions **********************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2007-03-21 00:51:12 +08:00
|
|
|
/* POSIX-like scheduling policies */
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2023-01-29 12:07:20 +08:00
|
|
|
#define SCHED_NORMAL 0 /* Alias to SCHED_OTHER */
|
|
|
|
#define SCHED_OTHER 0 /* Map to SCHED_FIFO or SCHED_RR */
|
2016-12-11 06:06:14 +08:00
|
|
|
#define SCHED_FIFO 1 /* FIFO priority scheduling policy */
|
|
|
|
#define SCHED_RR 2 /* Round robin scheduling policy */
|
|
|
|
#define SCHED_SPORADIC 3 /* Sporadic scheduling policy */
|
2015-08-04 00:46:36 +08:00
|
|
|
|
|
|
|
/* Maximum number of SCHED_SPORADIC replenishments */
|
|
|
|
|
2016-12-11 06:06:14 +08:00
|
|
|
#define SS_REPL_MAX CONFIG_SCHED_SPORADIC_MAXREPL
|
|
|
|
|
2023-05-03 22:11:05 +08:00
|
|
|
/* Cancellation definitions *************************************************/
|
2016-12-11 06:06:14 +08:00
|
|
|
|
|
|
|
/* Cancellation states used by task_setcancelstate() */
|
|
|
|
|
|
|
|
#define TASK_CANCEL_ENABLE (0)
|
|
|
|
#define TASK_CANCEL_DISABLE (1)
|
|
|
|
|
|
|
|
/* Cancellation types used by task_setcanceltype() */
|
|
|
|
|
|
|
|
#define TASK_CANCEL_DEFERRED (0)
|
|
|
|
#define TASK_CANCEL_ASYNCHRONOUS (1)
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2023-05-03 22:11:05 +08:00
|
|
|
/* Pthread definitions ******************************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2020-05-08 21:23:26 +08:00
|
|
|
#define PTHREAD_KEYS_MAX CONFIG_TLS_NELEM
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2023-05-03 22:11:05 +08:00
|
|
|
/* CPU affinity mask helpers ************************************************/
|
2020-02-09 21:32:52 +08:00
|
|
|
|
2016-02-22 01:27:55 +08:00
|
|
|
/* These are not standard but are defined for Linux compatibility */
|
2016-02-21 08:45:07 +08:00
|
|
|
|
|
|
|
#ifdef CONFIG_SMP
|
|
|
|
|
|
|
|
/* void CPU_ZERO(FAR cpu_set_t *set); */
|
|
|
|
|
|
|
|
# define CPU_ZERO(s) do { *(s) = 0; } while (0)
|
|
|
|
|
|
|
|
/* void CPU_SET(int cpu, FAR cpu_set_t *set); */
|
|
|
|
|
|
|
|
# define CPU_SET(c,s) do { *(s) |= (1 << (c)); } while (0)
|
|
|
|
|
|
|
|
/* void CPU_CLR(int cpu, FAR cpu_set_t *set); */
|
|
|
|
|
|
|
|
# define CPU_CLR(c,s) do { *(s) &= ~(1 << (c)); } while (0)
|
|
|
|
|
|
|
|
/* int CPU_ISSET(int cpu, FAR const cpu_set_t *set); */
|
|
|
|
|
|
|
|
# define CPU_ISSET(c,s) ((*(s) & (1 << (c))) != 0)
|
|
|
|
|
|
|
|
/* int CPU_COUNT(FAR const cpu_set_t *set); */
|
|
|
|
|
2020-09-21 16:39:09 +08:00
|
|
|
# define CPU_COUNT(s) popcountl(*s)
|
2016-02-21 08:45:07 +08:00
|
|
|
|
|
|
|
/* void CPU_AND(FAR cpu_set_t *destset, FAR const cpu_set_t *srcset1,
|
|
|
|
* FAR const cpu_set_t *srcset2);
|
|
|
|
*/
|
|
|
|
|
|
|
|
# define CPU_AND(d,s1,s2) do { *(d) = *(s1) & *(s2); } while (0)
|
|
|
|
|
|
|
|
/* void CPU_OR(FAR cpu_set_t *destset, FAR const cpu_set_t *srcset1,
|
|
|
|
* FAR const cpu_set_t *srcset2);
|
|
|
|
*/
|
|
|
|
|
|
|
|
# define CPU_OR(d,s1,s2) do { *(d) = *(s1) | *(s2); } while (0)
|
|
|
|
|
|
|
|
/* void CPU_XOR(FAR cpu_set_t *destset, FAR const cpu_set_t *srcset1,
|
|
|
|
* FAR const cpu_set_t *srcset2);
|
|
|
|
*/
|
|
|
|
|
|
|
|
# define CPU_XOR(d,s1,s2) do { *(d) = *(s1) ^ *(s2); } while (0)
|
|
|
|
|
|
|
|
/* int CPU_EQUAL(FAR const cpu_set_t *set1, FAR const cpu_set_t *set2); */
|
|
|
|
|
|
|
|
# define CPU_EQUAL(s1,s2) (*(s2) == *(s2))
|
|
|
|
|
2016-02-22 01:27:55 +08:00
|
|
|
/* REVISIT: Variably sized CPU sets are not supported */
|
2020-02-09 21:32:52 +08:00
|
|
|
|
2016-02-21 08:45:07 +08:00
|
|
|
/* FAR cpu_set_t *CPU_ALLOC(int num_cpus); */
|
|
|
|
|
|
|
|
# define CPU_ALLOC(n) (FAR cpu_set_t *)malloc(sizeof(cpu_set_t));
|
|
|
|
|
|
|
|
/* void CPU_FREE(cpu_set_t *set); */
|
|
|
|
|
2020-08-20 20:53:16 +08:00
|
|
|
# define CPU_FREE(s) free(s)
|
2016-02-21 08:45:07 +08:00
|
|
|
|
|
|
|
/* size_t CPU_ALLOC_SIZE(int num_cpus); */
|
|
|
|
|
|
|
|
# define CPU_ALLOC_SIZE(n) sizeof(cpu_set_t)
|
|
|
|
|
|
|
|
/* void CPU_ZERO_S(size_t setsize, FAR cpu_set_t *set); */
|
|
|
|
|
|
|
|
# define CPU_ZERO_S(n,s) CPU_ZERO_S(s)
|
|
|
|
|
|
|
|
/* void CPU_SET_S(int cpu, size_t setsize, FAR cpu_set_t *set); */
|
|
|
|
|
|
|
|
# define CPU_SET_S(c,n,s) CPU_SET(c,s)
|
|
|
|
|
|
|
|
/* void CPU_CLR_S(int cpu, size_t setsize, FAR cpu_set_t *set); */
|
|
|
|
|
|
|
|
# define CPU_CLR_S(c,n,s) CPU_CLR(c,s)
|
|
|
|
|
|
|
|
/* int CPU_ISSET_S(int cpu, size_t setsize, FAR const cpu_set_t *set); */
|
|
|
|
|
|
|
|
# define CPU_ISSET_S(c,n,s) CPU_ISSET(c,s)
|
|
|
|
|
|
|
|
/* int CPU_COUNT_S(size_t setsize, FAR const cpu_set_t *set); */
|
|
|
|
|
|
|
|
# define CPU_COUNT_S(n,s) CPU_COUNT(s)
|
|
|
|
|
|
|
|
/* void CPU_AND_S(size_t setsize, FAR cpu_set_t *destset,
|
|
|
|
* FAR const cpu_set_t *srcset1,
|
|
|
|
* FAR const cpu_set_t *srcset2);
|
|
|
|
*/
|
|
|
|
|
|
|
|
# define CPU_AND_S(n,d,s1,s2) CPU_AND(d,s1,s2)
|
|
|
|
|
|
|
|
/* void CPU_OR_S(size_t setsize, FAR cpu_set_t *destset,
|
|
|
|
* FAR const cpu_set_t *srcset1,
|
|
|
|
* FAR const cpu_set_t *srcset2);
|
|
|
|
*/
|
|
|
|
|
|
|
|
# define CPU_OR_S(n,d,s1,s2) CPU_OR(d,s1,s2)
|
|
|
|
|
|
|
|
/* void CPU_XOR_S(size_t setsize, FAR cpu_set_t *destset,
|
|
|
|
* FAR const cpu_set_t *srcset1,
|
|
|
|
* FAR const cpu_set_t *srcset2);
|
|
|
|
*/
|
|
|
|
|
|
|
|
# define CPU_XOR_S(n,d,s1,s2) CPU_XOR(d,s1,s2)
|
|
|
|
|
|
|
|
/* int CPU_EQUAL_S(size_t setsize, FAR const cpu_set_t *set1,
|
|
|
|
* FAR const cpu_set_t *set2);
|
|
|
|
*/
|
|
|
|
|
|
|
|
# define CPU_EQUAL_S(n,s1,s2) CPU_EQUAL(s1,s2)
|
|
|
|
|
|
|
|
#endif /* CONFIG_SMP */
|
|
|
|
|
2023-05-03 22:11:05 +08:00
|
|
|
/****************************************************************************
|
2013-01-23 07:42:51 +08:00
|
|
|
* Public Type Definitions
|
2023-05-03 22:11:05 +08:00
|
|
|
****************************************************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2007-03-21 00:51:12 +08:00
|
|
|
/* This is the POSIX-like scheduling parameter structure */
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2007-03-21 00:51:12 +08:00
|
|
|
struct sched_param
|
2007-02-18 07:21:28 +08:00
|
|
|
{
|
2015-07-24 03:16:32 +08:00
|
|
|
int sched_priority; /* Base thread priority */
|
|
|
|
|
|
|
|
#ifdef CONFIG_SCHED_SPORADIC
|
|
|
|
int sched_ss_low_priority; /* Low scheduling priority for sporadic
|
|
|
|
* server */
|
|
|
|
struct timespec sched_ss_repl_period; /* Replenishment period for sporadic
|
|
|
|
* server. */
|
|
|
|
struct timespec sched_ss_init_budget; /* Initial budget for sporadic server */
|
|
|
|
int sched_ss_max_repl; /* Maximum pending replenishments for
|
|
|
|
* sporadic server. */
|
|
|
|
#endif
|
2007-02-18 07:21:28 +08:00
|
|
|
};
|
2007-03-09 23:27:47 +08:00
|
|
|
|
2023-05-03 22:11:05 +08:00
|
|
|
/****************************************************************************
|
2013-01-23 07:42:51 +08:00
|
|
|
* Public Data
|
2023-05-03 22:11:05 +08:00
|
|
|
****************************************************************************/
|
2007-02-18 07:21:28 +08:00
|
|
|
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
#undef EXTERN
|
|
|
|
#if defined(__cplusplus)
|
|
|
|
#define EXTERN extern "C"
|
2013-01-23 07:42:51 +08:00
|
|
|
extern "C"
|
|
|
|
{
|
2007-02-18 07:21:28 +08:00
|
|
|
#else
|
|
|
|
#define EXTERN extern
|
|
|
|
#endif
|
|
|
|
|
2023-05-03 22:11:05 +08:00
|
|
|
/****************************************************************************
|
2013-01-23 07:42:51 +08:00
|
|
|
* Public Function Prototypes
|
2023-05-03 22:11:05 +08:00
|
|
|
****************************************************************************/
|
2013-01-23 07:42:51 +08:00
|
|
|
|
2007-02-18 07:21:28 +08:00
|
|
|
/* Task Control Interfaces (non-standard) */
|
|
|
|
|
2014-09-17 05:37:05 +08:00
|
|
|
#ifndef CONFIG_BUILD_KERNEL
|
2013-02-05 02:46:28 +08:00
|
|
|
int task_create(FAR const char *name, int priority, int stack_size,
|
|
|
|
main_t entry, FAR char * const argv[]);
|
2022-10-20 03:27:21 +08:00
|
|
|
int task_create_with_stack(FAR const char *name, int priority,
|
|
|
|
FAR void *stack_addr, int stack_size,
|
|
|
|
main_t entry, FAR char * const argv[]);
|
2014-09-14 22:22:21 +08:00
|
|
|
#endif
|
2013-01-23 07:42:51 +08:00
|
|
|
int task_delete(pid_t pid);
|
|
|
|
int task_restart(pid_t pid);
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2016-12-11 05:16:46 +08:00
|
|
|
int task_setcancelstate(int state, FAR int *oldstate);
|
2016-12-11 06:06:14 +08:00
|
|
|
int task_setcanceltype(int type, FAR int *oldtype);
|
2016-12-11 06:34:14 +08:00
|
|
|
void task_testcancel(void);
|
2016-12-11 05:16:46 +08:00
|
|
|
|
2007-02-18 07:21:28 +08:00
|
|
|
/* Task Scheduling Interfaces (based on POSIX APIs) */
|
|
|
|
|
2020-05-06 17:24:42 +08:00
|
|
|
int sched_setparam(pid_t pid, FAR const struct sched_param *param);
|
|
|
|
int sched_getparam(pid_t pid, FAR struct sched_param *param);
|
2013-01-23 07:42:51 +08:00
|
|
|
int sched_setscheduler(pid_t pid, int policy,
|
|
|
|
FAR const struct sched_param *param);
|
|
|
|
int sched_getscheduler(pid_t pid);
|
|
|
|
int sched_yield(void);
|
|
|
|
int sched_get_priority_max(int policy);
|
|
|
|
int sched_get_priority_min(int policy);
|
|
|
|
int sched_rr_get_interval(pid_t pid, FAR struct timespec *interval);
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2016-02-20 05:57:07 +08:00
|
|
|
#ifdef CONFIG_SMP
|
|
|
|
/* Task affinity */
|
|
|
|
|
2016-03-17 01:00:31 +08:00
|
|
|
int sched_setaffinity(pid_t pid, size_t cpusetsize,
|
|
|
|
FAR const cpu_set_t *mask);
|
|
|
|
int sched_getaffinity(pid_t pid, size_t cpusetsize, FAR cpu_set_t *mask);
|
2020-02-09 15:42:11 +08:00
|
|
|
int sched_cpucount(FAR const cpu_set_t *set);
|
2020-02-01 04:25:15 +08:00
|
|
|
int sched_getcpu(void);
|
2016-02-21 08:45:07 +08:00
|
|
|
#endif /* CONFIG_SMP */
|
2016-02-20 05:57:07 +08:00
|
|
|
|
2007-02-18 07:21:28 +08:00
|
|
|
/* Task Switching Interfaces (non-standard) */
|
|
|
|
|
2013-01-23 07:42:51 +08:00
|
|
|
int sched_lock(void);
|
|
|
|
int sched_unlock(void);
|
|
|
|
int sched_lockcount(void);
|
2007-02-18 07:21:28 +08:00
|
|
|
|
2016-06-20 21:35:38 +08:00
|
|
|
/* Queries */
|
|
|
|
|
|
|
|
bool sched_idletask(void);
|
|
|
|
|
2021-07-30 12:15:43 +08:00
|
|
|
/* Task Backtrace */
|
|
|
|
|
2021-12-24 15:38:14 +08:00
|
|
|
int sched_backtrace(pid_t tid, FAR void **buffer, int size, int skip);
|
2021-07-30 12:15:43 +08:00
|
|
|
void sched_dumpstack(pid_t tid);
|
|
|
|
|
2007-02-18 07:21:28 +08:00
|
|
|
#undef EXTERN
|
|
|
|
#if defined(__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* __ASSEMBLY__ */
|
|
|
|
|
2008-11-17 00:36:30 +08:00
|
|
|
#endif /* __INCLUDE_SCHED_H */
|