一种提高uc/os-ii操作系统安全性与稳定性的方法

发布者:炫酷骑士最新更新时间:2013-11-04 来源: 21ic关键字:ucos-ii  LPC1786  Cortex-M3 手机看文章 扫描二维码
随时随地手机看文章
引言

μC/OS-II是基于优先级的可剥夺型内核,实时性较强,但不区分用户空间和系统空间,使得系统的安全性变差。而μC/OS-II官网提供的基于Cortex-M3内核移植的μC/OS-II操作系统,一直运行在特权级下,用户程序也可以访问操作系统的变量和常量,导致系统的安全性与稳定性变得更差。

1 开发坏境与Cortex-M3内核简介

使用IAR 5.30开发环境,移植μC/OS-II 2.86到Cortex-M3内核上,选用配置了MPU的LPC1786处理器作为硬件实验平台。

Cortex-M3处理器支持:两种工作模式,线程模式和处理模式;两种访问等级,特权级和用户级;两个堆栈指针,主堆栈指针(MSP)和进程堆栈指针(PSP)。异常处理工作在“处理模式+特权级+MSP”下;线程模式下,访问等级与堆栈指针可以相互搭配使用;但是在用户级下,对特殊功能寄存器和系统控制空间(SCS)的大部分寄存器的访问是禁止的。

如果处理器(如LPC1700系列、LM3S系列等)配置有MPU,可通过设定内存的访问权限大幅度地提高系统的安全性。

2 μC/OS-II内核简介

μC/OS-II操作系统凭借其源代码公开、结构小巧、内核可剥夺、实时性高等诸多特性而得到广泛的应用,并且μC/OS-II绝大部分代码是用C语言编写的,便于移植到各种内核上。它提供了诸如任务调度、任务管理、时间管理、内存管理、中断管理,以及任务间的同步与通信等实时内核的基本功能,而没有提供输入输出管理、文件系统、图形用户接口及网络组件之类的额外服务。但由于μC/OS-II具有较好的可移植性和开源性,用户可以根据实际应用添加所需要的服务,而且系统移植只需修改文件OS_CPU_C.C、OS_CPU.H、OS_CPU_A.ASM。

3 μC/OS-II操作系统移植的改进

如果用户任务运行在“用户级+PSP”状态下,而调用操作系统函数时运行在“特权级+MSP”状态下,再配合MPU的使用,可以使系统的安全性与稳定性得到很大的提高。

3.1 设置系统寄存器

系统任务(统计任务、空闲任务等)只使用主堆栈指针MSP,并且一直运行在特权级下;而用户任务则使用PSP、MSP两个堆栈。在系统初始化时,设置MPU的相关寄存器,把内存分为特权级与用户级两个区,如图1所示。PSP分配在用户区,MSP、系统变量与常量分配在特权区,以提高系统的安全性。

3.2 修改系统函数

为了任务首次运行时,可以进入相应的访问等级和使用相应的堆栈指针,在任务创建时,加入工作状态参数mode。在ucos_ii.h中定义访问等级与堆栈选择的常量:

3.2.1 修改任务控制块OS_TCB

在任务控制块中加入MSP指针,形式如下:
[page]

3.2.2 修改任务创建函数

在任务创建函数的参数中加入mode参数,形式如下:

对OSTaskCreateExt()函数做的修改同上。

3.2.3 修改堆栈初始函数

在堆栈初始化时,把mode值存储在MSP底部,以便任务第一次运行时进入相应的运行状态(特权级还是用户级,使用MSP还是PSP)。系统任务的mode是OS_Mode_PRIVILEGE | OS_Mode_MSP,任务创建时PSP为0;而用户任务为OS_Mode_USER | OS_Mode_PSP。

堆栈初始函数的参数中加入mode参数,形式如下:

OS_TCBInit()函数把堆栈初始化得到的堆栈指针存入OS_TCB中。

3.3 修改OS_CPU_A.ASM文件中的函数

在OS_CPU_A.ASM文件中,只需修改函数PendSV_Handler(PendSV服务例程),任务切换是由它来完成的。
PendSV服务例程的流程如图2所示。


3.4 系统函数的使用

