ICT RTOS Research Group 胡伟平,王剑

Slides:



Advertisements
Similar presentations
心理现象及心理学效应. 蝴蝶效应 青蛙现象 鳄鱼法则 鲇鱼效应 羊群效应 木桶理论 马太效应 手表定律 破窗理论 二八定律 木桶理论 马太效应 责任分散效应 鸟笼逻辑 帕金森定律 晕轮效应 霍桑效应 习得性无助实验 证人的记忆 罗森塔尔效应 虚假同感偏差.
Advertisements

嵌入式系统简介 Introduction to Embedded System
嵌入式系统与结构 —基于ARM的体系结构和应用开发
讓你的程式具有多工(Multitasking) 及多重處理(Multiprocessing)的能力
開南大學 資訊管理學系 學分學程相關說明.
嵌入式控制系统 学时:45,1~12周,第13周闭卷考试 实验课:18学时,穿插在本课程间进行
第一章 嵌入式系统概况 大连理工大学 马洪连.
Foundations of Computer Science
中央广播电视大学开放教育试点课程 计算机操作系统.
前言 1.课程安排: 第一章 操作系统引论(7学时) 第二章 进程管理(14学时) 第三章 处理机调度与死锁(10学时)
操作系统结构.
Windows 2000/XP网络组建与系统管理 李燕 中南分校.
OSEK/VDX标准的产生 1993年5月,几家德国汽车制造商同意在适用于汽车且通用的实时分布式操作系统的规范化方面进行合作,产物就是OSEK(OSEK:Offense systeme und deren Schnit-stellen fur ide Elek im Kraftfahrzeug)。
UClinux在3000平台上的移植.
Chapter 6 時序.
第10章 多处理器和实时调度 主要内容: 多处理器调度 实时调度 操作系统调度例 分类与粒度 设计问题 进程调度 实时进程的要求与特点
Operating System Process Management - 4 Monday, August 11, 2008.
Operating System CPU Scheduing - 2 Monday, August 11, 2008.
Operating System CPU Scheduing - 3 Monday, August 11, 2008.
Xen基础架构安全性分析 云朋
Operating System Concepts 作業系統原理 Chapter 3 行程觀念 (Process Concept)
Windows Vista 操作系统最新安全特性
Symbian OS介绍 概述 第一部分.
C H A P T E R 11 体系结构对操作系统的支持.
軟體原型 (Software Prototyping)
第六章 应用程序结构.
網路技術管理進階班---區域網路的技術發展
11/17/2018 5:15 PM 病毒,间谍软件最新趋势 © 2005 Microsoft Corporation. All rights reserved. This presentation is for informational purposes only. Microsoft makes.
Applied Operating System Concepts
第8章作業系統.
The Research of Applying GuideLine Interchange Format (GLIF) of Protégé Application 報告人:博三 陳正怡 指導教授 李友專 博士 2018年11月20日 醫學資訊報告.
从UNIX到Windows的 电信软件移植实践
作 業 系 統 第三組 楊育翰 顏瑞霖.
SOLUTIONACCELERATORS Windows Vista Hardware Assessment 1
Operating System Concepts 作業系統原理 CHAPTER 2 系統結構 (System Structures)
嵌入式系统设计与开发 第1章 概述 第2章 ARM及其编程模型 第3章 ARM指令集 第4章 嵌入式程序设计
Android 课程讲义 智能手机开发
Chapter 3 行程觀念 (Process Concept)
製程能力分析 何正斌 教授 國立屏東科技大學工業管理學系.
SAP 架構及基本操作 SAP前端軟體安裝與登入 Logical View of the SAP System SAP登入 IDES
Chapter 4 多執行緒 (Multi Thread)
第三章 基本觀念 電腦繪圖與動畫 (Computer Graphics & Animation) Object Data Image
What’s wrong? public int listen() { lock.acquire();
DMA-2440XP WinCE5.0安裝與使用 長高科技 顏旭偉.
线程(Thread).
Formal Pivot to both Language and Intelligence in Science
作業系統 (Operating System)
邹佳恒 第十八届全国科学计算与信息化会议 • 威海,
校園網路架構介紹與資源利用 主講人:趙志宏 圖書資訊館網路通訊組.
寫作評估 實用文寫作講解 1.
凌宁 系统工程师 亚洲区嵌入式系统事业群 微软(中国)有限公司
第3章 認識處理元.
BSDTW 2017.
第三章 基本觀念 電腦繪圖與動畫 (Computer Graphics & Animation) Object Data Image
Microsoft SQL Server 2008 報表服務_設計
Unit 11.Operating System 11.1 What’s OS 11.2 Related Courses
SAP R/3架構及前端軟體安裝 Logical View of the R/3 System SAP Frontend 6.2安裝
Introduction to C Programming
Real-Time System Software Group Lab 408 Wireless Networking and Embedded Systems Laboratory Virtualization, Parallelization, Service 實驗室主要是以系統軟體設計為主,
RTOS.
中国科学技术大学计算机系 陈香兰 2013Fall 第七讲 存储器管理 中国科学技术大学计算机系 陈香兰 2013Fall.
虚 拟 仪 器 virtual instrument
中国科学技术大学计算机系 陈香兰 Fall 2013 第三讲 线程 中国科学技术大学计算机系 陈香兰 Fall 2013.
嵌入式Linux开发流程 成都研究所操作系统团队.
Inheritance -II.
SAP 架構及基本操作 SAP前端軟體安裝與登入 Logical View of the SAP System SAP登入 IDES
Operating System Software School of SCU
SAP 架構及前端軟體安裝 Logical View of the SAP System SAP Frontend 7.1安裝 SAP登入
MGT 213 System Management Server的昨天,今天和明天
作業系統概論 授課老師: 羅習五.
Presentation transcript:

99-10-20 ICT RTOS Research Group 胡伟平,王剑 实时操作系统 -- 背景、标准、技术、实现 99-10-20 ICT RTOS Research Group 胡伟平,王剑

RTOS地位 嵌入式系统存在并发需求(中断驱动),RTOS Kernel 是支持并发的主要工具。 提供的自举代码,各种硬件的驱动(DRIVERS ),以提供基本的硬件设备管理。 提供Download,Debugger 接口方便开发调试 提供NET , FILE , GRAPH, TV等 API 方便嵌入式系统的开发工作

Application Programming Interface RTOS Background Application Programming Interface U s e r M o d K n l 1 t _ v E x c u i S y R f ( ) P b m O I X H a w A L C g / F , D W 3 2 NET p Object Manager API Imple Based on WinNT DDK Kernel Standard posix/uITRON DD-PI 硬件抽象层HAL 影响RTOS系统的可移植性

免费RTOS 及RTOS研究 其他列表于http://www.eetoolbox.com/real/freertos.htm

RTOS系统比较 个人电脑上的操作系统向下功能缩减形成的方案 原嵌入式系统中的实时性操作系统功能扩展形成的方案

系统配置 RTOS 通常包含 Kernel +Drivers+NET+CLIB(FILE)+GUI 五部分,功能需求不同,RTOS大小也不同 From cygnus

RTOS性能指标 RTOS性能指标 中断响应时间: Interrupt Response 上下文切换时间:Context Switching Time 确定性: Determinism Kernel services should be deterministic by specifying how long each service call will take to execute. 调度器的实现算法 Rate Monotonic(发生率单调),优先级与发生率呈正比 [LiuLay 1973] lottery scheduler (彩票调度, Wald&Weihl94)

RTOS系统规模 (I)

RTOS系统规模(II)源代码 eCos 源代码行数 Linux源代码行数 > 1M Kernel -->h 8865 , cxx 8497 CLIB+MathLIB --> h 1541 , cxx 13K Linux源代码行数 > 1M Kernel 10K HAL 36K File System 124K Drivers 831K Net 147K

RTOS系统选择 1. OS高性能和保持安全性 2. 结构合理 3. 提供开发环境加快系统开发进度 成熟!? 分层以保持可移植,方便驱动程序实现 3. 提供开发环境加快系统开发进度 提供模拟开发环境降低开发成本 IDE ….

RTOS系统选择(II) 系统尺寸、性能 : 系统完整性:Software components & Device Drivers Footprint Performance 系统完整性:Software components & Device Drivers 标准化支持:Standards compatibility 版权与财务(License): Only for Build from scratch for special Performance requirement

RTOS 技术 核心服务界面(Kernel Service) 核心Implementation HAL界面 HAL Implementation DriverManager 界面 Driver Manager Implementation

核心服务界面标准 Posix 1003.1b 以POSIX扩充出现,适用于多进程系统,代码尺寸限制不是非常严格的场合为VxWorks,OSKIT,RTEMS等系统支持。 uItron 以实时系统专用标准出现,适用于代码尺寸限制严格的场合,为eCos等系统支持。 Standard Links

核心服务界面 Scheduling service Synchronization& Communication void cyg_thread_create(cyg_addrword_t sched_info, cyg_thread_entry_t *entry, cyg_addrword_t entry_data, char *name, void *stack_base, cyg_ucount32 stack_size, cyg_handle_t *handle, cyg_thread *thread); NU_Create_Task/ER cre_tsk(ID tskid, T_CTSK *pk_ctsk); Synchronization& Communication cyg_semaphore_init(cyg_sem_t *sem, cyg_ucount32 val); NU_Create_Semaphore cyg_bool_t cyg_semaphore_trywait(cyg_sem_t *sem); NU_Send_TO_Queue

核心服务(Cont‘d) C-API….. Interrupt Services Management I/O Driver Service Create_ISR, install_interrupt_handle I/O Driver Service Create_Driver memory services Allocate_Partition, ALLOC C-API….. strcpy

Itran 命名标准 ftp://159.226.42.103/rtos/rtosstandards/itron/ All system calls of ITRON specification are seven or eight characters long and of the form 'xxx_yyy' or 'zxxx_yyy' respectively, where 'xxx' represents the method of operation, and 'yyy' the object of the operation.

Itran 命名-对象

Itran 命名-方法

RTOS 核心 Service Summary 核心 服务(命名和语义)的标准化有利于如TCP/IP协议栈等API的实现与重用.

简单的异步系统 II 系统包含< Mouse + Mouse Viewer > 鼠标中断服务 调度器 空线程 绘图线程 1 事件队列 II

最小核心 实现 核心实现中包含如下对象 任务调度支持 Scheduler /Interrupt Manager Task 同步与通讯支持 Event Semaphone Queue

Scheduler ‘s Global 调度器中包含 当前线程 Cyg_Thread *current_thread; 线程队列 Cyg_ThreadQueue *queue; 调度状态 volatile cyg_ucount32 sched_lock; cyg_bool need_reschedule; cyg_ucount32 thread_switches; 。。。

Cyg_HardwareThread 线程控制块至少包含 栈定义。 栈状态 线程状态 CYG_ADDRESS stack_base; cyg_uint32 stack_size; 栈状态 CYG_ADDRESS stack_ptr; 线程状态 cyg_uint32 state;

Cyg_Thread 线程状态中通常还包含相关的消息及同步对象的列表……. 核心代码的操作对象即这些线程状态、消息及同步量 cyg_ucount32 wakeup_count; CYG_ADDRWORD wait_info; 核心代码的操作对象即这些线程状态、消息及同步量

核心初始化 核心所需的初始化包含 内存分配器初始化 核心自用的信号量初始化 基本的中断处理程序的安装……. 基本的驱动程序的安装……. 启动系统线程 启动用户线程

初始化例

运行时的RTOS 对象 II 中断堆栈 调度器对象 线程表/当前线程 中断向量表 ……. 中断服务 1 中断服务 n 线程 1 线程 2 同步对象 II 线程控制块+线程堆栈

简单系统的代码

任务切换过程 Draw Idle 线程堆栈 线程现场 线程控制块 OSTCBCUR 当前线程 OSTCBHighRrd

ucOS 任务切换实现

调度算法 调度算法选择将要执行的任务 a bitmap scheduler multi-level queue scheduler It represents each runnable thread with a bit in a bitmap. Each thread must have a unique priority and there is a strict upper limit on the number of threads allowed. multi-level queue scheduler This contains the multi-level queue scheduler implementation. It implements a number of thread priorities and is capable of timeslicing between threads at the same priority. This scheduler can also support priority inheritance. lottery scheduler (彩票调度, Wald&Weihl94) Compensation tickets and ticket donation allow fair sharing for I/O bound threads and an equivalent mechanism to priority inheritance.

RTOS性能指标 RTOS Performance Context Switching Time上下文切换时间 Interrupt Response 中断响应时间 Determinism 决定性 Kernel services should be deterministic by specifying how long each service call will take to execute. 实时调度的经典算法Rate Monotonic(发生率单调),优先级与发生率呈正比 [Liu&Lay 1973]

结束语 我们描述了RTOS Kernel的基本原理了解了RTOS Kernel 的结构 嵌入式系统的需求多种多样是RTOS种类繁多的重要原因。实际RTOS 的实现还可能包含SMP、MMU、调试支持、可移植性、驱动程序开发,等问题,RTOS Kernel 的实现效率,实时性也是重要问题。 希望以后有更多的交流,谢谢。

Embedded-OS 的发展方向 是否需要完整功能的操作系统 进程管理,存储保护,核心态用户态。 是否有兼容性需求 可使用的硬件资源 需要做数据文件交换(Pocket Word)。 CE 强调 Host Sync& Communication API支持 可使用的硬件资源 核心Footprint 在4Mb+时CE,LINUX有优势。 “主流” 用户程序数量是OS生存的重要条件。需要提供丰富、支持全面的API 1000+ 需要提供完善的集成开发环境,简化程序(包括驱动)开发。

Easy Embedded OS Easy Embedded OS是一个小型嵌入式操作系统,定位为小型通讯设备、数字化家电如机顶盒(STB)用的OS。由中科院计算所嵌入式系统软件研究组负责组织开发。 Easy Embedded 实时操作系统以库函数形式提供。此外Easy Embedded OS是包含Easy Embedded开发环境的完整嵌入式系统软件开发环境,提供OS配置工具、编译环境、模拟环境、下载工具和调试环境,以方便用户使用。

EEOS成分

Win32-EEOS应用仿真开发平台

交叉调试开发环境