基于μC/OS-II的智能窗系统设计

发布者:心怀感恩最新更新时间:2010-02-22 来源: 单片机与嵌入式系统应用关键字:ARM  μC/OS-II  智能窗 手机看文章 扫描二维码
随时随地手机看文章

1 系统硬件设计

    智能窗所要完成的功能如下:自动智能防盗并能短信通知户主,监控煤气泄漏,自动防风,自动防雨,智能遥控开关窗门。CPU的选择是嵌入式系统开发的关键所在。本文选用Luminary Micro(流明诺瑞)公司生产的Stellaris(群星)系列微控制器LM3S615,并以该芯片为核心搭建系统硬件平台。LM3S615是Luminary公司首款基于ARM Crotex—M3内核的微控制器,具有高性能的32位运算能力和低延迟的中断响应,在汽车电子和工控领域有出色的表现。系统架构如图1所示。

2 系统软件设计

2.1 μc/os—II的移植

    μC/OS—II是一种源码开放、移植性好、可裁减、抢占式的实时多任务操作系统内核。其中大部分代码是用ANSI C语言编写的,只有极少部分与处理器密切相关的代码需用汇编完成。基于μc/os—II嵌入式操作系统的软件体系结构如图2所示,它包括应用软件程序、与应用软件相关的代码、与处理器无关的代码以及与处理器相关的代码。所谓移植就是编写与处理器相关的代码,分别是头文件OS_CPU.H、汇编文件OS_CPU_A.ASM和C语言源文件OS_CPU_C.C。

    ①在OS_CPU.H中定义相关的宏,声明LM3S615能够识别的数据类型和堆栈增长方向。

    ②在OS_CPU_C. C中定义6个函数:OSTaskStklnit()、OSTaskCreateHook()、OSTaskSwHook()、OSTaskDelHook()、OSTaskStatHook()、OSTimeTickHook()。

    ③在0S_CPU_A.ASM中修改以下5个汇编函数:OS ENTER_CRITICAL()、0S_EXIT_CRITICAL()、OS_StartHighRdy、OSCtxSw、OSIntCtxSw。

    ④在主头文件INCLUDES.H中增加OS_CPU.H、OS_CPU_C.C和0S_CPU_A.ASM。

    ⑤在配置文件OS_CFG.H中定义最大事件数、最多内存分块数、最多消息队列数、最多任务数、最低任务优先级、是否允许信号量使能、是否允许邮箱使能、是否允许消息队列使能、时钟节拍数以及其他的一些配置。通过修改这些设置,可对μC/OS—II进行裁减,使之适应本系统的具体需要。

2.2 μC/OS—II下多任务机制的实现

    根据系统的功能模块,可将整个系统划分为几个并行存在的任务来运行,各个任务完成相对独立的功能。μC/OS—II是占先式操作系统,对任务的调度是按优先权的高低进行的,优先权的设置按照整个系统运行的时序来确定,对系统安全运行较重要和对实时性要求较严格的任务设成较高的优先级。各任务优先级由高到低依次为:煤气处理任务、盗情处理任务、下雨处理任务、大风处理任务、红外遥控任务、电机开窗任务、电机关窗任务、短信任务。在系统运行过程中,各任务的优先级固定不变。CPU对大多数事件的处理都放在任务中完成,而各个任务由对应的信号量激活。信号量可以由任务或外部中断来发送。

 

    (1)任务建立和资源分配

    μC/OS—II是一个实时多任务操作系统,所以把系统软件分割成多个任务,每个任务负责完成相应的处理工作,系统功能由多个任务协作完成。本系统的任务分配如表1所列。

                                                

    (2)主要任务描述首先建立一个main()函数,在主函数中调用OS-Init()函数初始化μC/OS-II,然后建立第一个任务(起始任务),最后调用OS-Start()函数启动多任务。在建立主函数之前必须定义各个任务的堆栈、系统的全局变量和相关宏。主函数的程序清单如下:

   
    起始任务是系统建立的第一个任务,主要有3个功能:完成对目标板的初始化(主要是定时器、外部中断和串行口的初始化),建立系统所要用到的信号量,建立系统的其他任务。起始任务部分程序清单如下:

   

   

    在电机开窗任务中首先等待信号量sem_open。该信号量是由煤气处理任务、红外遥控处理任务发送的。如果电机开窗任务得到该信号量,程序就设置电机转动方向,并控制PWM送出电机转动脉冲,直到窗户被打开。

    电机关窗任务必须等到信号量sem_close有效时才会被激活。信号量sam_close由盗情处理任务、下雨处理任务、大风处理任务、红外遥控处理任务发送。

    短信任务则要得到盗情处理任务发出的信号量sam_dq时被激活。系统采用门磁传感器作为人室盗窃报警信号发生器。当窗户被打开时,门磁的开关状态发生变化,信号被发送到微处理器。微处理器检测到信号输入、控制GPRS模块发送中文报警信息给户主手机,户主可根据短信及时报警,避免造成更大的损失。

