当前位置:首页 > 工业控制 > 工业控制
[导读]摘要:首先介绍了nesC语言及专门面向传感器网络的TinyOS操作系统软件平台,然后阐述了网络节点的硬件模块功能特点及其接口电路,最后根据硬件抽象体系结构的原则,在TinyOS操作系统平台下,对CC2420无线收发模块驱动

摘要:首先介绍了nesC语言及专门面向传感器网络的TinyOS操作系统软件平台,然后阐述了网络节点的硬件模块功能特点及其接口电路,最后根据硬件抽象体系结构的原则,在TinyOS操作系统平台下,对CC2420无线收发模块驱动组件设计作了深入的研究,以组件的形式将其硬件功能封装成接口供上层软件调用,实现了对上层软件的硬件特征屏蔽,从而实现该模块功能的软件语言表达和兼容性较强的跨平台抽象体系结构。
关键词:无线传感器网络;TinyOS;CC2420;硬件抽象体系结构

引言
    网络节点是构成无线传感器网络的基本单位,无线传感器网络节点有两种常用体系结构:Atmel AVR处理器+TinyOS和MSP430+TinyOS,本文采用ATmega128L+TinyOS的体系结构。因此,CC2420驱动组件设计应符合TinyOS的硬件抽象体系结构(HardWare Abstraction Architectu re,HAA)。TinyOS中将硬件抽象体系结构分为3层:硬件表示层(Hardware Presentation Layet,HPL)、硬件适配层(Hardware Adapation Layer,HAL)和硬件接口层(HardWare Interfaec Layer,HIL)。各层功能作用及具体设计原理在本文中作了细致的研究。CC2420是一款基于IEEE 802.15.4协议的低功耗无线收发模块。本文根据硬件抽象体系结构的原则,对CC2420无线收发模块在TinyOS平台下的驱动组件设计作了深入的研究,这使得基于CC2420硬件的无线传感器网络(Wireless Sensor Network,WSN)应用程序的开发,可以与TinyOS操作系统的组件模型、主动消息、基于事件驱动等机制有效地结合起来,使应用程序具有代码量小、能耗少、并发性高等特点。

1 nesC语言及TinyOS操作系统
    早期的面向传感器网络的操作系统TinyOS是用汇编和C语言开发的。但经研究发现,C语言并不能高效地完成传感器网络的应用开发。所以研究人员对C语言进行了一定的扩展,提出了一种新型的编程语言——支持组件化编程的nesC(C language for network embedded sys
tems)语言。用nesC语言编写的TinyOS,将轻量级线程、主动消息通信模型、事件驱动机制和组件化编程等技术相结合,是一种专门为无线传感器网络开发的微型操作系统,使面向传感器网络的操作系统及应用程序开发的复杂度大大降低,使程序的整体性能得到优化,提高了程
序的健壮性和安全性。
    TinyOS采用组件模型,这种模块化的思想使得应用程序的编写更加方便、高效。程序开发人员可以方便快捷地将独立的组件组合到各种配件文件中,并在应用程序的顶层(top-level)配件文件中完成程序的整体装配。TinyOS的组件模型体系结构如图1所示。


    上层组件对下层组件发命令,下层组件向上层组件发信号通知事件,最底层的组件直接和硬件打交道。TinyOS中有3种类型的组件:硬件抽象组件、合成组件、高层软件组件。硬件抽象组件将物理硬件映射到TinyOS组件模型;合成组件模拟高级硬件行为;高层软件组件负责数据传输、控制、路由等。本文针对的是实际硬件上的抽象层。

