# CosyOS
**Repository Path**: baoyoubing/cosyos
## Basic Information
- **Project Name**: CosyOS
- **Description**: CosyOS是一款来自中国的开源实时操作系统,从经典的8051内核,到流行的Arm Cortex-M内核,均可实现全局不关总中断、零中断延迟,适用于对系统实时性及中断响应速度有较高要求的场合。QQ交流群:303421780.
- **Primary Language**: C
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 97
- **Created**: 2025-03-17
- **Last Updated**: 2025-03-17
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
 _温馨舒适的操作系统、零中断延迟的操作系统_ :grey_exclamation:




[](https://gitee.com/cosyos/cosyos/stargazers)
[](https://gitee.com/cosyos/cosyos/members)
* CosyOS QQ交流群:303421780.
### 公告
* CosyOS-III V1.0.9,紧急修复了之前版本的一个BUG(任务优先级数在64级以上时运行异常),请及时更新!
* CosyOS-III V1.0.4,已支持 Arm Compiler 6(armclang),工程中需包含 cmsis_armclang.h;
Arm Compiler 5(armcc),需包含 cmsis_armcc.h。
* CosyOS 又取得新突破,现已升级至 **CosyOS-III**,说明文档持续更新中。。。
原有 CosyOS-I、CosyOS-II 停止更新维护,但仍提供技术支持。
### 序言
* 近年来,随着RTOS的普及及在嵌入式设备中的广泛应用,以关闭总中断等方式来保护临界段所带来的危害性(丢失响应、处理延误)正日益凸显出来,其中以高速通讯接收丢帧、高速捕获丢失脉冲等中断丢失响应现象最为紧要和普遍。有些RTOS关闭总中断可能过于频繁,且未能提供“系统最大关闭总中断时间”等核心关键参数,实时性有待商榷。
* 随着时代的发展、科技的进步,零中断延迟已经成为可能,RTOS正悄然的面临着一场时代的变革... ...
* 2023年,CosyOS 应运而生!
### 简介
CosyOS是一款来自中国的开源实时操作系统,从经典的8051内核,到流行的Arm Cortex-M内核,均可实现全局不关总中断、零中断延迟,适用于对系统实时性及中断响应速度有较高要求的场合。CosyOS以极具浪漫主义色彩的宏定义,实现了高度的面向对象及良好的易用性。
### CosyOS-实时运行模型
* **用户中断层** [用户中断按中断优先级实时抢占、零中断延迟]
* 中断本地服务 -> 执行
* 中断挂起服务_FIFO -> 装载
* 中断挂起服务_FLAG -> 设置
* **内核服务层**
* **SysTick** [minpri]
* 软件定时器计数
* 恢复定时任务
* 调用定时钩子、滴答钩子 [滴答服务 -> 执行]
* **PendSV** [minpri]
* 中断挂起服务_FIFO -> 执行
* 中断挂起服务_FLAG -> 执行
* 任务调度切换
* **内核锁** [关闭 SysTick/PendSV]
* 任务服务 -> 执行
* **任务层** [下方示例为仅抢占式调度并启用DEBUG]
* 系统保留 [maxpri]
* Debugger [maxpri-1]
* Taskmgr [maxpri-2]
* Starter [maxpri-3]
* 一般用户任务 [maxpri-4 ~ minpri+1:1]
* 系统空闲任务 [minpri:0]
### 零中断延迟
* 由RTOS保护临界段而导致的中断响应时间延迟为零。换言之,中断响应时间不受RTOS影响,与裸机编程是一样的。
### 零中断延迟基本原理
* 内核服务层中,SysTick、PendSV、内核锁,三者间是互斥访问的。换言之,整个服务层是一个大临界区(服务层临界区)。
* 所有内核服务(中断本地服务除外),均在 **“服务层临界区”** 执行,从而保证服务的 **“操作流”** 不会被打断。
* 中断本地服务,根据各自特征单独处理。
### 初体验
下面,让我们来初步体验一下CosyOS的易用性。
**CosyOS-III 一步创建任务示例:**
| 任务名称 | 任务优先级 | 任务栈大小 | 安全运行时 | 保留 |
|------------|-------|-------|-------|-------|
| task1 | 1级 | 128字节 | 0,无限长 | 0 |
| task2 | 2级 | 256字节 | 9个时间片 | 0 |
注:**安全运行时**是CosyOS的安全关键技术,可防止某任务长期独占或超时使用处理器。
```c
# 静态创建 task1
uCreateTask(task1, 1, 128, 0, 0)
{
while(1){
/* 任务代码 */
}
}
# 动态创建 task2
dCreateTask(task2, 2, 256, 9, 0)
{
while(1){
/* 任务代码 */
}
}
# 启动钩子
void start_hook(void)
{
uStartTask(task1, 0); // 启动 task1,初始状态为就绪状态
uStartTask(task2, 1); // 启动 task2,初始状态为挂起状态
}
```
您有没有眼前一亮呢?CosyOS创建任务竟如此简单,通过调用API并输入各项参数,而后直接写任务代码即可。下一步就是在启动钩子中启动任务,任务便可参与调度并运行了。任务静态创建与动态创建的相互转换也极为便利,API名称中,仅需 “u”改“d” 或 “d”改“u” 即可。
### 突破创新
* 所有支持内核均可实现全局不关总中断、**零中断延迟**,保证了用户中断的实时响应
* 领先的零中断延迟技术,率先应用于 8051、Cortex-M0 等处理器,在世界上尚属首例
* **任务就绪表**,采用 零/一/二级位图,保证了抢占式任务调度的硬实时性
* **三维链表**(独家技术),可显著的减少操作链表,服务执行速度更快
* 创新的**协作式调度**,仅作用于相同优先级的任务,具有高度的实用价值
* 独家技术实现系统服务的可重入,使51彻底摆脱可重入栈、全面提速
* **定时服务(软件定时器中断)**,包括任务和钩子,任务优先级都可由用户灵活配置
* **事件标志组**,对标志组和标志位的访问通过组名和位名来实现,极大的方便了标志组的应用
* **全局变量访问**,支持在任意任务和中断中对全局变量的安全访问,而不必担心重入的发生
* **安全关键技术**,有多项安全关键技术,如中断挂起服务空间隔离、安全运行时,可靠性高
### 因循守旧
* 完全开源的免版税、确定性的RTOS
* 任务调度,支持 不同优先级“抢占式调度”,相同优先级“协作式调度”或“时间片轮转调度”
* 用户任务数量不限,最多支持256级任务优先级
* 简洁高效的代码,极低的硬件资源占用,使CosyOS可轻松应用于各种小型MCU
* 任务管理器,实时监控各任务的运行情况,协助开发者急时发现设计中存在的问题

—————— CosyOS-III 任务管理器 ——————
### 支持内核
CosyOS 现支持 8051、80251、Cortex-M 等内核,未来会陆续添加对其它内核的支持。
### 编译环境
CosyOS 是在 keil C51、C251、MDK-Arm 编译器下开发的,对其支持最好,
未来会陆续优化调整对其它编译器的支持。
### 文件说明
| 名称 | 描述 |
|--------|------------------------------|
| **System** | **内核文件**
ur_api.h:用户API(含doxygen注释)
ur_eapi.h:用户API扩展
sv_❃.c/h:内核服务文件
os_❃.c/h:其它内核文件 |
| **Config** | **配置文件**
syscfg.h:系统配置文件
mcucfg_❃.h:MCU配置文件 |
| **Hook** | **钩子文件**
CosyOS 已经为用户创建好了六个系统钩子函数,
分别位于各自的同名文件中,用户直接写代码即可。 |
| **Port** | **移植文件**
|
### 文档中心
#### [CosyOS原理与应用](https://gitee.com/cosyos/cosyos/blob/master/%E8%AF%B4%E6%98%8E%E6%96%87%E6%A1%A3/CosyOS%E5%8E%9F%E7%90%86%E4%B8%8E%E5%BA%94%E7%94%A8.md)
#### [开发流程](https://gitee.com/cosyos/cosyos/blob/master/%E8%AF%B4%E6%98%8E%E6%96%87%E6%A1%A3/%E5%BC%80%E5%8F%91%E6%B5%81%E7%A8%8B.md)
#### [API用户参考手册](https://gitee.com/cosyos/cosyos/blob/master/%E8%AF%B4%E6%98%8E%E6%96%87%E6%A1%A3/CosyOS-II%20API%20%E7%94%A8%E6%88%B7%E5%8F%82%E8%80%83%E6%89%8B%E5%86%8C.rar)
### 参与贡献
1. Fork 本仓库
2. 新建 Feat_xxx 分支
3. 提交代码
4. 新建 Pull Request