3 小 结

    完成了基于32位ARM微处理器LM3S615和嵌入式实时操作系统μc/os—II的嵌入式智能窗的设计开发,并为嵌入式系统开发提供了一种解决方案。μc/os—II作为一个优秀的RTOS已经被成功移植到多种体系结构的微处理器上。将其移植到ARM平台上能够更深刻地理解RTOS的构造,加快应用和开发。把μC/OS—II引入到智能窗控制系统的软件设计中,使软件的开发更具层次性,开发效率更高,系统的稳定性、可靠性、实时性更强,也更容易扩展。

关键字:ARM  μC/OS-II  智能窗 引用地址:基于μC/OS-II的智能窗系统设计

上一篇:μCOS-II实时操作系统在μ′nSPTM中的低功耗研究
下一篇:MiniGUI在基于OMAP5912开发板上的移植

推荐阅读最新更新时间:2024-05-02 21:00

基于AT91 M42800A的LED显示系统设计
最近,笔者在某工厂大型生产线上基于现场总线的物流呼叫系统项目中发现,由于所需要显示的信息流比较大,用现有的基于AT89C51芯片组成的LED显示屏控制系统,由于受到微处理器的处理速度、体系架构、寻址范围、外围接口资源等诸多限制,已难以在要求显示较多像素、显示内容帧频较高、动态显示效果复杂的情况下,得到良好的动态视觉效果。针对以上情况,在利用现有资源的基础上,重新设计和研制了一种全新的,由32位高性能ARM微处理器组成的LED显示屏控制系统,并通过RS485接口与现场总线中的上位机进行实时数据通信,实现整个系统的信息显示。 1 系统硬件结构 该系统的硬件组成框图如图1所示。图1中,微处理器是Atmel公司生产的AT91M
[单片机]
基于AT91 M42800A的LED显示系统设计
ARM处理器系统初始化编程注意事项
在上述系统初始化过程中有以下两点需要注意,如果处理不好就可能出现程序跑飞的情况。 1)如果需要将程序从flash搬移到DRAM中运行 在现代嵌入式系统中,由于DRAM的速度比flash的速度快很多,所以除了极少数对性能要求不高但对成本要求很高的系统把程序放在flash中并一直在flash中运行外,大部分嵌入式系统都是将程序从flash芯片搬到DRAM芯片中运行,这样就会存在一个问题,因为我们编译链接程序都是将程序链接到程序最后运行的场所DRAM中的地址上,但是系统启动时只能从flash中读取指令,所以从系统启动读取的第一条指令到进入到DRAM运行前的程序代码是与地址无关的,如果要跳转到某个标号处运行,必须是基于pc的,不能是绝对跳转
[单片机]
OK6410A 开发板 (八) 118 linux-5.11 OK6410A linux对arm异常处理的相同部分解析
.section .vectors, ax , %progbits .L__vectors_start: W(b) vector_rst W(b) vector_und W(ldr) pc, .L__vectors_start + 0x1000 W(b) vector_pabt W(b) vector_dabt W(b) vector_addrexcptn W(b) vector_irq W(b) vector_fiq 每种处理方式中相同的部分 // 8个入口 1. 直接定义 2个 vector_rst: ARM( swi SYS_ERROR0 )
[单片机]
基于ARM与电力线载波技术的广场照明系统设计
O 引言 目前大空间的广场或教室等场所的照明系统绝大部分都采用完全照明的方式,即使只有某个部分区域有人活动也会开放全部的照明设备,从而造成了巨大的电能浪费。因此设计了基于ARM9和电力线载波通信技术相结合的控制系统,能够实时检测大空间中各区域人员活动情况,并根据控制指令以及事先设好的算法控制相应区域的照明设备点亮及照明时间,并能够对控制信息、照明情况进行记录,便于管理与查询。这样在人员较少的时候,大空间中只有局部区域照明设备点亮,从而实现大幅度节约电能。 1 硬件组成及原理 为了更好地实现控制与节能,将广场照明系统分为若干个区域,每个区域都由一个单片机从机系统负责单独控制。广场分区照明系统总体结构如图1所示,整个系
[单片机]
基于ARM微控制器LPC2134的多道脉冲幅度分析器设计
  多道脉冲幅度分析器不仅能自动获取能谱数据,而且一次测量就能得到整个能谱,因此可大大减少数据采集时间,与此同时,其测量精度也显着提高。自从20世纪50年代以来,多道脉冲幅度分析器发展迅速,现在已成为获取核能谱数据的通用仪器。   多道分析任务是将被测量的脉冲幅度范围平均分成2n个幅度间隔,然后测量幅度在每一个幅度间隔内的输入脉冲个数,最后得到输入信号的脉冲幅度分布曲线。其测量采用的是计算机技术中的A/D模数变换及数据存储技术。   在计算机的存储器中开辟一个数据缓冲区,数据缓冲区内有2n个计数器,每一个脉冲幅度间隔在数据缓冲区内部有一个对应的计数器。多道脉冲幅度分析时,可在微处理器的控制下,将被分析的脉冲信号首先送往模数