2 节点硬件模块
    节点采用ATmega128L微处理器和CC2420无线收发模块,硬件连接如图2所示。


    CC2420无线收发芯片符合IEEE 802.15.4标准,工作在ISM 2.4GHz频段。其内部集成了压控振荡器、天线、16MHz晶振等外围电路。CC24 20通过SPI接口与ATmega128L完成设置和收发数据两方面的任务。如图2所示,SPI接口由CSn、SI、SO和SCLK四个引脚构成。ATmega128L为接口主设备,访问CC2420内部寄存器和存储区;CC2420为SPI接口从设备,接收时钟信号和片选信号,并在处理器的控制下执行输入/输出操作。
    CC2420通过SFD、FIFO、FIFOP和CCA四个引脚与ATmega128L表示收发数据状态。CC2420收到物理帧的SFD字段后,会在SFD引脚输出高电平,直到接收完该帧。如果启用了地址识别,在地址识别后,SFD引脚立即转为输出低电平。FIFO和FIFOP引脚标识FIFO缓存区的状态。如果接收FIFO缓存区有数据,FIFO引脚输出高电平;如果接收FIFO缓冲区为空,FIFO引脚输出低电平。FIFOP引脚在接收FIFO缓存区的数据超过某个临界值时或者在CC2420接收到一个完整的帧以后输出高电平,触发ATmega128L的中断。CCA引脚有效表示信道空闲评估有效,通常为CSMA-CA算法的实现提供依据。

3 CC2420驱动组件
    TinyOS中的硬件抽象体系结构分为3层:硬件表示层、硬件适配层和硬件接口层。本设计根据实际需求,完成了其中两层结构的实现。
3.1 HPL组件
    如前面所述,ATmega128L通过SPI接口访问CC2420内部寄存器和存储区,CC2420使用SFD、FIFO、FIFOP和CCA四个引脚表示收发数据状态。硬件表示层的作用就是根据这种硬件连接将CC2420所提供的硬件基本功能以接口函数的形式封装起来,供上层HAL组件调用,实现对底层硬件的隔离。
    HPL体系结构如图3所示。HPL组件包括3个模块文件HPLCC2420FIFOM、HPLCC2420M、HPLCC2420Interrupt,分别实现CC2420的不同功能接口,最后由HPLCC2420C以组件的形式将所有的接口函数封装起来,提供给HAL组件调用。


    HPLCC2420FIFOM模块文件实现了 HPLCC2420FIFO接口,完成了对发送、接收数据缓存区的读写控制工作,主要接口函数如下:
   
    HPLCC2420M模块文件实现了3个接口:
    ①StdControl接口,完成ATmega128L中与CC2420相连的硬件引脚端口电平设置及硬件SPI接口相关寄存器的初始化工作。
    ②HPLCC2420接口,实现CC2420内部寄存器的读写功能。CC2420有33个控制/状态寄存器、15个命令选通寄存器和2个访问FIFO缓存区的寄存器。
    ③HPLCC2420RAM接口,实现对CC2420内部RAM的读写功能。CC2420的内部RAM分为3块——128字节的发送FIFO缓存区、128字节的接收FIFO缓存区以及112字节的用于保存设备地址、密钥等信息的存储区。
    主要接口函数如下:
   
    HPLCC2420InterruptM模块文件实现了HPLCC2420Interrupt、HPLCC2420Capture接口,主要完成中断捕捉功能。CC2420使用SFD、FIFO、FIFOP和CCA四个引脚表示收发数据状态,当引脚电平变化时,触发ATmega128L硬件中断。TinyOS平台下,根据事件驱动机制,向上调用HPLCC 2420Interrupt(类似HPLCC24240Capture)接口中的事件通告函数result_t fired(void)进行上层处理。HPLCC2420Interrupt接口中使用resul t_t startWait(bool low_to high)函数设置触发方式(上升沿还是下降沿),使用result_t disable(void)函数禁止中断使能。HPLCC2420 In terruptM模块文件还调用了HPLTimerlM.nc和TimerC.nc文件中的Timer接口函数,完成相关的底层中断处理。
