原文链接:http://blog.****.net/cornrn/article/details/72473845
采用这个接口层写程序,基本上可以说不用再去管所用的是什么操作系统。相同的代码可以轻而易举的移植到不同的实时系统中。不敢说完全没有改动,但绝对是最少的。其简洁的书写手法,也会给我的应用层带来视觉上的体验感,使用可以尽可能去关注应用。
首先这里整理下CMSISOS-FREERTOS 的API如下:
FreeRTOS 封装后的 API
内核控制函数 |
|
|
osStatus osKernelStart (void); |
//内核开始运行 |
|
int32_t osKernelRunning(void); |
//返回值为 1 表示正在运行 作用:系统是否正常工作 |
|
uint32_t osKernelSysTick (void); |
//系统当前节拍数 |
作用:毫秒级计时 |
osKernelSysTickMicroSec(microsec) |
//微妙(宏函数) |
作用:微秒级计时 |
线程管理函数
osThreadDef(name, thread, priority, instances, stacksz)//(宏函数) 作用:定义 osThreadDef_t 结构体
osThread(name)//(宏函数)作用:获取 os_thread_def_##name 结构体的指针
osThreadId osThreadCreate (const osThreadDef_t *thread_def, void *argument);//创建线程,错误返回 NULL
osThreadId osThreadGetId (void);//返回当前线程
osStatus osThreadTerminate (osThreadId thread_id); //终结线程
osStatus osThreadYield (void);//调度一次
osStatus osThreadSetPriority (osThreadId thread_id, osPriority priority); //设置线程优先级 osPriority osThreadGetPriority (osThreadId thread_id); //获取线程优先级
等待函数
osStatus osDelay (uint32_t millisec);//毫秒级延时
osEvent osWait (uint32_t millisec);//未实现
信号量管理函数
osSemaphoreDef(name)//(宏函数) 作用:定义 os_semaphore_def_##name 结构体
osSemaphore(name)//(宏函数) 作用:定义 os_semaphore_def_##name 结构体的指针
osSemaphoreId osSemaphoreCreate (const osSemaphoreDef_t *semaphore_def, int32_t count);//创建信号量
int32_t osSemaphoreWait (osSemaphoreId semaphore_id, uint32_t millisec);//信号量减一
osStatus osSemaphoreRelease (osSemaphoreId semaphore_id);//信号量加一
osStatus osSemaphoreDelete (osSemaphoreId semaphore_id);//删除信号量
互斥锁管理函数 |
|
|
|
osMutexDef(name) |
//(宏函数) |
作用:定义 os_mutex_def_##name 结构体 |
|
osMutex(name) |
//宏函数 |
作用:定义 os_mutex_def_##name 结构体的指针 |
|
osMutexId osMutexCreate (const osMutexDef_t *mutex_def); |
//创建互斥锁 |
||
osStatus osMutexWait (osMutexId mutex_id, uint32_t millisec); //锁定互斥锁 |
|||
osStatus osMutexRelease (osMutexId mutex_id); |
//解锁互斥锁 |
||
osStatus osMutexDelete (osMutexId mutex_id); |
//删除互斥锁 |
队列管理函数
osMessageQDef(name, queue_sz, type) //参数二:队列 size 参数三:成员 size 作用:定义
os_messageQ_def_##name 结构体
osMessageQ(name)//宏函数作用:定义 os_messageQ_def_##name 结构体的指针
osMessageQId osMessageCreate (const osMessageQDef_t *queue_def, osThreadId thread_id);//创建队列
osStatus osMessagePut (osMessageQId queue_id, uint32_t info, uint32_t millisec); |
//向队列中放入消息 |
||||
osEvent osMessageGet (osMessageQId queue_id, uint32_t millisec); |
//从队列中获取消息 |
||||
邮箱队列管理函数 |
|
|
|
|
|
osMailQDef(name, queue_sz, type) //参数二:邮箱 size 参数三:消息 size |
作用:定义 os_mailQ_def_##name |
||||
结构体 |
|
|
|
|
|
osMailQ(name) |
//宏函数 |
作用:定义 os_mailQ_def_##name 结构体的指针 |
|||
osMailQId osMailCreate (const osMailQDef_t *queue_def, osThreadId thread_id); |
//创建邮箱 |
||||
void *osMailAlloc (osMailQId queue_id, uint32_t millisec); |
//分配一个消息的空间 |
|
|||
void *osMailCAlloc (osMailQId queue_id, uint32_t millisec); |
//分配一个消息的空间并且清零 |
||||
osStatus osMailPut (osMailQId queue_id, void *mail); |
//将成员丢到邮箱中 |
|
|||
osEvent osMailGet (osMailQId queue_id, uint32_t millisec); |
//从邮箱中获取消息 |
|
|||
osStatus osMailFree (osMailQId queue_id, void *mail); |
//释放消息空间 |
|
软件定时器管理函数
osTimerDef(name, function)//宏函数作用:定义 os_timer_def_##name 结构体
osTimer(name)//宏函数作用:定义 os_timer_def_##name 结构体的指针
osTimerId osTimerCreate (const osTimerDef_t *timer_def, os_timer_type type, void *argument);//参数二:是否
重复回调 作用:创建软件定时器 |
|
|
|
|
osStatus osTimerStart (osTimerId timer_id, uint32_t millisec); |
//开始定时 |
|
||
osStatus osTimerStop (osTimerId timer_id); |
//停止定时 |
|
||
osStatus osTimerDelete (osTimerId timer_id); |
//删除定时器 |
|
||
信号管理函数 |
|
|
|
|
int32_t osSignalSet (osThreadId thread_id, int32_t signals); |
//带通知值的任务通知 |
|
||
int32_t osSignalClear (osThreadId thread_id, int32_t signals); |
//未实现 |
|
||
osEvent osSignalWait (int32_t signals, uint32_t millisec); |
//参数二:取出值后位置零 作用:等待通知到来 |
|||
内存池管理函数 |
|
|
|
|
osPoolDef(name, no, type) |
//参数二:内存池 size 参数三:成员 size |
作用:定义 |
||
os_pool_def_##name 结构体 |
|
|
|
|
osPool(name) |
//宏函数 |
作用:定义 os_pool_def_##name 结构体的指针 |
||
osPoolId osPoolCreate (const osPoolDef_t *pool_def); //创建内存池 |
|
|||
void *osPoolAlloc (osPoolId pool_id); |
|
//分配内存 |
|
|
void *osPoolCAlloc (osPoolId pool_id); |
|
//分配内存并且清零 |
|
|
osStatus osPoolFree (osPoolId pool_id, void *block); |
//释放内存 |
|
|
|
|
|
|
void osSystickHandler(void); |
//定时器中断处理函数 |
|
||
osThreadState osThreadGetState(osThreadId thread_id); |
//获取线程状态 |
|||
osStatus osThreadIsSuspended(osThreadId thread_id); |
|
//线程是否被挂起 |
||
osStatus osThreadSuspend (osThreadId thread_id); |
|
//挂起线程 |
||
osStatus osThreadResume (osThreadId thread_id); |
|
//恢复调度 |
||
osStatus osThreadSuspendAll (void); |
|
|
//挂起所有线程 |
|
osStatus osThreadResumeAll (void); |
|
//恢复调度所有线程 |
||
osStatus osDelayUntil (uint32_t *PreviousWakeTime, uint32_t millisec); |
//绝对延时 |
|||
osStatus osThreadList (uint8_t *buffer); |
|
|
//获取任务信息 任务名、优先级 |
|
osEvent osMessagePeek (osMessageQId queue_id, uint32_t millisec); |
//瞥一眼队列中有没有消息 |
|||
osMutexId osRecursiveMutexCreate (const osMutexDef_t *mutex_def); |
//创建递归互斥锁 |
|||
osStatus osRecursiveMutexRelease (osMutexId mutex_id); |
//释放递归互斥锁 |
|||
osStatus osRecursiveMutexWait (osMutexId mutex_id, uint32_t millisec); |
//锁定递归互斥锁 |
下面先用FreeRTOS系统接口为例进行简单概述:
这里是主要的配置区,你所用到哪些功能用0或1来选择和取消。由于有些和系统中宏配置有相同意思的宏配置,所以我这里直接用了系统配置中的宏。
这是所用不同系统时的主要不同处。其他地方就很少会改动了。
下面来举例来说明如何简单的使用这个接口。
首先进入main函数:
更多接受可以如下方法进去官网查看CMSIS-OS API使用