[单片机]
基于<font color='red'>ARM</font>微控制器LPC2134的多道脉冲幅度分析器设计
低成本ARM 32位MCU,开发人员面临的两种选择
要使用低成本的 32位微控制器 ,开发人员面临两种选择,基于Cortex-M3内核或者ARM7TDMI内核的处理器。如何做出选择?选择标准又是什么?本文主要介绍了ARM Cortex-M3内核微控制器区别于ARM7的一些特点,帮助您快速选择。 1.ARM实现方法 ARM Cortex-M3是一种基于 ARM V7架构 的最新ARM嵌入式内核,它采用哈佛结构,使用分离的指令和数据总线(冯诺伊曼结构下,数据和指令共用一条总线)。从本质上来说,哈佛结构在物理上更为复杂,但是处理速度明显加快。根据摩尔定理,复杂性并不是一件非常重要的事,而吞吐量的增加却极具价值。 ARM公司对Cortex-M3的定位是:向专业嵌入式市场提供低
[单片机]
ARM920T MMU-CP15协处理器的寄存器
ARM 微处理器可支持多达 16 个协处理器,用于各种协处理操作,在程序执行的过程中,每个协处理器只执行针对自身的协处理指令,忽略 ARM 处理器和其他协处理器的指令。ARM 的协处理器指令主要用于 ARM 处理器初始化 ARM 协处理器的数据处理操作,以及在ARM 处理器的寄存器和协处理器的寄存器之间传送数据,和在 ARM 协处理器的寄存器和 存储器 之间传送数据。 ARM 协处理器指令包括以下 5 条: CDP 协处理器数操作指令 LDC 协处理器数据加载指令 STC 协处理器数据存储指令 MCR ARM 处理器寄存器到协处理器寄存器的数据传送指令 MRC 协处理器寄存器到ARM 处理器寄存器的数据传送指令
[单片机]
基于ARM920T的两种CAN总线扩展方式
1、引言 随着工业控制系统逐步的自动化,现代化,现场总线控制系统得到越来越多的重视和应用,CAN总线是目前开发简单,性能价格比高的一种现场总线 。相对其他现场总线而言,CAN通信控制器的生产厂家最多、品种最全、应用也最为广泛。基于现场总线控制系统智能化、复杂度的提高,作为现场总线的核心部件微处理器,传统的51芯片,甚至ARM7已经逐渐不能满足需要,ARM9成为合适的选择。但许多ARM9并没有集成CAN接口,扩展CAN接口成为当务之急。且ARM9将数据地址总线分开,而CAN控制器为数据地址总线复用,使得CAN的扩展不能一味照搬51处理器的方式。在CAN模块驱动开发上,现有资料往往只针对Linux系统上的驱动开发 进行介绍,而现场总
[单片机]
基于<font color='red'>ARM</font>920T的两种CAN总线扩展方式
小广播
最新嵌入式文章
何立民专栏 单片机及嵌入式宝典

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

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