系统函数都是在“特权级+MSP”状态下执行的,因此,在用户任务调用系统函数前,应先切换到“特权级+MSP”状态,系统函数执行完毕后再切换到“用户级+PSP”状态。具体代码如下。




在特权级下通过置位CONTRO[0]来进入用户级,而用户级下是不能直接修改CONTROL[0]回到特权级的,必须通过一个异常,在异常例程中修改CONTROL[0],才能在返回到线程模式后拿到特权级。通常的方法是使用软中断SVC。

因此,从“用户级+PSP”状态下切换到“特权级+MSP”状态的实现方法是:在用户级下执行SVC指令,在SVC异常服务函数中清零CONTROL[0]位,再返回到线程模式下清零CONTROL[1]位切换到MSP;而从“特权级+MSP”状态下切换到“用户级+PSP”状态下,只需置位CONTROL[0]与CONTROL[1]。

4 系统测试

在基于第二代Correx-M3内核的LPC1786处理器的语音识别系统上,对修改后的操作系统进行测试。具体测试过程为:首先创建3个信号量0、1、2(计数器初始值都为0);ADC按10 kHz的频率对语音信号采样,采样200点(也就是一帧数据)后发送信号量0(发生中断级切换);任务0(优先级0)请求信号量0,并对语音信号预处理并检测语音信号的起始端与结束端;当任务0检测到起始端后,每处理完一帧数据都发送信号量1(产生任务级切换),直到检测到结束端,任务1(优先级1)请求道信号量1后对真正的语言信号进行特征提取;当任务0检测到语音信号结束端时发送信号量2,任务2(优先级2)获得信号量2后利用DWT算法对语音信号进行识别并显示到LCD屏上。
测试结果表明,改进后的系统抗干扰能力、稳定性和安全性均大大增强,并且系统连续稳定地运行很长时间,没有出现任何问题,可见系统移植成功。

结语

改进后的系统,内存的使用没有增加,只是增加了很小的系统开销;但配合MPU使用,使系统的安全性和稳定性得到了很大的提高。该方法可广泛应用于对系统安全性与稳定性要求比较高的场合。

关键字:ucos-ii  LPC1786  Cortex-M3 引用地址:一种提高uc/os-ii操作系统安全性与稳定性的方法

上一篇:嵌入式Web服务器移植与测试
下一篇:TI首次将Cortex-M4 MCU中集成MAC+PHY

推荐阅读最新更新时间:2024-03-16 13:30