3.2 HAL组件
    HAL组件使用HPL组件HPLCC2420C提供的源接口,在CC2420所提供的基本功能的基础上进一步抽象,形成CC2420初始化、设备地址设置、收发模式设置、发送接收消息等复杂功能,同时以组件接口的形式进行封装供上层HIL组件调用。HAL体系结构如图4所示。HAL组件包括两个模块文件CC2420RadioM.nc和CC2420Control.nc,最后由配置文件CC2420RadioC.ne装配起来。


    CC2420ControlM模块文件使用SplitControl接口完成CC2420的寄存器初始化、启动等工作,主要函数如下:command result_t Split Control.init();//CC2420寄存器初始化command result_t SplitControl.start();//开启1.8 V稳压源供电,将复位RSTN引脚置为高电平,启动CC2420晶振CC2420ControlM模块文件还实现了CC2420Control接口,实现对CC2420的一些控制功能:
   
    CC2420RadioM使用BareSendMsg接口发送消息,使用ReceiveMsg接口接收消息:
   

结语
    首先以TinyOS操作系统为软件平台,根据网络节点的硬件模块功能及其接口电路的特点,在硬件抽象体系结构的原则下,对CC2420无线收发模块在TinyOS平台下的驱动组件设计作了深入的研究。实验表明,节点在满足指标要求的同时运行稳定可靠。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

舍弗勒以"专注驱动技术的科技公司"为主题亮相IAA MOBILITY 2025(B3馆B40展台) 合并纬湃科技后首次亮相IAA MOBILITY,展示拓展后的汽车产品组合 凭借在软件、...

关键字: 电气 软件 驱动技术 BSP

香港2025年 9月12日 /美通社/ -- 全球领先的互联网社区创建者 - 网龙网络控股有限公司 ("网龙"或"本公司",香港交易所股票代码:777)欣然宣布,其子公司My...

关键字: AI 远程控制 控制技术 BSP

深圳2025年9月11日 /美通社/ -- 2025 年 9 月 10 日,第 26 届中国国际光电博览会(简称 "CIOE 中国光博会")在深圳盛大开幕。本届展会吸引力再创新高,全球超3800家优质...

关键字: 自动化 光电 CIO BSP

天津2025年9月11日 /美通社/ -- 国际能源署(IEA)数据显示,2024 年全球数据中心电力消耗达 415 太瓦时,占全球总用电量的 1.5%,预计到 2030 年,这一数字将飙升至 945 太瓦时,近乎翻番,...

关键字: 模型 AI 数据中心 BSP

北京2025年9月11日 /美通社/ -- 国际9月11日上午,2025年中国国际服务贸易交易会(以下简称"服贸会")—体育赛事经济高质量发展大会现场,北京经济技术开发区工委委员、管委会副主...

关键字: 5G BSP GROUP MOTOR

柏林2025年9月9日 /美通社/ -- 2025年9月5日,纳斯达克上市公司优克联集团(NASDAQ: UCL)旗下全球互联品牌GlocalMe,正式亮相柏林国际消费电子展(IFA 2025),重磅推出融合企...

关键字: LOCAL LM BSP 移动网络

深圳2025年9月9日 /美通社/ -- PART 01活动背景 当技术的锋芒刺穿行业壁垒,万物互联的生态正重塑产业疆域。2025年,物联网产业迈入 "破界创造"与"共生进化" 的裂变时代——AI大模型消融感知边界,...

关键字: BSP 模型 微信 AIOT

"出海无界 商机无限"助力企业构建全球竞争力 深圳2025年9月9日 /美通社/ -- 2025年8月28日, 由领先商业管理媒体世界经理人携手环球资源联合主办、深圳•前海出海e站通协办的...

关键字: 解码 供应链 AI BSP

柏林2025年9月9日 /美通社/ -- 柏林当地时间9月6日,在2025德国柏林国际电子消费品展览会(International Funkausstellung...

关键字: 扫地机器人 耳机 PEN BSP

武汉2025年9月9日 /美通社/ -- 7月24日,2025慧聪跨业品牌巡展——湖北•武汉站在武汉中南花园酒店隆重举办!本次巡展由慧聪安防网、慧聪物联网、慧聪音响灯光网、慧聪LED屏网、慧聪教育网联合主办,吸引了安防、...

关键字: AI 希捷 BSP 平板
关闭