diff --git a/System/ur_api.h b/System/ur_api.h
deleted file mode 100644
index 7a4e1aa..0000000
--- a/System/ur_api.h
+++ /dev/null
@@ -1,1774 +0,0 @@
-/**************************************************************************//**
- * @item CosyOS-III Kernel
- * @file ur_api.h
- * @brief 用户API
- * @details 用户API定义,含注释说明,所有内核服务的API说明均在此文件中,并支持doxygen。
- * @author 迟凯峰
- * @version V1.2.9
- * @date 2025.06.27
- ******************************************************************************/
-
-#ifndef __UR_API_H
-#define __UR_API_H
-
-/**
- \page CosyOS_API_DESCRIBE 概述:API说明
- 用户通过调用API来实现对系统服务的调用,所有API均为宏定义,所有API参数均支持宏定义。
-
-
-
- \li API分类
-
- \li 创建API
- 静态创建:前缀为“u”,分为声明对象(uExtern)、创建对象(uCreate)、定义对象(uDef)。
- 动态创建:前缀为“d”,分为声明对象(dExtern)、创建对象(dCreate)。
-
- \li 任务API
- 前缀为“u”,指仅在任务中调用。
-
- \li 滴答API
- 前缀为“t”,指仅在 SysTick_Handler 中调用,包括但不限于在滴答钩子、定时中断钩子、
- 定时查询钩子、定时查询事件等处调用。
-
- \li 中断API
- 前缀为“i”,指仅在用户中断中调用。
-
- \li PSVAPI
- 前缀为“p”,指仅在 PendSV_Handler(pendsv_hook)中调用。
-
- \li 公共API
- 前缀为“x”,指可在任意处调用。
-
-
-
- \li API返回
-
- \li 无返回
- (1)服务的执行结果一定是成功的,所以不需要返回。
- (2)所有中断挂起服务均无返回。
-
- \li 返回错误码
- 服务的执行结果可能会失败,导致失败的原因可能有多个。
- (1)无错误。
- (2)由于结果已经成功,导致本次并未执行。
- (3)失败。
-
- \li 返回结果
- 服务的执行结果可能会失败,但导致失败的原因是唯一的。
- 执行结果为 bool 类型,true 为成功,false 为失败。
-
- \li 返回指针
- 返回一个指针,(void *) 类型,NULL 为失败。
-
- \li 返回值
- 返回一个数值,特定的数据类型,0 为失败。
-
-
-
- \li 名词解释
-
- \li 无限阻塞
- 阻塞时间为无限长。
-
- \li 无限等待
- 超时时间为无限长。
-
- \li 无限延时
- 延时时间为无限长。
-
- \li 无限同步
- 仅同步一次,事件处理线程便可不限次数的周期运行处理事件。
- 仅二值信号量支持该功能,可通过上锁的方式来终止无限同步。
-
-
- */
-
-/**
- \defgroup CosyOS_用户API
- @{
- */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 构建系统
- \brief 系统构建相关服务。
- @{
- */
-
-/**
- \brief 启动-CosyOS
- \param 无
- \return 错误码
- \note 用户应自主创建main函数,并在其末尾处调用该函数来启动-CosyOS;
- 在正常情况下,该函数并不会返回,而是直接调度至 Starter 运行;
- 只有在 Sysidle / Starter 启动失败时,才会返回错误码提示用户。
- */
-s_ecode_t uStartCosyOS(void);
-
-/**
- \brief CosyOS-滴答
- \param 无
- \return 无
- \note 对于Arm用户来说,您应自主创建 SysTick_Handler(),并在其中调用该服务。
- \warning 对于51/251用户来说,系统滴答中断固定采用定时器0中断,并由CosyOS托管,
- 您应屏蔽掉工程中原有的定时器0中断函数以避免冲突。
- */
-void tCosyTick_Handler(void);
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 任务
- \brief 任务线程的声明、创建、启动,及操作。
- @{
- */
-
-/**
- \ingroup 任务
- \defgroup 声明任务
- \brief 任务线程的声明
- \note 首先,声明任务不一定是必须的,当仅在一个c文件中启动、操作任务时,时常并不需要声明。
- \note 在声明任务时,通常无论是在h文件中声明还是在c文件中声明,都应采用完整声明方式,
- 只有在编译器发出警告,与该任务相关的全局变量未引用时,再考虑简化声明方式。
- \note 通常这种情况并不会发生,典型的是在您使用GCC(GNU)编译器时,可能偶尔会出现这种警告。
- @{
- */
-
-/**
- \brief 简化声明静态任务
- \param[in] task 任务名称
- \return 无
- */
-#define uExtTask(task) \
- sCSV_ExtTask(task)
-
-/**
- \brief 简化声明动态任务
- \param[in] task 任务名称
- \return 无
- */
-#define dExtTask(task) \
- dCSV_ExtTask(task)
-
-/**
- \brief 完整声明静态任务
- \param[in] task 任务名称
- \return 无
- */
-#define uExternTask(task) \
- sCSV_ExternTask(task)
-
-/**
- \brief 完整声明动态任务
- \param[in] task 任务名称
- \return 无
- */
-#define dExternTask(task) \
- dCSV_ExternTask(task)
-
-/** @} */
-
-/**
- \ingroup 任务
- \defgroup 创建任务
- \brief 任务线程的创建
- @{
- */
-
-/**
- \brief 静态创建一般任务
- \param[in] task 任务名称
- \param[in] pri 任务优先级
- \param[in] tss 任务栈大小(单位为字节)
- \param[in] srt 安全运行时(单位为时间片,0为无限长)
- \param[in] res 保留
- \param[in] add{...} 附加任务代码
- \return 无
- */
-#define uCreateTask(task, pri, tss, srt, res) \
- sCSV_CreateTask(task, pri, tss, srt, SYSCFG_CREATETASKCUSTOM(task, res))
-
-/**
- \brief 动态创建一般任务
- \param[in] task 任务名称
- \param[in] pri 任务优先级
- \param[in] tss 任务栈大小(单位为字节)
- \param[in] srt 安全运行时(单位为时间片,0为无限长)
- \param[in] res 保留
- \param[in] add{...} 附加任务代码
- \return 无
- */
-#define dCreateTask(task, pri, tss, srt, res) \
- dCSV_CreateTask(task, pri, tss, srt, SYSCFG_CREATETASKCUSTOM(task, res))
-
-/**
- \brief 静态创建定时中断任务
- \param[in] tmid 定时中断定时器ID
- \param[in] arl 自动重装载
- \param[in] task 任务名称
- \param[in] pri 任务优先级
- \param[in] tss 任务栈大小(单位为字节)
- \param[in] srt 安全运行时(单位为时间片,0为无限长)
- \param[in] res 保留
- \param[in] add{...} 附加任务代码
- \return 无
- */
-#define uCreateTask_TimInt(tmid, arl, task, pri, tss, srt, res) \
- sCSV_CreateTask_TimInt(tmid, arl, task, pri, tss, srt, SYSCFG_CREATETASKCUSTOM(task, res))
-
-/**
- \brief 动态创建定时中断任务
- \param[in] tmid 定时中断定时器ID
- \param[in] arl 自动重装载
- \param[in] task 任务名称
- \param[in] pri 任务优先级
- \param[in] tss 任务栈大小(单位为字节)
- \param[in] srt 安全运行时(单位为时间片,0为无限长)
- \param[in] res 保留
- \param[in] add{...} 附加任务代码
- \return 无
- */
-#define dCreateTask_TimInt(tmid, arl, task, pri, tss, srt, res) \
- dCSV_CreateTask_TimInt(tmid, arl, task, pri, tss, srt, SYSCFG_CREATETASKCUSTOM(task, res))
-
-/**
- \brief 静态创建定时查询任务
- \param[in] tmid 定时查询定时器ID
- \param[in] event 定时查询事件
- \param[in] arl 自动重装载
- \param[in] task 任务名称
- \param[in] pri 任务优先级
- \param[in] tss 任务栈大小(单位为字节)
- \param[in] srt 安全运行时(单位为时间片,0为无限长)
- \param[in] res 保留
- \param[in] add{...} 附加任务代码
- \return 无
- */
-#define uCreateTask_TimQry(tmid, event, arl, task, pri, tss, srt, res) \
- sCSV_CreateTask_TimQry(tmid, event, arl, task, pri, tss, srt, SYSCFG_CREATETASKCUSTOM(task, res))
-
-/**
- \brief 动态创建定时查询任务
- \param[in] tmid 定时查询定时器ID
- \param[in] event 定时查询事件
- \param[in] arl 自动重装载
- \param[in] task 任务名称
- \param[in] pri 任务优先级
- \param[in] tss 任务栈大小(单位为字节)
- \param[in] srt 安全运行时(单位为时间片,0为无限长)
- \param[in] res 保留
- \param[in] add{...} 附加任务代码
- \return 无
- */
-#define dCreateTask_TimQry(tmid, event, arl, task, pri, tss, srt, res) \
- dCSV_CreateTask_TimQry(tmid, event, arl, task, pri, tss, srt, SYSCFG_CREATETASKCUSTOM(task, res))
-
-/** @} */
-
-/**
- \ingroup 任务
- \defgroup 启动任务
- \brief 任务线程的启动。任务只有在启动以后,才能加入到任务队列参与调度并运行。
- \warning 所有定时中断任务和定时查询任务均由操作系统自动启动,用户不要启动。
- \warning 不支持在临界区中,包括任务临界区、服务层临界区、全局临界区,或关闭总中断时调用。
- @{
- */
-
-/**
- \brief 启动任务
- \details 启动任务并置任务的初始状态为设定状态。
- \param[in] task 任务名称
- \param[in] status 任务的初始状态
- 就绪状态:OS_STATUS_READY
- 阻塞状态:OS_STATUS_BLOCKED,阻塞类型为延时阻塞,延时时间为无限长。
- 挂起状态:OS_STATUS_SUSPENDED,先前状态为就绪状态。
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_OVERFLOW_TASKSTACK 任务栈溢出
- \retval OS_ECODE_MALLOCFAIL_TASKNODE 任务节点内存分配失败
- \retval OS_ECODE_MALLOCFAIL_TASKSTACK 任务栈内存分配失败
- */
-#define uStartTask(task, status) \
- sUSV_StartTask(&u_taskhand_##task, status)
-
-/**
- \brief 启动任务并就绪
- \details 启动任务并置任务的初始状态为就绪状态。
- \param[in] task 任务名称
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_OVERFLOW_TASKSTACK 任务栈溢出
- \retval OS_ECODE_MALLOCFAIL_TASKNODE 任务节点内存分配失败
- \retval OS_ECODE_MALLOCFAIL_TASKSTACK 任务栈内存分配失败
- */
-#define uStartTask_Ready(task) \
- uStartTask(task, OS_STATUS_READY)
-
-/**
- \brief 启动任务并阻塞
- \details 启动任务并置任务的初始状态为阻塞状态(阻塞类型为延时阻塞,延时时间为无限长)。
- \param[in] task 任务名称
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_OVERFLOW_TASKSTACK 任务栈溢出
- \retval OS_ECODE_MALLOCFAIL_TASKNODE 任务节点内存分配失败
- \retval OS_ECODE_MALLOCFAIL_TASKSTACK 任务栈内存分配失败
- */
-#define uStartTask_Block(task) \
- uStartTask(task, OS_STATUS_BLOCKED)
-
-/**
- \brief 启动任务并挂起
- \details 启动任务并置任务的初始状态为挂起状态(先前状态为就绪状态)。
- \param[in] task 任务名称
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_OVERFLOW_TASKSTACK 任务栈溢出
- \retval OS_ECODE_MALLOCFAIL_TASKNODE 任务节点内存分配失败
- \retval OS_ECODE_MALLOCFAIL_TASKSTACK 任务栈内存分配失败
- */
-#define uStartTask_Suspend(task) \
- uStartTask(task, OS_STATUS_SUSPENDED)
-
-/** @} */
-
-/**
- \ingroup 任务
- \defgroup 操作任务
- \brief 对任意任务的操作,如 恢复、挂起、删除、设置优先级 等。
- @{
- */
-
-/**
- \brief 清除就绪延时
- \details 清除当前任务的就绪延时,前提是当前任务已在就绪延时中。
- \param 无
- \return 无
- \note 同型服务:
- iClearDelay(),无返回。
- pClearDelay(),无返回。
- */
-#define tClearDelay() sTSV_ClearDelay()
-
-/**
- \brief 恢复任务
- \param[in] task 任务名称
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKNOTSUSPENDED 任务未挂起
- \retval OS_ECODE_TASKSTOPPED 任务已停止
- \retval OS_ECODE_TASKNOTSTARTED 任务未启动/已删除
- \note 同型服务:
- tResumeTask(task),同返回。
- iResumeTask(task),无返回。
- pResumeTask(task),无返回。
- */
-#define uResumeTask(task) \
- sUSV_ResumeTask(u_taskhandle_##task)
-
-/**
- \brief 挂起任务
- \param[in] task 任务名称
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKSUSPENDED 任务已挂起
- \retval OS_ECODE_TASKSTOPPED 任务已停止
- \retval OS_ECODE_TASKNOTSTARTED 任务未启动/已删除
- \note 同型服务:
- tSuspendTask(task),同返回。
- iSuspendTask(task),无返回。
- pSuspendTask(task),无返回。
- */
-#define uSuspendTask(task) \
- sUSV_SuspendTask(u_taskhandle_##task)
-
-/**
- \brief 删除任务
- \param[in] task 任务名称
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKNOTSTARTED 任务未启动/已删除
- \note 同型服务:
- tDeleteTask(task),同返回。
- iDeleteTask(task),无返回。
- pDeleteTask(task),无返回。
- */
-#define uDeleteTask(task) \
- sUSV_DeleteTask(u_taskhandle_##task)
-
-/**
- \brief 设置任务优先级
- \param[in] task 任务名称
- \param[in] npri 新优先级
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKPRIUNCHANGED 任务优先级未改变
- \retval OS_ECODE_TASKSTOPPED 任务已停止
- \retval OS_ECODE_TASKNOTSTARTED 任务未启动/已删除
- \note 同型服务:
- tSetTaskPri(task, npri),同返回。
- iSetTaskPri(task, npri),无返回。
- pSetTaskPri(task, npri),无返回。
- */
-#define uSetTaskPri(task, npri) \
- sUSV_SetTaskPri(u_taskhandle_##task, npri)
-
-/**
- \brief 清除阻塞(状态)
- \details 清除指定任务的阻塞状态并使其就绪。
- \param[in] task 任务名称
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKNOTBLOCKED 任务未阻塞
- \retval OS_ECODE_TASKNOTSTARTED 任务未启动/已删除
- \note 同型服务:
- tClearBlock(task),同返回。
- iClearBlock(task),无返回。
- pClearBlock(task),无返回。
- */
-#define uClearBlock(task) \
- sUSV_ClearBlock(u_taskhandle_##task)
-
-/**
- \ingroup 操作任务
- \defgroup 设置阻塞(时间)
- \brief 设置、修改指定任务的阻塞时间,前提是该任务当前已为阻塞状态。
- \note 理想误差:-1tick。
- \warning 按 毫秒、秒钟、分钟、小时 设置,用户需自己保证时间的有效性(可被系统滴答周期整除)。
- \warning 无限阻塞,仅能通过调用 xSetBlock_tc(task, ~0) 来实现。
- @{
- */
-
-/**
- \brief 设置阻塞-滴答周期
- \param[in] task 任务名称
- \param[in] tc 滴答周期(阻塞时间)
- +0:清除阻塞
- ~0:无限阻塞
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKNOTBLOCKED 任务未阻塞
- \retval OS_ECODE_TASKNOTSTARTED 任务未启动/已删除
- \note 同型服务:
- tSetBlock_tc(task, tc),同返回。
- iSetBlock_tc(task, tc),无返回。
- pSetBlock_tc(task, tc),无返回。
- */
-#define uSetBlock_tc(task, tc) sUSV_SetBlock(u_taskhandle_##task, tc)
-
-/**
- \brief 设置阻塞-毫秒
- \param[in] task 任务名称
- \param[in] ms 毫秒(阻塞时间)
- 0:清除阻塞
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKNOTBLOCKED 任务未阻塞
- \retval OS_ECODE_TASKNOTSTARTED 任务未启动/已删除
- \note 同型服务:
- tSetBlock_ms(task, ms),同返回。
- iSetBlock_ms(task, ms),无返回。
- pSetBlock_ms(task, ms),无返回。
- */
-#define uSetBlock_ms(task, ms) uSetBlock_tc(task, (1000UL * (ms)) / SYSCFG_SYSTICK_CYCLE)
-
-/**
- \brief 设置阻塞-秒钟
- \param[in] task 任务名称
- \param[in] s 秒钟(阻塞时间)
- 0:清除阻塞
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKNOTBLOCKED 任务未阻塞
- \retval OS_ECODE_TASKNOTSTARTED 任务未启动/已删除
- \note 同型服务:
- tSetBlock_s(task, s),同返回。
- iSetBlock_s(task, s),无返回。
- pSetBlock_s(task, s),无返回。
- */
-#define uSetBlock_s(task, s) uSetBlock_ms(task, 1000UL * (s))
-
-/**
- \brief 设置阻塞-分钟
- \param[in] task 任务名称
- \param[in] m 分钟(阻塞时间)
- 0:清除阻塞
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKNOTBLOCKED 任务未阻塞
- \retval OS_ECODE_TASKNOTSTARTED 任务未启动/已删除
- \note 同型服务:
- tSetBlock_m(task, m),同返回。
- iSetBlock_m(task, m),无返回。
- pSetBlock_m(task, m),无返回。
- */
-#define uSetBlock_m(task, m) uSetBlock_s(task, 60UL * (m))
-
-/**
- \brief 设置阻塞-小时
- \param[in] task 任务名称
- \param[in] h 小时(阻塞时间)
- 0:清除阻塞
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKNOTBLOCKED 任务未阻塞
- \retval OS_ECODE_TASKNOTSTARTED 任务未启动/已删除
- \note 同型服务:
- tSetBlock_h(task, h),同返回。
- iSetBlock_h(task, h),无返回。
- pSetBlock_h(task, h),无返回。
- */
-#define uSetBlock_h(task, h) uSetBlock_m(task, 60UL * (h))
-
-/** @} */
-/** @} */
-/**
- \ingroup 任务
- \defgroup 操作自身任务
- \brief 仅适用于对自身任务的操作
- @{
- */
-
-/**
- \brief 禅让任务
- \details 自身任务主动禅让CPU使用权,轮转至下一个相同优先级的任务运行。
- \param 无
- \return 无
- \note 多个相同优先级的任务,通过禅让的方式可实现合作式任务。
- \note 禅让是自身任务主动时间片到期,禅让后任务仍为就绪状态。
- \warning 当开启相同优先级任务的时间片轮转调度时,才支持此服务。
- */
-#define uYieldTasking() su_yield_tasking()
-
-/**
- \brief 设置自身任务优先级
- \param[in] npri 新优先级
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TPLUNCHANGED 优先级未改变
- */
-#define uSetTaskingPri(npri) sUSV_SetTaskPri(s_task_current, npri)
-
-/**
- \brief 挂起自身任务
- \param 无
- \return 错误码(s_ecode_t)
- \note 虽然也返回错误码,但在正常情况下结果一定是成功的,不必查看错误码。
- */
-#define uSuspendTasking() sUSV_SuspendTask(s_task_current)
-
-/**
- \brief 删除自身任务
- \param 无
- \return 错误码(s_ecode_t)
- \note 虽然也返回错误码,但在正常情况下结果一定是成功的,不必查看错误码。
- */
-#define uDeleteTasking() sUSV_DeleteTask(s_task_current)
-
-/**
- \brief 恢复指定任务并挂起自身任务
- \param[in] task 指定任务名称
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval OS_ECODE_TASKNOTREADY 指定任务未就绪
- \retval OS_ECODE_TASKSTOPPED 指定任务已停止
- \retval OS_ECODE_TASKNOTSTARTED 指定任务未启动/已删除
- \note 当返回错误时,指定任务未能恢复为就绪状态,自身任务不会挂起。
- */
-#define uResumeSuspend(task) sUSV_ResumeSuspend(u_taskhandle_##task)
-
-/**
- \ingroup 操作自身任务
- \defgroup 自身任务延时
- \brief 自身任务延时分为阻塞延时和就绪延时。
- \note 阻塞延时:在延时期间,任务会进入阻塞状态,把CPU使用权转让给其它任务。
- \note 就绪延时:在延时期间,任务会维持就绪状态,原地等待延时时间到达,不转让CPU使用权。
- \note 当在任务临界区中,自动选择为就绪延时,否则选择为阻塞延时。
- \note 理想误差:-1tick。
- \warning 按 毫秒、秒钟、分钟、小时 延时,用户需自己保证时间的有效性(可被系统滴答周期整除)。
- \warning 无限延时,仅能通过调用 uDelay_tc(~0) 来实现。
- \warning 不支持在服务层临界区、全局临界区,或关闭总中断时调用。
- @{
- */
-
-/**
- \brief 延时-滴答周期
- \param[in] tc 滴答周期(延时时间)
- ~0:无限延时
- \return 无
- */
-#define uDelay_tc(tc) sUSV_Delay(tc)
-
-/**
- \brief 延时-毫秒
- \param[in] ms 毫秒(延时时间)
- \return 无
- */
-#define uDelay_ms(ms) uDelay_tc((1000UL * (ms)) / SYSCFG_SYSTICK_CYCLE)
-
-/**
- \brief 延时-秒钟
- \param[in] s 秒钟(延时时间)
- \return 无
- */
-#define uDelay_s(s) uDelay_ms(1000UL * (s))
-
-/**
- \brief 延时-分钟
- \param[in] m 分钟(延时时间)
- \return 无
- */
-#define uDelay_m(m) uDelay_s(60UL * (m))
-
-/**
- \brief 延时-小时
- \param[in] h 小时(延时时间)
- \return 无
- */
-#define uDelay_h(h) uDelay_m(60UL * (h))
-/** @} */
-/** @} */
-/** @} */
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 定时中断
- \brief 由用户定时操作,当定时器溢出时,系统将自动恢复/调用与其绑定的任务/钩子并可自动重复定时。
- \note 理想误差:-1tick。
- \warning 按 毫秒、秒钟、分钟、小时 定时,用户需自己保证时间的有效性(可被系统滴答周期整除)。
- @{
- */
-
-/**
- \brief 创建定时中断钩子
- \param[in] tmid 定时器ID
- \param[in] arl 自动重装载设置
- 0:关闭自动重装载
- 1:开启自动重装载
- \param[in] hook 钩子函数
- \param[in] add{...} 附加钩子代码
- \return 无
- */
-#define uCreateHook_TimInt(tmid, arl, hook) \
- sCSV_CreateHook_TimInt(tmid, arl, hook)
-
-/**
- \brief 定时中断-滴答周期
- \param[in] tmid 定时中断定时器ID
- \param[in] tc 滴答周期(定时时间)
- \return 无
- \note 同型服务:
- tTimInt_tc(tmid, tc)。
- iTimInt_tc(tmid, tc)。
- */
-#define uTimInt_tc(tmid, tc) sUSV_TimInt(tmid, tc)
-
-/**
- \brief 定时中断-毫秒
- \param[in] tmid 定时中断定时器ID
- \param[in] ms 毫秒(定时时间)
- \return 无
- \note 同型服务:
- tTimInt_ms(tmid, ms)。
- iTimInt_ms(tmid, ms)。
- */
-#define uTimInt_ms(tmid, ms) uTimInt_tc(tmid, (1000UL * (ms)) / SYSCFG_SYSTICK_CYCLE)
-
-/**
- \brief 定时中断-秒钟
- \param[in] tmid 定时中断定时器ID
- \param[in] s 秒钟(定时时间)
- \return 无
- \note 同型服务:
- tTimInt_s(tmid, s)。
- iTimInt_s(tmid, s)。
- */
-#define uTimInt_s(tmid, s) uTimInt_ms(tmid, 1000UL * (s))
-
-/**
- \brief 定时中断-分钟
- \param[in] tmid 定时中断定时器ID
- \param[in] m 分钟(定时时间)
- \return 无
- \note 同型服务:
- tTimInt_m(tmid, m)。
- iTimInt_m(tmid, m)。
- */
-#define uTimInt_m(tmid, m) uTimInt_s(tmid, 60UL * (m))
-
-/**
- \brief 定时中断-小时
- \param[in] tmid 定时中断定时器ID
- \param[in] h 小时(定时时间)
- \return 无
- \note 同型服务:
- tTimInt_h(tmid, h)。
- iTimInt_h(tmid, h)。
- */
-#define uTimInt_h(tmid, h) uTimInt_m(tmid, 60UL * (h))
-
-/**
- \brief 终止定时中断
- \param[in] tmid 定时中断定时器ID
- \return 无
- \note 同型服务:
- tTimInt_Cancel(tmid)。
- iTimInt_Cancel(tmid)。
- */
-#define uTimInt_Cancel(tmid) uTimInt_tc(tmid, 0)
-
-/**
- \brief 定时中断定时器自动重装载
- \param[in] tmid 定时中断定时器ID
- \param[in] arl 自动重装载设置
- 0:关闭自动重装载
- 1:开启自动重装载
- \return 无
- */
-#define xTimInt_AutoReload(tmid, arl) s_timint_autoreload[tmid] = arl
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 定时查询
- \brief 由用户定时操作,当定时器溢出后,系统在每个滴答周期都会查询用户定义的事件,
- 若事件为真,系统将自动恢复/调用与其绑定的任务/钩子并可自动重复定时。
- \note 理想误差:-1tick。
- \warning 按 毫秒、秒钟、分钟、小时 定时,用户需自己保证时间的有效性(可被系统滴答周期整除)。
- @{
- */
-
-/**
- \brief 创建定时查询钩子
- \param[in] tmid 定时器ID
- \param[in] event 定时查询事件
- \param[in] arl 自动重装载设置
- 0:关闭自动重装载
- 1:开启自动重装载
- \param[in] hook 钩子函数
- \param[in] add{...} 附加钩子代码
- \return 无
- */
-#define uCreateHook_TimQry(tmid, event, arl, hook) \
- sCSV_CreateHook_TimQry(tmid, event, arl, hook)
-
-/**
- \brief 定时查询-滴答周期
- \param[in] tmid 定时查询定时器ID
- \param[in] tc 滴答周期(定时时间)
- \return 无
- \note 同型服务:
- tTimQry_tc(tmid, tc)。
- iTimQry_tc(tmid, tc)。
- */
-#define uTimQry_tc(tmid, tc) sUSV_TimQry(tmid, tc)
-
-/**
- \brief 定时查询-毫秒
- \param[in] tmid 定时查询定时器ID
- \param[in] ms 毫秒(定时时间)
- \return 无
- \note 同型服务:
- tTimQry_ms(tmid, ms)。
- iTimQry_ms(tmid, ms)。
- */
-#define uTimQry_ms(tmid, ms) uTimQry_tc(tmid, (1000UL * (ms)) / SYSCFG_SYSTICK_CYCLE)
-
-/**
- \brief 定时查询-秒钟
- \param[in] tmid 定时查询定时器ID
- \param[in] s 秒钟(定时时间)
- \return 无
- \note 同型服务:
- tTimQry_s(tmid, s)。
- iTimQry_s(tmid, s)。
- */
-#define uTimQry_s(tmid, s) uTimQry_ms(tmid, 1000UL * (s))
-
-/**
- \brief 定时查询-分钟
- \param[in] tmid 定时查询定时器ID
- \param[in] m 分钟(定时时间)
- \return 无
- \note 同型服务:
- tTimQry_m(tmid, m)。
- iTimQry_m(tmid, m)。
- */
-#define uTimQry_m(tmid, m) uTimQry_s(tmid, 60UL * (m))
-
-/**
- \brief 定时查询-小时
- \param[in] tmid 定时查询定时器ID
- \param[in] h 小时(定时时间)
- \return 无
- \note 同型服务:
- tTimQry_h(tmid, h)。
- iTimQry_h(tmid, h)。
- */
-#define uTimQry_h(tmid, h) uTimQry_m(tmid, 60UL * (h))
-
-/**
- \brief 终止定时查询
- \param[in] tmid 定时查询定时器ID
- \return 无
- \note 同型服务:
- tTimQry_Cancel(tmid)。
- iTimQry_Cancel(tmid)。
- */
-#define uTimQry_Cancel(tmid) uTimQry_tc(tmid, ~0)
-
-/**
- \brief 定时查询定时器自动重装载
- \param[in] tmid 定时查询定时器ID
- \param[in] arl 自动重装载设置
- 0:关闭自动重装载
- 1:开启自动重装载
- \return 无
- */
-#define xTimQry_AutoReload(tmid, arl) s_timqry_autoreload[tmid] = arl
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 互斥信号量
- \brief 仅适用于在任务中对任务级公共资源的互斥访问。
- \note 有优先级继承/天花板机制,以抑制优先级反转的发生。
- \note 互斥信号量均支持嵌套使用,最大嵌套深度255,获取与归还必须配对使用。
- \note 如果任务中调用了获取互斥量,应谨慎操作该任务,如操作不当可能会导致获取该互斥量的其它任务死锁。
- @{
- */
-
-/**
- \brief 声明互斥信号量
- \param[in] mut 互斥信号量名称
- \return 无
- */
-#define uExternMut(mut) sCSV_ExternMut(mut)
-
-/**
- \brief 创建互斥信号量
- \param[in] mut 互斥信号量名称
- \return 无
- \warning 创建互斥信号量时,系统将自动赋初值,用户不可赋初值。
- */
-#define uCreateMut(mut) sCSV_CreateMut(mut)
-
-/**
- \brief 获取互斥信号量
- \param[in] mut 互斥信号量名称
- \param[in] tc 滴答周期(超时时间)
- +0:立即返回
- ~0:无限等待
- \return 结果(bool)
- \retval false 失败
- \retval true 成功
- \warning 不支持在临界区中,包括任务临界区、服务层临界区、全局临界区,或关闭总中断时调用。
- */
-#define uTakeMut(mut, tc) sUSV_TakeMut(mut, tc)
-
-/**
- \brief 归还互斥信号量
- \param[in] mut 互斥信号量名称
- \return 无
- */
-#define uBackMut(mut) sUSV_BackMut(mut)
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 二值信号量
- \brief 常用于事件同步、互斥访问(中断与任务之间的互斥)。
- @{
- */
-
-/**
- \brief 声明二值信号量
- \param[in] bin 二值信号量名称
- \return 无
- */
-#define uExternBin(bin) sCSV_ExternBin(bin)
-
-/**
- \brief 创建二值信号量
- \param[in] bin 二值信号量名称
- \param[in] init 二值信号量初始值
- false(0):已上锁,无法立即成功获取
- true(1) :已解锁,可以立即成功获取
- \return 无
- \note 当用于互斥访问时,初始值应为true。
- */
-#define uCreateBin(bin, init) sCSV_CreateBin(bin, init)
-
-/**
- \brief 上锁二值信号量
- \details 用于终止线程的无限同步。
- \param[in] bin 二值信号量名称
- \return 无
- \note 同型服务:
- tLockBin(bin)。
- iLockBin(bin)。
- pLockBin(bin)。
- */
-#define uLockBin(bin) bin.binary = false
-
-/**
- \brief 等待二值信号量
- \details 在指定的超时时间内等待二值信号量为真,适用于任务的无限同步,与获取的区别是不上锁。
- \param[in] bin 二值信号量名称
- \param[in] tc 滴答周期(超时时间)
- +0:立即返回
- ~0:无限等待
- \return 结果(bool)
- \retval false 失败
- \retval true 成功
- \warning 不支持在临界区中,包括任务临界区、服务层临界区、全局临界区,或关闭总中断时调用。
- */
-#define uWaitBin(bin, tc) sUSV_WaitBin(bin, tc)
-
-/**
- \brief 给予二值信号量
- \details 专用于事件同步。
- \param[in] bin 二值信号量名称
- \return 无
- \note 同型服务:
- tGiveBin(bin)。
- iGiveBin(bin)。
- pGiveBin(bin)。
- */
-#define uGiveBin(bin) sUSV_GiveBin(bin)
-
-/**
- \brief 获取二值信号量
- \details 用于事件同步或互斥访问。
- \param[in] bin 二值信号量名称
- \param[in] tc 滴答周期(超时时间)
- +0:立即返回
- ~0:无限等待
- \return 结果(bool)
- \retval false 失败
- \retval true 成功
- \note 同型服务:
- tTakeBin(bin)。
- iTakeBin(bin)。
- \warning 任务中获取,不支持在临界区中,包括任务临界区、服务层临界区、全局临界区,或关闭总中断时调用。
- */
-#define uTakeBin(bin, tc) sUSV_TakeBin(bin, tc)
-
-/**
- \brief 归还二值信号量
- \details 专用于互斥访问。
- \param[in] bin 二值信号量名称
- \return 无
- \note 同型服务:
- tBackBin(bin)。
- iBackBin(bin)。
- */
-#define uBackBin(bin) uGiveBin(bin)
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 计数信号量
- \brief 常用于事件同步、重入访问(资源管理),是唯一能够实现并发事件同步的手段。
- @{
- */
-
-/**
- \brief 声明计数信号量
- \param[in] sem 计数信号量名称
- \return 无
- */
-#define uExternSem(sem) sCSV_ExternSem(sem)
-
-/**
- \brief 创建计数信号量
- \param[in] sem 计数信号量名称
- \param[in] init 计数信号量初始值
- \param[in] max 计数信号量最大值
- \return 无
- */
-#define uCreateSem(sem, init, max) sCSV_CreateSem(sem, init, max)
-
-/**
- \brief 给予计数信号量
- \param[in] sem 计数信号量名称
- \return 无
- \note 同型服务:
- tGiveSem(sem)。
- iGiveSem(sem)。
- */
-#define uGiveSem(sem) sUSV_GiveSem(sem)
-
-/**
- \brief 获取计数信号量
- \param[in] sem 计数信号量名称
- \param[in] tc 滴答周期(超时时间)
- +0:立即返回
- ~0:无限等待
- \return 结果(bool)
- \retval false 失败
- \retval true 成功
- \note 同型服务:
- tTakeSem(sem)。
- \warning 任务中获取,不支持在临界区中,包括任务临界区、服务层临界区、全局临界区,或关闭总中断时调用。
- */
-#define uTakeSem(sem, tc) sUSV_TakeSem(sem, tc)
-
-/**
- \brief 归还计数信号量
- \param[in] sem 计数信号量名称
- \return 无
- \note 同型服务:
- tBackSem(sem)。
- */
-#define uBackSem(sem) uGiveSem(sem)
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 事件标志组
- \brief 适用于对一类事件的事件同步。
- \details 某一类事件,它的发生线程可能会有多个,均同步至同一个事件处理线程中统一处理该类事件。
- \note 名词解释
- 组名:标志组的名称
- 位名:标志位的名称
- 空位:空标志位
- \note 查询标志位:任务、滴答、中断中,均直接查询。
- @{
- */
-
-/**
- \brief 声明标志组
- \param[in] group 组名
- \param[in] bits 定义各标志位,分号间隔
- \return 无
- */
-#define uExternFlagGroup(group, bits) sCSV_ExternFlagGroup(group, bits)
-
-/**
- \brief 定义标志位
- \param[in] bit 位名
- \return 无
- */
-#define uDefFlagBit(bit) sDefBitField(bit)
-
-/**
- \brief 定义空位
- \param[in] nvb 空位的数量
- \return 无
- */
-#define uDefVoidBits(nvb) sDefVoidBits(nvb)
-
-/**
- \brief 创建标志组
- \param[in] group 组名
- \param[in] add={...} 附加代码(赋初值)
- \return 无
- */
-#define uCreateFlagGroup(group) sCSV_CreateFlagGroup(group)
-
-/**
- \brief 等待标志组
- \param[in] group 组名
- \param[in] tc 滴答周期(超时时间)
- +0:立即返回
- ~0:无限等待
- \return 结果(bool)
- \retval false 失败
- \retval true 成功
- \warning 不支持在临界区中,包括任务临界区、服务层临界区、全局临界区,或关闭总中断时调用。
- \warning 事件的各个发生线程中设置标志位后,应调用 uClearBlock(task) 来手动完成事件同步。
- */
-#define uWaitFlagGroup(group, tc) sUSV_WaitFlagGroup(group, tc)
-
-/**
- \brief 查询标志组
- \param[in] group 组名
- \return 结果(bool)
- \retval false 失败
- \retval true 成功
- \note 同型服务:
- tQueryFlagGroup(group)。
- iQueryFlagGroup(group)。
- */
-#define uQueryFlagGroup(group) sUSV_QueryFlagGroup(group)
-
-/**
- \brief 清除标志组
- \param[in] group 组名
- \return 无
- \note 同型服务:
- tClearFlagGroup(group)。
- iClearFlagGroup(group)。
- */
-#define uClearFlagGroup(group) sUSV_ClearFlagGroup(group)
-
-/**
- \brief 设置标志位
- \param[in] group 组名
- \param[in] bit 位名
- \return 无
- \note 同型服务:
- tSetFlagBit(group, bit)。
- iSetFlagBit(group, bit)。
- */
-#define uSetFlagBit(group, bit) uSetFlagBits(group, 1) bit)
-
-/**
- \brief 清除标志位
- \param[in] group 组名
- \param[in] bit 位名
- \return 无
- \note 同型服务:
- tClearFlagBit(group, bit)。
- iClearFlagBit(group, bit)。
- */
-#define uClearFlagBit(group, bit) uClearFlagBits(group, 1) bit)
-
-/**
- \brief 设置多标志位
- \param[in] group 组名
- \param[in] nbit 标志位的数量
- \param[in] add...) 各位名,逗号间隔
- \return 无
- \note 同型服务:
- tSetFlagBits(group, nbit)。
- iSetFlagBits(group, nbit)。
- */
-#define uSetFlagBits(group, nbit) sUSV_WriteFlagBits(group, true, nbit)
-
-/**
- \brief 清除多标志位
- \param[in] group 组名
- \param[in] nbit 标志位的数量
- \param[in] add...) 各位名,逗号间隔
- \return 无
- \note 同型服务:
- tClearFlagBits(group, nbit)。
- iClearFlagBits(group, nbit)。
- */
-#define uClearFlagBits(group, nbit) sUSV_WriteFlagBits(group, false, nbit)
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 飞信
- \brief 原子类型、传输数据。
- \details 仅使用一个变量,同时即是消息,又是新消息标志。
- 飞信为0时,表示无消息;飞信非0时,表示有消息;
- 因此:
- \warning 用户传输的有效消息必须为真值。
- \note 架构 数据类型
- 8051 uint8_t
- 80251 uint16_t
- Arm32 uint32_t
- 通用别名 m_fetion_t
- @{
- */
-
-/**
- \brief 声明信箱
- \param[in] tbox 信箱名称
- \return 无
- */
-#define uExternTionbox(tbox) sCSV_ExternTionbox(tbox)
-
-/**
- \brief 创建信箱
- \param[in] tbox 信箱名称
- \return 无
- */
-#define uCreateTionbox(tbox) sCSV_CreateTionbox(tbox)
-
-/**
- \brief 接收飞信
-
- 别名
-
- uRecvFet
- \param[in] tbox 信箱名称
- \param[in] tc 滴答周期(超时时间)
- +0:立即返回
- ~0:无限等待
- \return 飞信(m_fetion_t)
- \retval false 无飞信
- \note 同型服务:
- tRecvFetion(tbox) / tRecvFet。
- iRecvFetion(tbox) / iRecvFet。
- \warning 任务中接收,不支持在临界区中,包括任务临界区、服务层临界区、全局临界区,或关闭总中断时调用。
- */
-#define uRecvFetion(tbox, tc) sUSV_RecvFetion(tbox, tc)
-
-/**
- \brief 发送飞信
-
- 别名
-
- uSendFet
- \param[in] tbox 信箱名称
- \param[in] tion 飞信
- \return 无
- \note 同型服务:
- tSendFetion(tbox, tion) / tSendFet。
- iSendFetion(tbox, tion) / iSendFet。
- */
-#define uSendFetion(tbox, tion) sUSV_SendFetion(tbox, tion)
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 消息邮箱
- \brief 任意类型、传输指针。
- @{
- */
-
-/**
- \brief 声明邮箱
- \param[in] mbox 邮箱名称
- \return 无
- */
-#define uExternMailbox(mbox) sCSV_ExternMailbox(mbox)
-
-/**
- \brief 创建邮箱
- \param[in] mbox 邮箱名称
- \return 无
- */
-#define uCreateMailbox(mbox) sCSV_CreateMailbox(mbox)
-
-/**
- \brief 接收邮件
- \param[in] mbox 邮箱名称
- \param[in] tc 滴答周期(超时时间)
- +0:立即返回
- ~0:无限等待
- \return 邮件指针(void *)
- \retval NULL 无邮件
- \note 同型服务:
- tRecvMail(mbox)。
- iRecvMail(mbox)。
- \warning 任务中接收,不支持在临界区中,包括任务临界区、服务层临界区、全局临界区,或关闭总中断时调用。
- */
-#define uRecvMail(mbox, tc) sUSV_RecvMail(mbox, tc)
-
-/**
- \brief 发送邮件
- \param[in] mbox 邮箱名称
- \param[in] mail 邮件指针
- \return 无
- \note 同型服务:
- tSendMail(mbox, mail)。
- iSendMail(mbox, mail)。
- */
-#define uSendMail(mbox, mail) sUSV_SendMail(mbox, mail)
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 消息队列
- \brief 任意类型、传输指针,是唯一能够实现并发消息同步的手段。
- \details 消息队列包括静态队列和动态队列。
- 静态队列:收发消息的效率高,队列占用固定的内存;
- 动态队列:收发消息的效率低,接收消息后,队列内存可被回收。
- \note 每个队列,用户应当自己明确消息的类型和size,此事与OS无关。
- @{
- */
-
-/**
- \brief 声明静态队列
- \param[in] que 队列名称
- \return 无
- */
-#define uExternQueue_Static(que) sCSV_ExternQueue_Static(que)
-
-/**
- \brief 声明动态队列
- \param[in] que 队列名称
- \return 无
- */
-#define uExternQueue_Dynamic(que) sCSV_ExternQueue_Dynamic(que)
-
-/**
- \brief 创建静态队列
- \param[in] que 队列名称
- \param[in] mode 传输模式
- 0:FIFO(先入先出)
- 1:LIFO(后入先出)
- \param[in] len 队列长度
- \return 无
- */
-#define uCreateQueue_Static(que, mode, len) sCSV_CreateQueue_Static(que, mode, len)
-
-/**
- \brief 创建动态队列
- \param[in] que 队列名称
- \param[in] mode 传输模式
- 0:FIFO(先入先出)
- 1:LIFO(后入先出)
- \param[in] len 队列长度
- \return 无
- */
-#define uCreateQueue_Dynamic(que, mode, len) sCSV_CreateQueue_Dynamic(que, mode, len)
-
-/**
- \brief 接收消息
- \param[in] que 队列名称
- \param[in] tc 滴答周期(超时时间)
- +0:立即返回
- ~0:无限等待
- \return 消息指针(void *)
- \retval NULL 无消息
- \note 同型服务:
- tRecvMsg(que)。
- iRecvMsg(que)。
- \warning 任务中接收,不支持在临界区中,包括任务临界区、服务层临界区、全局临界区,或关闭总中断时调用。
- \warning 中断中接收,队列只能是静态队列,消息缓存只能是静态缓存。
- */
-#define uRecvMsg(que, tc) sUSV_RecvMsg(que, tc)
-
-/**
- \brief 发送消息
- \param[in] que 队列名称
- \param[in] msg 消息指针
- \return 错误码(s_ecode_t)
- \retval OS_ECODE_NOERROR 无错误
- \retval ECODE_OVERFLOW_MSGQUEUE 消息队列溢出
- \retval ECODE_MALLOCFAIL_MSGNODE 消息节点内存分配失败
- \note 同型服务:
- tSendMsg(que, msg),同返回。
- iSendMsg(que, msg),无返回。
- \warning 中断中发送,消息缓存只能是静态缓存。
- */
-#define uSendMsg(que, msg) sUSV_SendMsg(que, msg)
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 全局变量访问
- \brief 由CosyOS内核提供服务支持,可实现在任务、滴答、中断中,对非原子
- 全局变量的线程安全访问,同时不会破坏零中断延迟。
- \note 原子型:
- 滴答中:直接->读访问、写访问、自运算。
- 任务中:直接->读访问、写访问,内核上锁后->自运算。
- 中断中:直接->读访问,调用服务->写访问、自运算。
- \note 非原子型:
- 滴答中:直接->读访问、写访问、自运算。
- 任务中:内核上锁后->读访问、写访问、自运算。
- 中断中:不可以读访问,调用服务->写访问、自运算。
- \note 不可以读访问:
- 建议挂起到PendSV中或同步至任务中处理事件。
- @{
- */
-
-/**
- \brief 写全局变量
- \param[in] gv 全局变量名称
- \param[in] lv 局部变量名称
- \return 无
- */
-#define iWriteGVar(gv, lv) sPSV_WriteGVar((void *)&gv, (void *)&lv, sizeof(gv))
-
-/**
- \brief 写全局数组
- \param[in] gp 全局数组指针
- \param[in] lp 局部数组指针
- \param[in] size 拷贝的大小(字节数)
- \return 无
- */
-#define iWriteGAry(gp, lp, size) sPSV_WriteGVar(gp, lp, size)
-
-/**
- \brief 写全局字符串
- \param[in] gs 全局字符串指针
- \param[in] ls 局部字符串指针
- \return 无
- */
-#define iWriteGStr(gs, ls) sPSV_WriteGVar(gs, ls, 0)
-
-/**
- \brief 挂起服务调用
- \param[in] fp 函数指针
- \return 无
- \note 适用于全局变量自运算、事件处理等。
- */
-#define iPendSVC(fp) sPSV_PendSVC(fp)
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 软件RTC
- \brief 适用于没有硬件RTC的物联网终端设备。
- \note 实际应用中,可每间隔一段时间(如一小时)同步一次网络时间,以校正误差。
- @{
- */
-
-/**
- \brief 获取时间
- \param[in] t 本地时间的指针(s_rtc_ts *)
- \return t(void *)
- \note 同型服务:
- tGetTime(t)。
- */
-#define uGetTime(t) sUSV_GetTime(t)
-
-/**
- \brief 设置时间
- \param[in] t 本地时间的指针(s_rtc_ts *)
- \return 无
- \note 同型服务:
- tSetTime(t)。
- iSetTime(t)。
- */
-#define uSetTime(t) sUSV_SetTime(t)
-
-/** @} */
-
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 动态内存
- @{
- */
-
-/**
- \ingroup 动态内存
- \defgroup 进程内存
- \brief 以进程为单位初始化内存池,各进程独享自己的内存池。
- @{
- */
-
-/**
- \brief malloc
- \details 在进程内存池或堆中分配一块内存。
- \param[in] size 内存块的大小(字节数)
- \return 分配的指针(void _MALLOC_MEM_ *)
- \retval NULL 内存分配失败
- */
-#define uMalloc(size) sUSV_Malloc(size)
-
-/**
- \brief calloc
- \details 在进程内存池或堆中连续分配多块内存。
- \param[in] nmemb 内存块的数量
- \param[in] size 内存块的大小(字节数)
- \return 分配的指针(void _MALLOC_MEM_ *)
- \retval NULL 内存分配失败
- */
-#define uCalloc(nmemb, size) sUSV_Calloc(nmemb, size)
-
-/**
- \brief realloc
- \details 重新分配内存。
- \param[in] p 预重分配的指针
- \param[in] size 预重分配的大小(字节数)
- \return 分配的指针(void _MALLOC_MEM_ *)
- \retval NULL 内存分配失败
- */
-#define uRealloc(p, size) sUSV_Realloc(p, size)
-
-/**
- \brief free
- \param[in] p 释放的指针
- \return 无
- */
-#define uFree(p) sUSV_Free(p)
-
-/** @} */
-
-/**
- \ingroup 动态内存
- \defgroup 线程内存
- \brief 以线程为单位初始化内存池,各线程独享自己的内存池。
- \note 线程内存的分配效率远高于进程内存,因为每一次调用uTalloc都是在自己的线程内存池中直接按序分配内存。
- \note 在某线程中,如果需要多次动态内存分配,可考虑采用线程内存以提高性能。
- \note 线程内存的应用法则:当所有uTalloc的内存都可以释放时,再一次性释放所有内存(线程内存池)。
- @{
- */
-
-/**
- \brief 创建线程内存池
- \details 实为定义变量(线程内存控制块),C89模式时可考虑在线程的开始处创建。
- \param 无
- \return 无
- */
-#define uCreateMempool() sCSV_CreateMempool()
-
-/**
- \brief 初始化线程内存池
- \details 实质上是通过调用malloc,从进程内存池或堆中分配一块内存来做为线程内存池。
- \param[in] size 线程内存池的大小(字节数)
- \return 结果(bool)
- \retval false 失败
- \retval true 成功
- */
-#define uInitMempool(size) sUSV_InitMempool(size)
-
-/**
- \brief 线程内存分配
- \details 在线程内存池中分配一块内存。
- \param[in] size 内存块的大小(字节数)
- \return 分配的指针(void _MALLOC_MEM_ *)
- \retval NULL 内存分配失败
- */
-#define uTalloc(size) sUSV_Talloc(size)
-
-/**
- \brief 释放线程内存池
- \param 无
- \return 无
- */
-#define uFreeMempool() sUSV_FreeMempool()
-
-/** @} */
-/** @} */
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 临界区
- \note CosyOS的临界区包括任务临界区、服务层临界区、全局临界区,均支持嵌套使用。
- 各临界区之间也可随意互相嵌套,但通常推荐在任务临界区中嵌套服务层临界区,
- 在服务层临界区中嵌套全局临界区,以逐步扩大保护范围。
- @{
- */
-
-/**
- \ingroup 临界区
- \defgroup 调度锁(任务临界区)
- \brief 通过上锁任务调度器的方式,来实现任务级的临界区保护,仅支持在任务中调用。
- \note 仅是上锁任务调度器,不关闭系统中断(SysTick、PendSV),所以即使是长时间的、
- 对大段的任务级公共资源的独占访问,也不会影响系统节拍和内核服务的执行。
- \note 调度锁支持嵌套使用,最大嵌套深度255,调度上锁与调度解锁必须配对使用。
- \note 调度锁不会破坏零中断延迟,当需要任务级的临界区保护时,可以考虑。
- @{
- */
-
-/**
- \brief 调度上锁(进入任务临界区)
- \param 无
- \return 无
- */
-#define uScheduleLock() su_schedule_locks()
-
-/**
- \brief 调度解锁(退出任务临界区)
- \param 无
- \return 无
- */
-#define uScheduleUnlock() su_schedule_unlocks()
-
-/** @} */
-
-/**
- \ingroup 临界区
- \defgroup 内核锁(服务层临界区)
- \brief OS内核级的临界区保护,会关闭系统中断(SysTick、PendSV),仅支持在任务中调用。
- \note 由SysTick、PendSV、内核锁,共同组成大的服务层临界区,当处理得当时,可实现全局的临界区保护。
- 实现过程:
- 滴答中:直接访问即可。
- 任务中:内核上锁后访问。
- 中断中:采用中断挂起服务。
- \note 内核锁支持嵌套使用,最大嵌套深度255,内核上锁与内核解锁必须配对使用。
- \note 内核锁不会破坏零中断延迟,当需要全局的临界区保护时,应首先予以考虑。
- \note 内核锁应遵循快进快出的原则,临界段代码的执行时间应远小于系统滴答周期,
- 否则可能会导致丢失系统节拍、延误其它内核服务的执行,对系统实时性造成不利影响。
- \note 当在任务中访问非原子全局变量时,可采用内核锁实现全局的临界区保护。
- @{
- */
-
-/**
- \brief 内核上锁(进入服务层临界区)
- \param 无
- \return 无
- */
-#define uKernelLock() su_kernel_locks()
-
-/**
- \brief 内核解锁(退出服务层临界区)
- \param 无
- \return 无
- */
-#define uKernelUnlock() su_kernel_unlocks()
-
-/** @} */
-
-/**
- \ingroup 临界区
- \defgroup 中断锁(全局临界区)
- \brief 全局的临界区保护,通常会关闭总中断,支持在任意处调用。
- \note CosyOS内核中从来不会关闭总中断,提供此项服务只是为了便于用户
- 对全局公共资源和程序过程的保护。
- \note 全局临界区会破坏零中断延迟,应做为最后的选项,慎重使用。
- @{
- */
-#if MCUCFG_ISA != __ARM__
-/**
- \ingroup 全局临界区
- \defgroup 操作-EA
- \note 支持嵌套使用,最大嵌套深度255,进入临界区与退出临界区必须配对使用。
- @{
- */
-
-/**
- \brief 进入全局临界区
- \param 无
- \return 无
- */
-#define xDisableIRQ() mxDisableIRQ()
-
-/**
- \brief 退出全局临界区
- \param 无
- \return 无
- */
-#define xResumeIRQ() mxResumeIRQ()
-
-/** @} */
-#else
-/**
- \ingroup 全局临界区
- \defgroup 操作-PRIMASK
- \note 支持嵌套使用,进入临界区与退出临界区必须配对使用。
- @{
- */
-
-/**
- \brief 进入全局临界区
- \param 无
- \return oirq PRIMASK上一次的值(uint32_t类型)
- */
-#define xDisableIRQ() mxDisableIRQ()
-
-/**
- \brief 退出全局临界区
- \param[in] oirq PRIMASK上一次的值(uint32_t类型)
- \return 无
- */
-#define xResumeIRQ(oirq) mxResumeIRQ(oirq)
-
-/** @} */
-
-/**
- \ingroup 全局临界区
- \defgroup 操作-BASEPRI
- \note 使用条件:
- 1、MCU必须有 BASEPRI 寄存器;
- 2、MCU配置中,系统中断配置必须选择 TIMn_IRQHandler + XXX_IRQHandler。
- \note 使用说明:
- 1、关于npri,例如中断优先级分组选择 NVIC_PriorityGoup_4,那么中断优先级从高到低为 0~15。
- 如果需要掩蔽(3~15)的中断,npri应输入3。
- 2、支持嵌套使用,进入临界区与退出临界区必须配对使用。
- 3、嵌套使用时,仅能逐步扩大掩蔽范围(npri越来越小),否则新的掩蔽范围不会生效(将维持上一次的掩蔽范围)。
- @{
- */
-
-/**
- \brief 进入全局临界区
- \param[in] npri 掩蔽范围的最高优先级的优先级号(uint32_t类型)
- \return opri BASEPRI的原值(uint32_t类型)
- */
-#define xMaskingPRI(npri) mxMaskingPRI(npri)
-
-/**
- \brief 退出全局临界区
- \param[in] opri BASEPRI的原值(uint32_t类型)
- \return 无
- */
-#define xResumePRI(opri) mxResumePRI(opri)
-
-/** @} */
-#endif
-/** @} */
-/** @} */
-/**************************************************************************//**
- \ingroup CosyOS_用户API
- \defgroup 杂项
- @{
- */
-
-/**
- \ingroup 杂项
- \defgroup DEBUG
- \brief DEBUG接口,串口发送与接收的实现。
- @{
- */
-
-/**
- \brief DEBUG发送完成
- \param 无
- \return 无
- */
-#define xDebugSend_Complete() s_sign_debugsend = true
-
-/**
- \brief DEBUG接收解析
- \param[in] p 接收缓存的开始指针
- \param[in] len 接收数据包的长度
- \return 无
- */
-#define xDebugRecv_Handler(p, len) \
-do{ \
- s_debug_recvptr = p; \
- s_debug_recvlen = len; \
-}while(false)
-
-/** @} */
-
-/**
- \ingroup 杂项
- \defgroup 时间单位转换
- \brief 把其它单位的时间转换为滴答周期。
- @{
- */
-
-/**
- \brief 毫秒转换为滴答周期
- \param[in] ms 毫秒
- \return 滴答周期
- */
-#define xTick_ms(ms) ((1000UL * (ms)) / SYSCFG_SYSTICK_CYCLE)
-
-/**
- \brief 秒钟转换为滴答周期
- \param[in] s 秒钟
- \return 滴答周期
- */
-#define xTick_s(s) xTick_ms(1000UL * (s))
-
-/**
- \brief 分钟转换为滴答周期
- \param[in] m 分钟
- \return 滴答周期
- */
-#define xTick_m(m) xTick_s(60UL * (m))
-
-/**
- \brief 小时转换为滴答周期
- \param[in] h 小时
- \return 滴答周期
- */
-#define xTick_h(h) xTick_m(60UL * (h))
-
-/** @} */
-
-/**
- \brief 触发PendSV
- \details 在用户中断中,当采用中断挂起服务FLAG队列执行服务时,用户在设置标志位后,
- 需手动触发PendSV,而后在 pendsv_hook() 中执行服务。
- \param 无
- \return 无
- */
-#define iPendSV_Set() mPendSV_Set()
-
-/** @} */
-
-
-/** @} */
-#endif