ucos-ii示例4:邮箱测试
环境: 主机:WIN8 开发环境:MDK4.72 ucgui版本:3.90 ucos版本:ucos-ii mcu: stm32f103VE 说明: 本示例中task1通过邮箱发送数据给task2 效果图: 源码: #define TASK_STK_SIZE 512 /********************************************************************* * 静态函数 ****************************************************************
[单片机]
<font color='red'>ucos-ii</font>示例4:邮箱测试
Cortex-M3 的SVC、PendSV异常,与操作系统(ucos实时系统)
SVC异常是? PendSV异常是? ucos 任务切换时机? ucos 如何满足实时性(实现)? ucos中,systick的优先级? SVC和PendSV SVC(系统服务调用,亦简称系统调用)和PendSV(可悬起系统调用),它们多用于在操作系统之上的软件开发中。 SVC: SVC 用于产生系统函数的调用请求。 例如,操作系统不让用户程序直接访问硬件,而是通过提供一些系统服务函数,用户程序使用SVC 发出对系统服务函数的呼叫请求,以这种方法调用它们来间接访问硬件。 因此, 当用户程序想要控制特定的硬件时,它就会产生一个SVC 异常, 然后操作系统提供的SVC 异常服务例程得到执行, 它再调用相关的操
[单片机]
<font color='red'>Cortex-M3</font> 的SVC、PendSV异常,与操作系统(ucos实时系统)
ucos-ii示例2:信号量测试
环境: 主机:WIN8 开发环境:MDK4.72 ucgui版本:3.90 ucos版本:ucos-ii mcu: stm32f103VE 说明: 本示例新建一个信号量,task1接收信号量,task2发送信号量。task1时间片为1s/次,task2时间片3s/次。可以看到,因为信号量的关系,task1输出也是3s/次。 注意: 1.信号量的创建不能在内核初始化之前 源码: #define TASK_STK_SIZE 512 /********************************************************************* *
[单片机]
ucos-ii示例1:新建任务
环境: 主机:WIN8 开发环境:MDK4.72 ucgui版本:3.90 ucos版本:ucos-ii mcu: stm32f103VE 说明: 本示例新建两个任务,并运行。 注意: 1.不同任务的任务优先级必须不一样,否则只运行首先定义的任务 2.从系统时钟设置必须在内核启动后设置,否则会导致OSIntNesting一直为1,从而OS_TaskStat函数因为OSTimeDly函数一直返回0陷入死循环 //系统时钟设置,1ms嘀嗒一次 if (SysTick_Config(SystemCoreClock / OS_TICKS_PER_SEC)) { while (1); }
[单片机]
ARM Cortex-M3 内核介绍
内核包含四部分:1.乘法器;2.控制逻辑;3.Thumb指令译码器;4.内部接口 CM3内部包含元素介绍: 1. DAP,调试访问接口,Debug Access Port。Cortex‐M3 的调试系统基于 ARM 最新的 CoreSight 架构。不同于以往的 ARM 处理器,内核本身不再含有 JTAG 接口。取而代之的,是 CPU 提供称为 调试访问接口(DAP) 的总线接口。通过这个总线接口,可以访问芯片的寄存器,也可以访问系统存储器,甚至是在内核运行的时候访问!对此总线接口的使用,是由一个调试端口(DP)设备完成的。DPs 不属于 CM3 内核,但它们是在芯片的内部实现的。目前可用的 DPs包括 SWJ‐DP(既支持传统的
[单片机]
Energy Micro新增12款Cortex-M3低功耗MCU
挪威奥斯陆,2011年7月12日 – 低功耗微控制器公司Energy Micro®日前公布了其QFP64封装的EFM32 Gecko和Tiny Gecko产品线。全新64引脚器件在不断发展的智能仪表市场特别受欢迎,此外还适用于其他对功耗敏感的应用,如楼宇自动化、安防系统和便携式健康医疗及健身设备。 此次,Energy Micro为ARM® Cortex™-M3架构新引入了12款大I/O引脚数的微控制器产品,提供从8K – 128K FLASH, 2K – 16K RAM。与EFM32 MCU系列的其他封装形式一样,EFM32G232、EFM32G842、EFM32TG232和EFM32TG842也提供低功耗的Gecko技术
[单片机]
ucos-ii学习笔记——s12 lcd led 两任务信号量通信
Created on: 2012-10-17 Author: zhang bin 学习笔记 for ucos-ii MC9S12XS128 lcd12864 ser_2_pin redesigned by zhang bin 2012-10-17 versions :V-0.1 All Rights Reserved //本程序实现lcd的显示和led的闪烁,这两个任务通过信号量进行通信,要实现的效果如下: //lcd任务申请一个信号量后 显示完一个周期后停止显示并且释放信号量,led任务申请到信号量后开始闪烁,闪烁了10 //次后停止,释放信号量,lcd任务再申请信号量,继续开始显示,如
[单片机]
自己动手用Cortex-M3与ADXL345做个重力感应遥控器
 已经是很久没有写文章了,因为没有时间,人家都说大四不考研,天天像过年,可我依旧没能有那份闲暇的时间。 现在几乎人人的手里都是一款安卓智能机这是我非常羡慕的,而我手里只有上学期用380元买的一台二手诺基亚N96,虽然也称得上智能机但是远远没有如今安卓智能的优秀,其中一个功能就是通过重力感应玩赛车游戏,我想这个大家都不陌生,只要把手机歪一歪斜一斜就可以控制赛车方向了,这个功能令桥哥好生羡慕嫉妒恨,可惜自己的手机不能玩,上周突来灵感何不自己做一个玩玩。正好上学期开始着手给侄子做的四轴飞行器的基板基本调试完成,核心的芯片就是一块M3微控器,一块三轴加速度传感器ADXL345,一块三轴数字陀螺仪。而要做一个简单的重力感应遥控器用M3结合A
[电源管理]
自己动手用<font color='red'>Cortex-M3</font>与ADXL345做个重力感应遥控器
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved