1系统中断与时钟节拍
单片机系统的时钟与定时器设计原理详解
单片机系统的时钟与定时器设计原理详解引言:随着现代电子技术的快速发展,单片机在各个领域得到了广泛应用。
在单片机系统中,时钟和定时器是非常重要的组成部分。
时钟用来驱动整个单片机系统的节奏,而定时器用于实现各种时间相关的功能。
本文将详细解析单片机系统中时钟和定时器的设计原理。
一、时钟设计原理:在单片机系统中,时钟充当着同步整个系统操作的功能。
它是一个稳定可靠的信号源,用于指导单片机各个部件的工作。
时钟信号通常由晶体振荡器产生,通过芯片内部的倍频电路进行频率提升。
常见的时钟频率有4MHz、8MHz、16MHz等。
时钟的设计需要考虑以下几个方面:1. 稳定性:时钟信号必须具有高稳定性,以确保整个系统的正常运行。
通常使用石英晶体作为振荡器,由于石英晶体具有稳定频率的特性,因此可以提供可靠和精确的时钟信号。
2. 频率选择:时钟频率的选择应根据具体的应用需求进行。
较高频率的时钟可以提高系统的处理速度,但同时也会增加功耗。
因此,在设计时应合理选择适当的时钟频率。
3. 电源噪声:电源噪声对时钟信号的稳定性有很大影响。
为了减小电源噪声对时钟的干扰,可以采用电源滤波电路,提高时钟信号的抗干扰能力。
4. 时钟分频:有时候需要减小时钟频率用于驱动其他外设,可以通过时钟分频器来实现。
分频器可以将高频的时钟信号分频得到较低频率的时钟信号。
二、定时器设计原理:定时器在单片机系统中有着广泛的应用,可以实现延时、定时、脉冲生成等功能。
定时器通常由一个计数器和相关的控制逻辑组成。
定时器的设计需要考虑以下几个方面:1. 计数器选择:在选择定时器时,需要根据需求选择适当的计数器位数。
通常,8位计数器可以计数255个时间单位,16位计数器可以计数65535个时间单位。
计数器的位数越大,可以表示的时间范围就越大,但同时也会增加硬件成本和资源占用。
2. 定时器模式:定时器可以有不同的工作模式,如定时模式、脉冲计数模式等。
定时模式用于实现定时功能,脉冲计数模式用于计算脉冲的个数。
时钟周期 以中断为背景
时钟周期以中断为背景时钟中断是操作系统最重要的中断,操作系统内核依靠时钟中断完成时间片计算和分配、定时等管理工作,是分时机制实现的基础。
可以说如果没有时钟中断,操作系统将无法正常运行。
时钟中断由专门的时钟芯片产生,比如PC机上的8253芯片。
大多数的操作系统实现,时钟中断周期会维持在10ms到100ms之间,比如Windows操作系统,其时钟中断周期一般为10ms或者20ms。
表面上看,似乎时钟中断周期越短,系统的实时性越好,因为进程或线程的运行时间片会被控制的越精确,优先级高的进程或线程会优先得到运行。
但仔细分析起来,会发现实际并不是这么回事,时钟中断周期的大小与系统整体实时性关系并不十分紧密。
可用两个指标来衡量操作系统的实时性:一个是中断响应时间,即从外部中断发生,到得到操作系统处理之间的时间;另外一个是任务切入时间,即一个高优先级的线程运行所需的资源就绪,到得到调度所需的时间。
时钟中断周期的大小,与这两个指标并无直接关联。
首先看中断响应时间,这个时间与硬件系统关联紧密。
中断一般由外部设备引发,外部设备的控制电路连接到计算机的中断控制器上(比如PC的8259A芯片)。
一旦外部设备发生中断,设备会通过一条中断引脚通知中断控制器,中断控制器根据输入引脚的状态(比如是否禁止引发中断)、输入引脚的优先级、连接到片上的其它中断引脚的情况,综合判断是否需要对该中断进行处理。
如果判断结果为进一步处理,则通过CPU的中断输入(比如x86CPU的INTR信号)通知CPU。
CPU并不会马上处理中断,而是有一套比较复杂的判断机制,判断是否对刚刚输入的中断进行响应。
最重要的决定因素有两个:一个是CPU只会在一条指令执行完毕后才会检查中断状态,如果CPU正处于一条指令的执行过程中(需要注意的是,CPU执行一条指令,有时候会需要很多个CPU节拍的),中断是不会被处理的。
另外一个因素是中断使能标志是否被清除(比如x86 CPU标志寄存器中的中断使能位)。
单片机中的中断与定时器的原理与应用
单片机中的中断与定时器的原理与应用在单片机(Microcontroller)中,中断(Interrupt)和定时器(Timer)是重要的功能模块,广泛应用于各种嵌入式系统和电子设备中。
本文将介绍中断和定时器的基本原理,并探讨它们在单片机中的应用。
一、中断的原理与应用中断是指在程序执行过程中,当发生某个特定事件时,暂停当前任务的执行,转而执行与该事件相关的任务。
这样可以提高系统的响应能力和实时性。
单片机中的中断通常有外部中断和定时中断两种类型。
1. 外部中断外部中断是通过外部触发器(如按钮、传感器等)来触发的中断事件。
当外部触发器发生状态变化时,单片机会响应中断请求,并执行相应的中断服务程序。
外部中断通常用于处理实时性要求较高的事件,如按键检测、紧急报警等。
2. 定时中断定时中断是通过定时器来触发的中断事件。
定时器是一种特殊的计时设备,可以按照设定的时间周期产生中断信号。
当定时器倒计时完成时,单片机会响应中断请求,并执行相应的中断服务程序。
定时中断常用于处理需要精确计时和时序控制的任务,如脉冲计数、PWM波形生成等。
中断的应用具体取决于具体的工程需求,例如在电梯控制系统中,可以使用外部中断来响应紧急停车按钮;在家电控制系统中,可以利用定时中断来实现定时开关机功能。
二、定时器的原理与应用定时器是单片机中的一个重要模块,可以用于计时、延时、频率测量等多种应用。
下面将介绍定时器的工作原理和几种常见的应用场景。
1. 定时器的工作原理定时器是通过内部时钟源来进行计时的。
它通常由一个计数器和若干个控制寄存器组成。
计数器可以递增或递减,当计数值达到设定值时,会产生中断信号或触发其他相关操作。
2. 延时应用延时是定时器最常见的应用之一。
通过设定一个合适的计时器参数,实现程序的精确延时。
例如,在蜂鸣器控制中,可以使用定时器来生成特定频率和持续时间的方波信号,从而产生不同的声音效果。
3. 频率测量应用定时器还可以用于频率测量。
嵌入式实时操作系统试题
嵌⼊式实时操作系统试题1、⽬前使⽤的嵌⼊式操作系统主要有那些?请举出六种常⽤的。
Windwos CE、Windows Mobile、VxWork、Linux、uCos、Symbian、QNX2、⼀般⽽⾔,嵌⼊式系统的架构可以分为4个部分,分别是(处理器)、存储器、输⼊输出和软件,⼀般软件分为(操作系统)和应⽤软件两个主要部分。
3、从嵌⼊式操作系统特点可以将嵌⼊式操作系统分为(实时操作系统)和分时操作系统,其中实时系统可分为(硬实时系统)和软实时系统4、uc/os操作系统不包括以下哪集中状态A、运⾏B、挂起C、退出D、休眠5、0x70&0x11的运算结果是A、0x1B、0x11C、0x17D、0x76、下列哪种⽅式不是ucos操作系统中任务之间的通信⽅式A、信号量B、消息队列C、邮件D、邮箱7、在将ucos操作系统移植到ARM处理器上时,以下那些⽂件不需要修改A、OS_CORE.CB、include.hC、OS_CPU.HD、OSTaskInit设计实时操作系统时,⾸先应该考虑系统的()。
A.可靠性和灵活性B.实时性和可靠性C.分配性和可靠性D.灵活性和实时性2. ⼤多数嵌⼊式实时操作系统中,为了让操作系统能够在有突发状态时迅速取得控制权,以作出反映,⼤都采⽤()的功能。
A:抢占式任务调度B:时间⽚轮转调度C:单调速率调度D:FIFO调度8、所有的电⼦设备都属于嵌⼊式设备简单题:1、根据嵌⼊式系统的特点、写出嵌⼊式系统的定义答:以应⽤为中⼼,以计算机技术为基础,软硬件可裁剪、功能、可靠性、成本、体积、功耗严格要求的专⽤计算机系统2、试分析实时操作系统的⼯作特点及相互之间的转换运⾏:获得CPU的控制权就绪:进⼊任务等待队列,通过调度中转为运⾏状态挂起:由于系统函数调⽤⽽被设置成挂起状态,任务发⽣阻塞,等待系统实时事件的发⽣⽽被唤醒,从⽽转为就绪或运⾏。
休眠:任务完成或者错误被清除的任务,该任务此时不具有任务控制块。
《嵌入式实时操作系统复习资料》
一、填空题(请将答案填入题后括号中):共10小题,每小题2分,满分20分。
1、一般而言,嵌入式系统的构架可以分为4个部分:分别是(处理器)、存储器、输入/输出和软件,一般软件亦分为操作系统相关和(应用软件)两个主要部分。
2、根据嵌入式系统使用的微处理器,可以将嵌入式系统分为嵌入式微控制器,(嵌入式微处理器)(嵌入式DSP处理器)以及片上系统。
3、操作系统是联接硬件与应用程序的系统程序,其基本功能有(任务管理)、任务间通信、(内存管理)和I/O资源管理。
4.实时系统:指系统能够在限定的(响应)时间内提供所需水平的服务5.ucos-ii最多管理(64 )个任务6.ucos-ii中,OS_TaskStat任务的优先级占(62 ),OS_TaskIdle任务的优先级是( 63 )7 ucos-ii中,OSRdyTbl就绪表的大小是由宏定义:OS_RDY_TBL_SIZE来定义,由全局宏( OS_LOWEST_PRIO )来决定的,8. TCB中的四个成员变量:INT8U OSTCBX;INT8U OSTCBY;INT8U OSTCBBitX;INT8U OSTCBBitY ,用于(加速)任务就绪态的计算过程。
9.TCB内部最重要的元素放在第一个单元叫(OSTCBStkPtr),因此,这个变量是惟一一个能用汇编语言处置的变量,将其放在结构最前面,使得在汇编语言中处理这个变量时较为容易。
10.uC/OS-II是一个简洁、易用的基于优先级的嵌入式(抢占式)多任务实时内核。
11.任务是一个无返回的无穷循环。
uc/os-ii总是运行进入就绪状态的(最高优先级)的任务。
12.因为uc/os-ii总是运行进入就绪状态的最高优先级的任务。
所以,确定哪个任务优先级最高,下面该哪个任务运行,这个工作就是由调度器(scheduler)来完成的。
13.(不可剥夺型)内核要求每个任务自我放弃CPU的所有权。
不可剥夺型调度法也称作合作型多任务,各个任务彼此合作共享一个CPU。
时钟节拍——精选推荐
时钟节拍 时钟节拍可谓是 uC/OS 操作系统的⼼脏,它若不跳动,整个系统都将会瘫痪。
时钟节拍就是操作系统的时基,操作系统要实现时间上的管理,必须依赖于时基。
时钟节拍就是系统以固定的频率产⽣中断(时基中断),并在中断中处理与时间相关的事件,推动所有任务向前运⾏。
时钟节拍需要依赖于硬件定时器,在 STM32 裸机程序中经常使⽤的 SysTick 时钟是 MCU的内核定时器,通常都使⽤该定时器产⽣操作系统的时钟节拍。
⽤户需要先在“os_cfg_app.h”中设定时钟节拍的频率,该频率越⾼,操作系统检测事件就越频繁,可以增强任务的实时性,但太频繁也会增加操作系统内核的负担加重,所以⽤户需要权衡该频率的设置。
秉⽕在这⾥采⽤默认的 1000 Hz(本书之后若⽆特别声明,均采⽤1000 Hz),也就是时钟节拍的周期为 1 ms。
设置时钟节拍的频率:/* ------------------------ TICKS ----------------------- */#define OS_CFG_TICK_RATE_HZ 1000u // 时钟节拍频率 (10 to 1000 Hz)#define OS_CFG_TICK_TASK_PRIO 10u // 时钟节拍任务 OS_TickTask() 的优先级#define OS_CFG_TICK_TASK_STK_SIZE 128u // 时钟节拍任务 OS_TickTask() 的栈空间⼤⼩#define OS_CFG_TICK_WHEEL_SIZE 17u // OSCfg_TickWheel 数组的⼤⼩,推荐使⽤任务总数/4,且为质数View Code 在app.c中的起始任务 AppTaskStart() 中初始化时钟节拍定时器,其实就是初始化 STM32 内核的 SysTick 时钟。
初始化 SysTick 时钟:cpu_clk_freq = BSP_CPU_ClkFreq(); //获取 CPU 内核时钟频率(SysTick ⼯作时钟)cnts = cpu_clk_freq / (CPU_INT32U)OSCfg_TickRate_Hz; //根据⽤户设定的时钟节拍频率计算 SysTick 定时器的计数值OS_CPU_SysTickInit(cnts); //调⽤ SysTick 初始化函数,设置定时器计数值和启动定时器View Code OS_CPU_SysTickInit() 函数的定义位于“os_cpu_c.c” :void OS_CPU_SysTickInit (CPU_INT32U cnts){CPU_INT32U prio;/* 填写 SysTick 的重载计数值 */CPU_REG_NVIC_ST_RELOAD = cnts - 1u; // SysTick 以该计数值为周期循环计数定时/* 设置 SysTick 中断优先级 */prio = CPU_REG_NVIC_SHPRI3;prio &= DEF_BIT_FIELD(24, 0);prio |= DEF_BIT_MASK(OS_CPU_CFG_SYSTICK_PRIO, 24); //设置为默认的最⾼优先级0,在裸机例程中该优先级默认为最低CPU_REG_NVIC_SHPRI3 = prio;/* 使能 SysTick 的时钟源和启动计数器 */CPU_REG_NVIC_ST_CTRL |= CPU_REG_NVIC_ST_CTRL_CLKSOURCE |CPU_REG_NVIC_ST_CTRL_ENABLE;/* 使能 SysTick 的定时中断 */CPU_REG_NVIC_ST_CTRL |= CPU_REG_NVIC_ST_CTRL_TICKINT;}View Code SysTick 定时中断函数 OS_CPU_SysTickHandler() 的定义也位于“os_cpu_c.c”,就毗邻 OS_CPU_SysTickInit() 函数定义体的上⽅。
【FreeRTOS操作系统教程】第16章 FreeRTOS调度锁,任务锁和中断锁
调度锁就是 RTOS 提供的调度器开关函数,如果某个任务调用了调度锁开关函数,处于调度锁开和调 度锁关之间的代码在执行期间是不会被高优先级的任务抢占的,即任务调度被禁止。这一点要跟临界段的 作用区分开,调度锁只是禁止了任务调度,并没有关闭任何中断,中断还是正常执行的。而临界段进行了 开关中断操作。
利用 FreeRTOS 的调度锁功能给调度器加锁的话,将关闭任务切换功能,从而高优先级任务也就无法 抢占低优先级任务的执行,同时高优先级任务也是无法向低优先级任务切换的。另外特别注意,调度 锁只是禁止了调度器工作,并没有关闭任何中断。 通过关闭任务切换中断 PendSV 和系统时钟节拍中断 Systick
#define INCLUDE_vTaskPrioe INCLUDE_uxTaskPriorityGet
1
#define INCLUDE_vTaskDelete
#define portGET_RUN_TIME_COUNTER_VALUE()
ulHighFrequencyTimerTicks
//#define portALT_GET_RUN_TIME_COUNTER_VALUE
1
/* Co-routine definitions. */
#define configUSE_CO_ROUTINES
2016年06月30日
版本:1.0
第 4 页 共 28 页
武汉安富莱电子有限公司
安富莱 STM32-V6 开发板 FreeRTOS 教程
{ while(1) { vTaskSuspendAll(); /* 开启调度锁 */ printf("任务 vTaskLED 正在运行\r\n"); xTaskResumeAll (); if(!xTaskResumeAll()) /* 关闭调度锁,如果需要任务切换,此函数返回 pdTRUE,否则返回 pdFALSE */ { taskYIELD (); }
时钟中断调度的原理
时钟中断调度的原理
时钟中断调度是操作系统中的一种调度方式,它基于中断的机制实现。
当时钟中断发生时,操作系统会暂停当前任务的执行,切换到另一个任务,以实现多任务并发执行。
时钟中断调度的原理如下:
1. 定时中断:操作系统会设置一个时钟中断定时器,它会在固定的时间间隔内产生一个时钟中断。
这个时间间隔通常被称为时间片(time slice),一般设置为几毫秒或十几毫秒。
2. 中断处理程序:当时钟中断发生时,CPU会立即跳转到操作系统的中断处理程序。
中断处理程序是操作系统内核的一部分,它会执行一系列的操作,包括保存当前执行任务的上下文,切换到另一个任务的上下文等。
3. 任务切换:在中断处理程序中,操作系统会选择一个新的任务来执行。
这个选择可以基于各种调度算法,例如轮转调度、优先级调度等。
4. 上下文切换:在中断处理程序中,操作系统会保存当前任务的上下文,包括寄存器的值、栈指针等,然后加载新任务的上下文,将控制权交给新的任务。
这样,新任务就开始执行了。
5. 恢复执行:当操作系统完成任务切换后,它会返回到中断发生前的程序继续执行。
这样,原来的任务就被暂停了,而新的任务开始运行。
通过时钟中断调度,操作系统能够以很短的时间片轮转方式,实现多任务并发执行。
每个任务都能够获得一定的执行时间,从而提高系统的吞吐量和响应速度。
嵌入式实时操作系统复习纲要
嵌⼊式实时操作系统复习纲要嵌⼊式实时操作系统复习纲要第⼀章●嵌⼊式系统:嵌⼊到对象体系中,为实现对象体系智能化控制的计算机系统,叫做嵌⼊式计算机系统,简称嵌⼊式系统。
●嵌⼊式操作系统:嵌⼊到特定设备的专⽤的可裁剪的计算机系统●嵌⼊式操作系统分为实时操作系统和分时操作系统。
●嵌⼊式系统的三个要素:嵌⼊性、专⽤性和计算机系统●嵌⼊式系统的特点:专⽤性强、可裁剪性好、实时性与可靠性好、功耗低●内核类型:可剥夺型和不可剥夺型●⼏种常见的嵌⼊式操作系统:VxWorks、pSOS、Windows CE、QNX OS;⼿持设备的有:Plam、WinCE、EPOC;互联⽹⽅⾯的有:uCLinux、uC/OS-II.(记住其中五种)第⼆章●任务:任务是⼀种程序实体,实质上时⼀个线程。
●uC/OS-II的任务组成:任务程序代码(任务的执⾏部分)、任务推栈(保存任务⼯作环境)、任务控制块(保存任务属性)●uC/OS-II的任务有两种:⽤户任务和系统任务;其中系统任务有分为:空闲任务和统计任务,空闲任务是⽤户应⽤程序必须使⽤的,统计任务是应⽤程序可以根据实际需要来选择使⽤的。
●任务的5种状态:睡眠状态、就绪状态、运⾏状态、等待状态、中断服务状态。
要重点看⼀下P17页的图2-2。
在这些状态中睡眠状态只能直接进⼊就绪状态,就绪状态和中断服务状态可以直接进⼊运⾏状态,就绪状态可以直接进⼊睡眠状态和运⾏状态,中断服务状态只能直接进⼊运⾏状态,等待状态可以直接进⼊除了中断服务状态外的其他三种状态。
运⾏状态可以进⼊其他四种状态。
等待状态有:延时等待、请求等待和任务挂起等。
●临界段:为了有效地对中断进⾏控制,在任务的代码⾥可使⽤uC/OS-II定义的宏OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL()来控制任务何时响应中断,何时屏蔽中断。
在运⾏这两个宏之间的代码时是不会响应中断的,这种受保护的代码段叫做临界段。
ucos中断处理和时间管理
取消延时函数
延时的任务可以不等延时期满,而是通过其
他任务取消延时而使自己进入就绪状态。
取消延时函数为:
INT8U OSTimeDlyResume( INT8U prio);
INT8U OSTimeDlyResume (INT8U prio) {
OS_TCB *ptcb; 。。。。。。
判断优先级是否有效
三、配置中断源和向量中断控制器
1、中断源初始化: 以定时器1为例,让产生周期为10ms的中断 的参数配置如下:
T1IR = 0xFFFFFFFF; T1TC = 0x00; T1PR = 0x00; T1TCR = 0x01; T1MCR = 0x03; //匹配时产生中断并复位定时器1 T1MR0 = Fpclk/100; //定时时间为10ms
μC/OS-II 用硬件定时器产生一个周期为 ms 级的周期性中断来实现系统时钟,时钟 节拍(Time Tick)就是两次中断之间相间 隔的时间。 硬件定时器以时钟节拍为周期定时地产 生中断,该中断的中断服务程序叫做 OSTickISR( )。中断服务程序通过调用函数 OSTimeTick( )来完成系统在每个时钟节拍 时需要做的工作(如确定任务延时时间是 否结束或等待事件的时限是否已到?。
函数OSTimeTick( )的 任务,就是在每个时 钟节拍了解每个任务 的延时状态,使其中 已经到了延时时限的 非挂起任务进入就绪 状态。
时间服务函数
问题:如何使优先级高 的任务不独占CPU,给其他 任务优先级别较低的任务获 得CPU使用权的机会?
调用延时函数OSTimeDly( ),使当前任 务的延时(暂停)一段时间并进行一次 任务调度,以让出CPU的使用权。 调用挂起函数OSTaskSuspend( ),使当前 任务挂起并进行一次任务调度,以让出 CPU的使用权。 调用等待事件函数OSXXXPend( ),使当 前任务等待某一事件发生并进行一次任 务调度,以让出CPU的使用权。
ucosii任务管理及调度
统计任务OSTaskStat(),提供运行时间统计。每 秒钟运行一次,计算当前的CPU利用率。其优先级 是OS_LOWEST_PRIOR-1,可选。
22
任务控制块TCB 任务控制块 OS_TCB是描述一个任务的核 心数据结构,存放了它的各种管理信息 ,包括任务堆栈指针,任务的状态、优 先级,任务链表指针等;
11
µC/OS-II的各种商业应用
全世界有数百种产品在应用:
Avionics Medical Cell phones
Routers and switches
High-end audio equipment Washing machines and dryers UPS (Uninterruptible Power Supplies)
19
任务也可以自我删除(并非真的删除,只是内核不 再知道该任务)
void MyTask (void *pdata) {
ReWorks实时操作系统核心功能分析
2.1 中断/异常管理
x86常见异常号
❖ 系统出现异常时,CPU通常通过异常号来反映具体的异常信息。以x86为例,常见的异常号如下表
所示:
异常号
0 4 5
异常名称
除零异常 溢出异常 越界异常
异常号
6 7 14
异常名称
无效指令异常 浮点异常
非法地址异常
路漫漫其修远兮, 吾将上下而求索
培训大纲
1
时钟/定时器管理:
阐述ReWorks的系统时钟、时间、定时器等基本功能。
中断/异常管理:
2
描述ReWorks对于外部事件的中断响应方式,以及对于CPU异常的处
理机制。
多任务管理 :
3
讲述ReWorks中对于多任务的调度机制,以及任务间共享资源以
及同步的手段。
4
内存管理:
叙述实时系统中对于内存的管理方法,包括对于硬件MMU的支持
ReWorks实时操作系统 核心功能分析
路漫漫其修远兮, 吾将上下而求索
2020年4月4日星期六
路漫漫其修远兮, 吾将上下而求索
培训大纲
1.ReWorks实时操作系统概述 2.ReDe开发环境介绍 3.ReWorks BSP开发 4.ReWorks BSP示例分析 5.ReWorks核心功能介绍 6.ReWorks核心功能示例分析与实验 7.ReWorks扩展功能介绍 8.ReWorks设备驱动开发 9.ReWorks示例分析与实验
定时器
❖ 定时器通过定时器控制块管理,通过系统时钟的计时手段提供定时触 发功能。 定时器状态转换图如下图所示:
路漫漫其修远兮, 吾将上下而求索
1.3 定时器管理
ucos(一)ucos系统简介
ucos(⼀)ucos系统简介⼀、概述 µC/OS-II由Micrium公司提供,是⼀个可移植、可固化的、可裁剪的、占先式多任务实时内核,它适⽤于多种微处理器,微控制器和数字处理芯⽚(已经移植到超过100种以上的微处理器应⽤中)。
同时,该系统源代码开放、整洁、⼀致,注释详尽,适合系统开发。
µC/OS-II已经通过联邦航空局(FAA)商⽤航⾏器认证,符合航空⽆线电技术委员会(RTCA)DO-178B标准。
现在最新版的是µC/OS-III。
⼆、性质µC/OS-II被⼴泛应⽤于微处理器、微控制器和数字信号处理器。
µC/OS-II 的前⾝是µC/OS,最早出⾃于1992 年美国嵌⼊式系统专家Jean brosse 在《嵌⼊式系统编程》杂志的5 ⽉和6 ⽉刊上刊登的⽂章连载,并把µC/OS 的源码发布在该杂志的B B S 上。
µC/OS 和µC/OS-II 是专门为计算机的嵌⼊式应⽤设计的,绝⼤部分代码是⽤C语⾔编写的。
CPU 硬件相关部分是⽤汇编语⾔编写的、总量约200⾏的汇编语⾔部分被压缩到最低限度,为的是便于移植到任何⼀种其它的CPU 上。
⽤户只要有标准的ANSI 的C交叉编译器,有汇编器、连接器等软件⼯具,就可以将µC/OS-II嵌⼊到开发的产品中。
µC/OS-II 具有执⾏效率⾼、占⽤空间⼩、实时性能优良和可扩展性强等特点,最⼩内核可编译⾄ 2KB 。
µC/OS-II 已经移植到了⼏乎所有知名的CPU 上。
严格地说uC/OS-II只是⼀个实时操作系统内核,它仅仅包含了任务调度,任务管理,时间管理,内存管理和任务间的通信和同步等基本功能。
没有提供输⼊输出管理,⽂件系统,⽹络等额外的服务。
但由于uC/OS-II良好的可扩展性和源码开放,这些⾮必须的功能完全可以由⽤户⾃⼰根据需要分别实现。
系统节拍定时(SysTick)
1.2 SysTick 基本操作
利用《Stellaris 外设驱动库》操作 SysTick 是非常简单的。无论是配置还是操作,SysTick 的用法都比一般片内外设简单。这一部分的库函数描述请参考表 1.2、表 1.3、表 1.4、表 1.5、 表 1.6。
表 1.2 函数 SysTickPeriodSet( )
表 1.5 函数 SysTickDisable( )
功能 原型 参数 返回
关闭 SysTick 计数器,停止计数 void SysTickDisable(void) 无 无
表 1.6 函数 SysTickValueGet( )
功能 原型 参数 返回
获取 SysTick 计数器的当前值 unsigned long SysTickValueGet(void) 无 SysTick 计数器的当前值,该值的范围是:0~函数 SysTickPeriodSet( )设定的初值-1
i
广州周立功单片机发展有限公司 Tel:(020)38730976 38730977 Fax:38730925
第1章 系统节拍定时(SysTick)
表 1.1 SysTick 库函数索引
函数原型 void SysTickPeriodSet(unsigned long ulPeriod) unsigned long SysTickPeriodGet(void) void SysTickEnable(void) void SysTickDisable(void) unsigned long SysTickValueGet(void) void SysTickIntEnable(void) void SysTickIntDisable(void) void SysTickIntRegister(void (*pfnHandler)(void)) void SysTickIntUnregister(void)
【FreeRTOS操作系统教程】第17章 FreeRTOS系统时钟节拍和时间管理
2016年06月30日
版本:1.0
第 6 页 共 33 页
武汉安富莱电子有限公司
uint8_t pcWriteBuffer[500];
安富莱 STM32-V6 开发板 FreeRTOS 教程
while(1) {
ucKeyCode = bsp_GetKey();
/* *********************************************************************************************************
2016年06月30日
版本:1.0
第 4 页 共 33 页
武汉安富莱电子有限公司
17.2.5函数 xTaskGetTickCount
关于这个函数的讲解及其使用方法可以看 FreeRTOS 在线版手册:
2016年06月30日
版本:1.0
第 5 页 共 33 页
武汉安富莱电子有限公司
安富莱 STM32-V6 开发板 FreeRTOS 教程
这里也对此函数进行下介绍。
对于抢占式调度器,让高优先级任务可以通过时间延迟函数释放 CPU 使用权,从而让低优先级任务
可以得到执行。
下面我们通过如下的框图来说明一下延迟函数对任务运行状态的影响,让大家有一个形象的认识。
运行条件: 仅对任务 Task1 的运行状态做说明。 调度器支持时间片调度和抢占式调度。 运行过程描述如下: 起初任务 Task1 处于运行态,调用 vTaskDelay 函数后进入到阻塞状态,也就是 blocked 状态。 vTaskDelay 函数设置的延迟时间到,由于任务 Task1 不是当前就绪的最高优先级任务,所以不能进
OS与时钟节拍
OS与时钟节拍引⼊操作系统会消耗掉⼀部分CPU处理能⼒,这是不得不付出的代价。
也许刚接触OS,不太习惯OS要浪费CPU时间⽚的现实,我以前也有这种困惑,如果这样的话,要OS有什么⽤呢?其实,OS是通过帮你统⼀有效地管理系统⽽提升性能的,它⾮但不能增加处理能⼒,还要消耗⼀部分。
就好象⽤三极管放⼤功率,三极管要消耗能量,⽽且本⾝不能产⽣能量,但是可以通过调节载流⼦数⽬,⽤⼩功率信号控制⼤功率信号,等效为把⼩信号功率放⼤了,当然,能量是别处提供的⽽且必须要有。
OS的情形也是如此,⾸先要有⼀个强⼒的CPU,通过OS提供的API函数,⽤户程序可以认为⾃⼰独占CPU和所有资源,多个任务并发执⾏,等效为⼀个CPU变成了N个,当然,这是靠⽠分CPU时间⽚得到的,总的处理能⼒还是等于这个CPU的能⼒减去OS消耗。
RTOS的优势是实时控制,实时不是指“快”,⽽是指可精确预测可控制,能保证在规定时间内完成任务。
因为执⾏时间可预测,所以当你想快时,只要选⼀个速度合适的CPU即可,这个需要的速度在OS保障下是可以精确算出来的。
当然,不增加硬件投⼊⽽增强性能的想法是不现实的。
时钟节拍率与CPU速度⽆关,⼀般选10-100HZ。
这个时钟节拍不是指CPU时钟频率,⽽是指OS切换频率,即tick值。
就是说OS⼀秒内定时中断多少次,例如100HZ就意味着每10ms定时中断⼀次,进⾏必要的处理。
时钟节拍率越⾼,CPU利⽤率越低,但响应时间快,适合成本⾼的应⽤。
DlyHMSM延时精度肯定受影响,100HZ时每10ms才滴答⼀次,你要想得到更⼩的时间粒度,只能提⾼时钟节拍率/⽤汇编写延时函数。
不过,OS不适合做这种精确定时,得不偿失。
你可以⽤硬件在外部实现。
使⽤OS情况下,尽量不要在中断处理函数ISR⾥作完全部⼯作,应该把后续处理任务放在延迟中断处理程序DSR⾥实现,ISR的处理时间越短越好。
主时钟信号与节拍、工作脉冲的关系
主时钟信号与节拍、工作脉冲的关系引言:在数字电子系统中,主时钟信号起着至关重要的作用。
它不仅是系统中各个模块之间同步工作的基础,同时也决定了系统的性能和稳定性。
而节拍和工作脉冲则是主时钟信号所衍生出的两个重要概念,它们与主时钟信号之间存在着密切的关系。
本文将介绍主时钟信号与节拍、工作脉冲之间的关系,并探讨它们在数字电子系统中的应用。
一、主时钟信号的作用主时钟信号是数字电子系统中的一个基准信号,它以固定的频率和周期性地驱动整个系统的运行。
主时钟信号的频率决定了系统的运行速度,而其周期则决定了系统各个模块之间的协调和同步。
主时钟信号通常由晶体振荡器产生,具有高精度和稳定性。
二、节拍的概念及其与主时钟信号的关系节拍是指系统中的一个时钟周期,在该周期内,系统中的所有操作都必须完成。
节拍的长度由主时钟信号的频率决定,频率越高,节拍的长度越短,系统的运行速度也就越快。
主时钟信号驱动着节拍的产生和更新,确保系统中的各个模块按照统一的步调工作。
在数字电子系统中,节拍的产生通常通过计数器实现。
计数器接收主时钟信号作为输入,并在每个主时钟周期结束时加1。
当计数器的值达到预设的节拍长度时,一个节拍信号被触发,用于同步系统中的各个操作。
通过控制计数器的初始值和节拍长度,可以调整系统的节拍频率和长度,从而满足不同的应用需求。
三、工作脉冲的概念及其与主时钟信号的关系工作脉冲是指系统中的一个短暂的脉冲信号,通常用于触发某个具体操作或事件。
与节拍不同的是,工作脉冲的长度可以是任意的,且不一定与主时钟信号的周期一致。
工作脉冲的产生通常通过触发器实现,触发器在接收到主时钟信号的特定边沿时,输出一个短暂的高电平或低电平信号。
在数字电子系统中,工作脉冲的产生和应用非常广泛。
例如,当需要在特定时刻对某个寄存器进行写入操作时,可以通过一个工作脉冲信号来触发写入动作。
此时,主时钟信号驱动着触发器的工作,而工作脉冲则起到了控制信号的作用。
通过控制工作脉冲的触发时机和长度,可以实现对系统中各个操作的精确控制。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
1 系统中断与时钟节拍
1.1 系统中断
中断是种硬件机制用于通知CPU有个异步事件发生了中断旦被系统识别CPU则保存部分(或全部)现场
(context)即部分(或全部)寄存器值跳转到专门子称为中断服务子(ISR)中断服务子做事件处理处理完成后执行任务调度回到就绪态优先级最高任务开始运行(对于可剥夺型内核)中断使得CPU可以在事件发生时才予以处理而不必让微处理器连续不断地查询(polling)是否有事件发生通过两条特殊指令:关中断(disable errupt)和开中断(enable errupt)可以让微处理器不响应或响应中断在实时环境中关中断时间应尽量短关中断影响中断响应时间关中断时间太长可能会引起中断丢失中断服务处理时间应该尽可能短中断服务所做事情应该尽可能少应把大部分工作留给任务去做
1.2 系统时钟节拍
时钟节拍是特定周期性中断(时钟中断)这个中断可以看作是系统心脏脉动操作系统通过时钟中断来确定时间间隔实现时间延时及确定任务超时中断之间时间间隔取决于不同应用般在10~200 ms之间时钟节拍式中断使得内核可以将任务延时若干个整数时钟节拍以及当任务等待事件发生时提供等待超时依据时钟节拍频率越快系统额外开销就越大系统定义了32位无符号整数OSTime来记录系统启动后时钟滴答数目用户必须在多任务系统启动以后再开启时钟节拍器也就是在OSStart之后μC/OSII中时钟节拍服务是通过在中断服务子中OSTimeTick实现时钟节拍中断服务子示意代码如下:
void OSTickISR(void) {
保存处理器寄存器值;
OSIntEnter 或是将OSIntNesting加1;
OSTimeTick ;
OSIntExit ;
恢复处理器寄存器值;
执行中断返回指令;
}
2 时钟管理系统
2.1 μC/OSII时钟管理系统
μC/OSII原有时钟管理系统类似于Linux但是比Linux简单得多它仅向用户提供个周期性信号OSTime时钟频率可以设置在10~100 Hz时钟硬件周期性地向CPU发出时钟中断系统周期性响应时钟中断每次时钟中断到来时中断处理更新个全局变量OSTimeμC/OSII时钟中断服务核心是OSTimeTick OSTimeTick 用来判断延时任务是否延时结束从而将其置于就绪态其伪代码如下:
void OSTimeTick(void) {
OSTimeTickHook;// 用户定义时钟节拍外连
while { (除空闲任务外所有任务)
OS_ENTER_CRITICAL;//关中断
对所有任务延时时间递减;
扫描时间到期任务并且唤醒该任务;
OS_EXIT_CRITICAL;//开中断
指针指向下个任务;
}
OSTime;//累计从开机以来时间
}
在μC/OSII时钟节拍中需要执行用户定义时钟节拍外连OSTimeTickHook 以及对任务链表进行扫描并且递减任务延时这样就造成了时钟节拍OSTimeTick 有两点不足:
①在时钟中断中处理额外任务OSTimeIickHook 这样增加了中断处理负担影响了定时服务准确性;
②在关中断情况下扫描任务链表任务越多所需要时间越长而长时间关中断对中断响应有不利影响是中断处理应当避免
2.2 改进时钟管理系统
针对上述OSTimeTick 不足之处需加以改进来优化时钟节拍在Linux中般对中断响应分为两部分:立即中断服务和底半中断处理(bottom half)立即中断服务仅仅做重要并且能快速完成工作而把不太重要需要较长时间完成工作放在底半处理部分来完成这样就可以提高中断响应速度μC/OSII不支持底半处理为了减轻时钟中断处理工作量来提高μC/OSII时钟精确度可以将部分在每次时钟中断需处理工作内容放在任务级来完成这样就可以减少每次时钟中断处理CPU消耗从而提高中断响应速度和μC/OSII时钟精确度为此定义任务OSTimeTask 由它来处理原来在OSTimeTick中需要处理操作μC/OSII采用基于优先级抢占式调度策略而每次时钟中断处理结束后需要首先调度该任务执行因此让任务OSTimeTask具有系统内最高优先级由它执行用户定义时钟节拍外连OSTimeTickHook 以及对所有任务延时时间进行递减并把到期任务链入到链表OSTCBRList中OSTCBRList管理所有到期任务OSTimeTask伪代码如下:
void OSTimeTask {
OSTimeTickHook//用户定义时间处理
while { (除空闲任务外所有任务)
对所有任务延时时间进行递减;
把所有要到期任务链入到OSTCBRList链表中;
} 任务状态改为睡眠OSSched 进行任务调度;
}
在任务OSTimeTask中执行原来在时钟中断处理用户OSTimeIickHook 并实现将延时到期任务链入到OSTCBRList链表中这样在时钟中断中就只需要扫描任务到期链表而不需要扫描整个链表减少了关中断时间,OSTCBRList为新建链表它管理所有到期任务,同时需要减少OSTimeTick 执行工作量只对OSTCBRList链表扫描这样也减少了关中断时间OSTimeTick 伪
代码如下:
void OSTimeTick(void) {
OSTime;
OS_TCB* ptcb=OSTCBList;// OSTCBRList指向所有到期任务链表
while(ptchb!=null){
关中断;
唤醒任务;
开中断;
指针指向下个任务;
}
}。