# 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 ![logo](images/logo.png) _温馨舒适的操作系统、零中断延迟的操作系统_ :grey_exclamation: ![Author](https://img.shields.io/badge/Author-迟凯峰-red?style=flat-square) ![languge](https://img.shields.io/badge/languge-C、Asm-blue) ![license](https://img.shields.io/badge/license-Apache2.0-brightgreen.svg) ![version](https://img.shields.io/badge/version-1.1.5-green) [![star](https://gitee.com/cosyos/cosyos/badge/star.svg?theme=dark)](https://gitee.com/cosyos/cosyos/stargazers) [![fork](https://gitee.com/cosyos/cosyos/badge/fork.svg?theme=dark)](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 * 任务管理器,实时监控各任务的运行情况,协助开发者急时发现设计中存在的问题

![任务管理器](images/taskmgr.png "任务管理器")
—————— 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