ZigBee协议栈串口应用

合集下载

ZigBee协议栈串口应用

ZigBee协议栈串口应用

• ZigBee协议栈中提供的与串口操作有关的 三个函数为 可在zmain.c和hal_uart.c中查看相关函数 • uint8 HalUARTOpen(uint8 halUARTCfg_t *config); • uint16 HalUARTRead(uint8 port,uint8 *buf,uint16 len); • Uint16 HalUARTWrite(uint8 prot,uint *buf,uint16 len);
PC机
Hale Waihona Puke ZigBee网络EndDevice
Coordinator
Coordinator.c
• • • • • • • • • • • • • • • #include "OSAL.h" #include "AF.h" #include "ZDApp.h" #include "ZDObject.h" #include "ZDProfile.h" #include <String.h> #include "Coordinator.h" #include "DebugTrace.h" #if !defined( WIN32 ) #include "OnBoard.h" #endif #include "hal_lcd.h" #include "hal_led.h" #include "hal_key.h" #include "hal_uart.h"
回调函数:通过指针(函数地址)调用的函数。如果把函数 的地址作为参数传递给另一个函数,当通过这个指针 调用它所指向的函数时,称为函数的回调。

zigbee基础应用(五)uart串口通信

zigbee基础应用(五)uart串口通信

zigbee基础应用(五)uart串口通信#include <iocc2530.h>#include <string.h>#define uint unsigned int#define uchar unsigned char//定义控制灯的端口#define LED1 P1_0#define LED2 P1_1void initUART0(void);void InitialAD(void);void UartTX_Send_String(uchar *Data,int len);uchar Recdata[30]="hello zigbee!\n";uchar RXTXflag = 1;uchar temp;uint datanumber = 0;uint stringlen;/************************************************************** **串口发送字符串函数*************************************************************** */void UartTX_Send_String(uchar *Data,int len){int j;for(j=0;j<len;j++){U0DBUF = *Data++;while(UTX0IF == 0);UTX0IF = 0;}}#if 0/************************************************************** **初始化串口0函数*************************************************************** */void initUART0(void){CLKCONCMD &= ~0x40; //设置系统时钟源为32MHZ晶振while(CLKCONSTA & 0x40); //等待晶振稳定CLKCONCMD &= ~0x47; //设置系统主时钟频率为32MHZPERCFG = 0x00; //位置1 P0口P0SEL = 0x3c; //P0用作串口P2DIR &= ~0XC0; //P0优先作为UART0 U0CSR |= 0x80; //串口设置为UART方式U0GCR |= 11;U0BAUD |= 216; //波特率设为115200UTX0IF = 1; //UART0 TX中断标志初始置位1U0CSR |= 0X40; //允许接收IEN0 |= 0x84; //开总中断,接收中断}/************************************************************** **串口接收一个字符:一旦有数据从串口传至CC2530,则进入中断,将接收到的数据赋值给变量temp.*************************************************************** */#pragma vector = URX0_VECTOR__interrupt void UART0_ISR(void){URX0IF = 0; //清中断标志temp = U0DBUF;}#else/************************************************************** **初始化串口0函数*************************************************************** */void initUART0(void){CLKCONCMD &= ~0x40; //设置系统时钟源为32MHZ晶振while(CLKCONSTA & 0x40); //等待晶振稳定CLKCONCMD &= ~0x47; //设置系统主时钟频率为32MHZPERCFG = 0x00; //位置1 P0口P0SEL = 0x3c; //P0用作串口P2DIR &= ~0XC0; //P0优先作为UART0 U0CSR |= 0x80; //串口设置为UART方式U0GCR |= 11;U0BAUD |= 216; //波特率设为115200UTX0IF = 1; //UART0 TX中断标志初始置位1U0CSR |= 0X40; //允许接收// IEN0 |= 0x84; //开总中断,接收中断}/************************************************************** **主函数*************************************************************** */void main(void){P1DIR = 0x03; //P1控制LEDLED1 = 1;LED2 = 1; //关LEDinitUART0();stringlen = strlen((char *)Recdata);UartTX_Send_String(Recdata,stringlen);while(1){if(RXTXflag == 1) //接收状态{if( URX0IF == 1){LED2=0; //接收状态指示URX0IF = 0; //清中断标志temp = U0DBUF;if((temp!='#')&&(datanumber<50)) //’#‘被定义为结束字符,最多能接收50个字符{Recdata[datanumber++] = temp;}else{RXTXflag = 3; //进入发送状态}if(datanumber == 50){RXTXflag = 3;}temp = 0;LED2=1; //接收状态指示}}if(RXTXflag == 3) //发送状态{UartTX_Send_String("send:",5);LED2 = 1; //关LED2LED1 = 0; //发送状态指示U0CSR &= ~0x40; //不能收数UartTX_Send_String(Recdata,datanumber); UartTX_Send_String("\n",1);U0CSR |= 0x40; //允许接收RXTXflag = 1; //恢复到接收状态datanumber = 0; //指针归0LED1 = 1; //关发送指示memset(Recdata, 0, sizeof(Recdata));}}}#endif。

ZIGBEE技术规范与协议栈分析

ZIGBEE技术规范与协议栈分析

ZIGBEE技术规范与协议栈分析篇一:ZigBee知识无线龙1.协议栈工作流程和无线收发控制 LED 实验内容:1. ZigBee 协议栈简介2. 如何使用 ZigBee 协议栈3. ZigBee 协议栈的安装、编译与下载4. 协议栈无线收发控制 LED5. 协议栈工作流程实现现象:协调器、终端上电,组网成功后 D1 灯闪烁 1. ZigBee 协议栈简介什么是 ZigBee 协议栈呢?它和 ZigBee 协议有什么关系呢?协议是一系列的通信标准,通信双方需要共同按照这一标准进行正常的数据发射和接收。

协议栈是协议的具体实现形式,通俗点来理解就是协议栈是协议和用户之间的一个接口,开发人员通过使用协议栈来使用这个协议的,进而实现无线数据收发。

图 1 展示了 ZigBee 无线网络协议层的架构图。

ZigBee 的协议分为两部分,IEEE 802.15.4 定义了 PHY(物理层)和 MAC(介质访问层)技术规范;ZigBee联盟定义了NWK(网络层)、APS(应用程序支持子层)、APL(应用层)技术规范。

ZigBee协议栈就是将各个层定义的协议都集合在一直,以函数的形式实现,并给用户提供 API(应用层),用户可以直接调用。

图 1 ZigBee 无线网络协议层 2. 如何使用 ZigBee 协议栈协议栈是协议的实现,可以理解为代码,函数库,供上层应用调用,协议较底下的层与应用是相互独立的。

商业化的协议栈就是给你写好了底层的代码,符合协议标准,提供给你一个功能模块给你调用。

你需要关心的就是你的应用逻辑,数据从哪里到哪里,怎么存储,处理;还有系统里的设备之间的通信顺序什么的,当你的应用需要数据通信时,调用组网函数给你组建你想要的网络;当你想从一个设备发数据到另一个设备时,调用无线数据发送函数;当然,接收端就调用接收函数;当你的设备没事干的时候,你就调用睡眠函数;要干活的时候就调用唤醒函数。

所以当你做具体应用时,不需要关心协议栈是怎么写的,里面的每条代码是什么意思。

TI_zigbee协议栈结构分析应用

TI_zigbee协议栈结构分析应用

Ver:1:网络层目录,包括着网络层TI ZStack的编译与烧写§ 点击跳出对话框(如右 图)中的“Open existing workspace” 按钮.打开TI ZStack附 带的实例SampleAppTI ZStack的编译与烧写§ 我们可以选择菜单Project->Options、 右击菜单options或者通过热键( ALT+F7)打开工程属性设置。

右击TI ZStack的编译与烧写§ 选择Project->Rebuild all或者工程 右击菜单中的Rebuild all重新编译 所有文件。

右击此处单击此处进行编译 编译错误总数, 数量为0时才能 完成编译操作。

编译警告总数,警告一般 是指可能存在错误或者使 用非常规语句。

就算有警 告也能通过编译TI ZStack的编译与烧写§ 选择Project->Debug或者热键 (Ctrl+D )给开发板上的Zigbee模块下载程序也可以点击此 按钮进行烧写TI ZStack的编译与烧写§ 执行Zigbee模块烧写程序时,如果计算机连接 了多个Zigbee USB工具则会出现如下对话框 ,让我们选择目标板Zigbee编程器编号。

我们 要选择与目标板(装有Zigbee模块的开发板或 者我们生产的产品)相连接的Zigbee编程器。

点击目标编程器或双击选中选择按钮TI ZStack的编译与烧写§ 如果选择了Debug模式,我们要实现在线调试程序功能,编译时EW8051 功能按钮说明如下图所示: 调试菜单 进入函数体执行 退出函数返回到上一层执行退回程序入口单步执行程序 执行到 鼠标位置 全速执行退出调试状态工程选项设置注意事项§ Debug模式和Release模式选择。

点击此选项更改默认输出文件名 建议扩展名改为hex选择Debug模式 选择Release模式 选择输出文件格式 一般选择intel ext模式工程选项设置注意事项§ 如果选择了Debug模式,我们还要记得 选择硬件仿真,当然我们也可以使用软 件仿真。

zigbee串口应用

zigbee串口应用
CLKCONCMD &= ~0x47;
SLEEPCMD |= 0x04;
PERCFG = 0x00;
P0SEL = 0x3c;
P2DIR &= ~0xC0;
U0CSR |= 0x80;
U0GCR |= 10;
U0BAUD |= 216;
}
3)串口发送函数编写
将需要发送的数据写入到U0DBUF中
void uarttx(uchar *data,uint len)
【实验日期】
2018.5.29
【教师对报告的最终评价及处理意见】
成绩(百分制):(涂改无效)
教师:年 月 日
【实验报告】
一、实验目的:
掌握使用串口想PC机发送数据。
掌握数据采集并通过串口发送至PC端
二、实验内容:
1)实现串口发送学生的姓名至PC端
2)实现AD采集电压值并通过串口传输至PC端
三、实验设备:
void uartinit();
void uarttx(uchar *data,uint len);
2)串口初始化函数
a.系统时钟初始化;
b.选择串口作为I/O外设的引脚连接位置;
c..设置串口模式;
代码如下:
void uartinit()ቤተ መጻሕፍቲ ባይዱ
{
CLKCONCMD &= ~0x40;
while(!(SLEEPSTA & 0x40));
实 验 报 告
【2017-2018学年第2学期】
【基本信息】
【开课部门】
青软实训
【实验课程】
ZigBee技术及应用实验
独立□ 非独立□
【实验项目】
实验三:串口应用

ZigBee之Z-Stack协议栈MT层串口应用

ZigBee之Z-Stack协议栈MT层串口应用

ZigBee之Z-Stack协议栈MT层串口应用By:Timeandspace7Date:20171029 At:YSU-B3071.包含头文件#include“MT_UART.h”,2.在用户的init函数中添加MT_UartInit ();MT_UartRegisterTaskID(task_id); //注册串口任务任务注意:在MT_UartInit ()函数中,可以修改串口的波特率,uartConfig.baudRate = MT_UART_DEFAULT_BAUDRATE;,即修改#define MT_UART_DEFAULT_BAUDRATE HAL_UART_BR_38400重要:uartConfig.flowControl = MT_UART_DEFAULT_OVERFLOW语句是配置流控的,我们进入定义可以看到:#define MT_UART_DEFAULT_OVERFLOW TRUE默认是打开串口流控的,如果你是只连了TX/RX 2 根线的方式务必关流控,注意:2 根线的通讯连接一定要关流控,不然是永远收发不了信息的,现在大部产品很少用流控。

也即:将宏定义修改为#define MT_UART_DEFAULT_OVERFLOW FALSE极其重要:在项目配置选项卡中预编译处加入以下一些内容ZIGBEEPROZTOOL_P1xMT_TASKxMT_SYS_FUNCxMT_ZDO_FUNCLCD_SUPPORTED=DEBUG也即是将原来的ZIGBEEPROZTOOL_P1MT_TASKMT_SYS_FUNCMT_ZDO_FUNCLCD_SUPPORTED=DEBUG分别MT_TASK,MT_SYS_FUNC,MT_ZDO_FUNC加上x。

事实上真正的宏是MT_TASK,MT_SYS_FUNC,T_ZDO_FUNC,加x 表示不定义它们了,如果去掉上面的x,编译后下载看串口会在你想输出的数据“xxxxx”前面出现一段乱码,如果用16 进制则会显示为FE 开头的字符串,这是Z-stack MT 层定义的串口发送格式。

zigbee,协议栈,串口

zigbee,协议栈,串口

zigbee,协议栈,串口篇一:ZigBee简易串口透传第十六讲ZigBee串口透传一、串口透明传输工程说明串口透明传输工程是在SampleApp工程基础之上进行修改而成,主要功能是完成简单的串口透明传输,功能要求:1、设备上电后自动选择设备类型。

第一个启动的设备为协调器,后续启动的为路由器。

(所有设备中程序相同)2、路由器的232串口接收到数据后将数据以单播的形式发送到协调器。

当路由器接收到来自空中的数据包将数据写入232串口。

3、协调器的232串口接收到数据后将数据以广播的形式发送到网络中所有的设备。

当协调器接收到来自空中的数据包将数据写入232串口。

图X 串口透明传输应用二、编译选项说明串口透明传输工程在SampleApp工程基础之上进行修改,但是编译选项使用原SampleApp工程的编译选项,SampleApp工程编译选项具体如下:CC2430EB、ZTOOL_P1、MT_TASK、SOFT_ST ART 通过编译选项ZTOOL_P1编译选项SOFT_START。

三、工程初始化与事件处理函数串口透明传输工程来源于对SampleApp工程的修改,工程初始化函数与SampleApp工程的初始化函数完全相同,读者可以参见前面章节。

串口透明传输工程事件处理函数在SampleApp工程事件处理函数的基础之上添加了对事件UART_RX_CB_EVT的处理,具体代码如下。

程序代码:uint16 SampleApp_ProcessEvent( uint8 task_id, uint16 events ){if ( events &amP1说明原SampleApp工程默认使用Z-T ool,我们这里对其修改,将其在串口初始化中的回调函数函数进行修改。

程序代码:void SPIMgr_Init () { …… #if defined (ZTOOL_P1) || defined (ZTOOL_P2)uartConfig.callBackFunc= rxCB; …… } 相应我们在SPIMgr.c文件中添加该回调函数rxCB( uint8 port, uint8 event ),具体代码如下。

ZigBee串口透明传输

ZigBee串口透明传输

使用的协议栈版本信息: ZigBee2006\ZStack-1.4.3-1.2.1因为用现在这模块SerialApp没做成功,上电后按键没反应……两块无线龙小板子已经买来N年了. 自己想在SampleApp例子基础上修改实现串口透明传输:串口调试助手1<————>模块1 <-----OTA-----> 模块2<————>串口调试助手2程序修改主要如下:**************************************************************************************** **************************************************************************************** 1、宏定义事件#define UART_RX_CB_EVT 0x0002 (SampleApp.h)全局变量声明: (SPIMgr.h)extern uint8 rxlen; //接收数据长度extern uint8* databuf; //接收数据指针**************************************************************************************** ****************************************************************************************2、串口回调函数rxCB: (SPIMgr.c,直接在SPIMgr_Init()中进行修改)#if defined (ZTOOL_P1) || defined (ZTOOL_P2)uartConfig.callBackFunc = rxCB;//uartConfig.callBackFunc = SPIMgr_ProcessZToolData; //回调函数**************************************************************************************** **************************************************************************************** 3、十六进制转字符函数(SampleApp.c) 这两个函数由[青竹]编写.uint8 hextoword1(uint8 t ){uint8 abc;uint8 cba;uint8 xx1;abc=t;cba=0xf0;abc=(abc&cba)>>4;if(abc<10){xx1=abc+48;}else{xx1=abc+55;}return xx1;}uint8 hextoword2(uint8 t){uint8 abc;uint8 cba;uint8 xx2;abc=t;cba=0x0f;abc=abc&cba;if(abc<10){xx2=abc+48;}else{xx2=abc+55;}return xx2;}**************************************************************************************** ****************************************************************************************4、定义串口回调函数rxCB() (SPIMgr.c)static void rxCB( uint8 port, uint8 event ){// uint8 rxlen; //接收数据长度// uint8* dataybuf;//接收数据块指针extern uint8 SampleApp_TaskID;uint16 short_ddr;uint8 short_ddr_H;uint8 short_ddr_L;// uint8 *pointer1;// uint8 word_buffer[8];short_ddr=NLME_GetShortAddr();short_ddr_H=(uint8)((short_ddr&0xff00)>>8);short_ddr_L=(uint8)short_ddr;rxlen=Hal_UART_RxBufLen(SPI_MGR_DEFAULT_PORT); //接收缓冲区数据长度,字节为单位databuf=osal_mem_alloc(rxlen+1+2); //多分配3字节,分配如下databuf[0]=rxlen; //一字节存放数据长度databuf[1]=short_ddr_H; //一字节存放源地址高8位databuf[2]=short_ddr_L; //一字节存放源地址低8位//databuf[rxlen+1]='\n'; //一字节存放换行符HalUARTRead ( SPI_MGR_DEFAULT_PORT, databuf+3, rxlen);//读接收缓冲区数据到内存databuf+ 3/* 回显数据(测试用)word_buffer[0]='l';word_buffer[1]='e';word_buffer[2]='n';word_buffer[3]=':';word_buffer[4]=databuf[0]/100+48;word_buffer[5]=(databuf[0]%100)/10+48;word_buffer[6]=databuf[0]%10+48;word_buffer[7]='\n';pointer1=word_buffer;// HalUARTWrite()写入串口正确说明数据已经正确地存储在databuf中!HalUARTWrite ( SPI_MGR_DEFAULT_PORT, pointer1, 8 );HalUARTWrite ( SPI_MGR_DEFAULT_PORT, databuf+1, rxlen+1 );//把数据送串口输出*/if(!rxlen)osal_mem_free( databuf ); //释放内存osal_set_event(SampleApp_TaskID,UART_RX_CB_EVT);// rxCB_to_SampleApp( databuf, rxlen );}********************************************************************************************************************************************************************************5、添加:事件处理函数(SampleApp.c)uint16 SampleApp_ProcessEvent( uint8 task_id, uint16 events ){afIncomingMSGPacket_t *MSGpkt;// 显示网络地址变量uint16 short_ddr;uint8 yy1;uint8 yy2;uint8 str_1[ ]="my short address is:";#if defined(ZDO_COORDINATOR)uint8 str_2[ ]="build the network successfully";#elseuint8 str_2[ ]="join the network successfully ";#endifuint8 str_3[ ]={'\n'};uint8 shortaddr[7];uint8 *pointer1;uint8 *pointer2;uint8 *pointer3;uint8 *pointer4;…………(省略)/*1、接收串口信息在SampleApp_MessageMSGCB()上进行修改*/ case AF_INCOMING_MSG_CMD:SampleApp_MessageMSGCB( MSGpkt );break;/*2、设备建网/入网成功则显示本地网络地址*/case ZDO_STATE_CHANGE:SampleApp_NwkState = (devStates_t)(MSGpkt->hdr.status);if ( (SampleApp_NwkState == DEV_ZB_COORD)|| (SampleApp_NwkState == DEV_ROUTER)|| (SampleApp_NwkState == DEV_END_DEVICE) ){//显示本地网络地址short_ddr=NLME_GetShortAddr();yy1=(uint8)((short_ddr&0xff00)>>8);yy2=(uint8)short_ddr;shortaddr[0]=48;shortaddr[1]=120;shortaddr[2]=hextoword1(yy1);shortaddr[3]=hextoword2(yy1);shortaddr[4]=hextoword1(yy2);shortaddr[5]=hextoword2(yy2);shortaddr[6]='\n';pointer1=&shortaddr[0];pointer2=&str_1[0];pointer3=&str_2[0];pointer4=&str_3[0];HalUARTWrite(0,pointer4,1);HalUARTWrite(0,pointer3,29);HalUARTWrite(0,pointer4,1);HalUARTWrite(0,pointer2,20);HalUARTWrite(0,pointer1,7);HalUARTWrite(0,pointer4,1);//***************************************}else{// Device is no longer in the network}break;…………(省略)/*3、对接收的串口数据进行处理*/if ( events & UART_RX_CB_EVT ) //串口数据处理{SampleApp_SPI_SendData( databuf, rxlen+1+2 );return (events ^ UART_RX_CB_EVT);}}**************************************************************************************** ****************************************************************************************6、定义AF层数据处理函数SampleApp_MessageMSGCB() (SampleApp.c)默认采用的簇ID为SAMPLEAPP_PERIODIC_CLUSTERIDvoid SampleApp_MessageMSGCB( afIncomingMSGPacket_t *pkt ){uint16 flashTime;uint16 short_ddr;uint8 *pointer1;uint8 *pointer2;uint8 *pointer3;uint8 *pointer4;uint8 *pointer5;uint8 *pointer6;uint8 *pointer7;uint8 *pointer8;uint8 *pointer9;uint8 str_1[ ]="Source address:";uint8 str_2[ ]="Destination address:";uint8 str_3[ ]="Data length:";uint8 str_4[ ]="Data:";uint8 str_5[ ]={'\n'};pointer1=&str_1[0];pointer2=&str_2[0];pointer3=&str_3[0];pointer4=&str_4[0];pointer9=&str_5[0];uint8 Src_short_ddr_H;uint8 Src_short_ddr_L;uint8 Des_short_ddr_H;uint8 Des_short_ddr_L;uint8 word_buffer[4];uint8 Src_shortaddr[7];uint8 Des_shortaddr[7];switch ( pkt->clusterId ) //判断簇ID{case SAMPLEAPP_PERIODIC_CLUSTERID:/*####################################################*/// flashTime = BUILD_UINT16(pkt->cmd.Data[1], pkt->cmd.Data[2] ); // HalLedBlink( HAL_LED_4, 4, 50, (flashTime / 4) );pointer5=&(pkt->cmd.Data[3]); //pointer5:具体数据首地址word_buffer[0]=(pkt->cmd.Data[0])/100+48;word_buffer[1]=((pkt->cmd.Data[0])%100)/10+48;word_buffer[2]=(pkt->cmd.Data[0])%10+48;word_buffer[3]='\n';pointer6=word_buffer; //pointer6:数据长度//----------------Src_short_ddr_H=pkt->cmd.Data[1];Src_short_ddr_L=pkt->cmd.Data[2];Src_shortaddr[0]=48;Src_shortaddr[1]=120;Src_shortaddr[2]=hextoword1(Src_short_ddr_H);Src_shortaddr[3]=hextoword2(Src_short_ddr_H);Src_shortaddr[4]=hextoword1(Src_short_ddr_L);Src_shortaddr[5]=hextoword2(Src_short_ddr_L);Src_shortaddr[6]='\n';pointer7=&Src_shortaddr[0]; //pointer7:源地址//----------------short_ddr=NLME_GetShortAddr();Des_short_ddr_H=(uint8)((short_ddr&0xff00)>>8);Des_short_ddr_L=(uint8)short_ddr;Des_shortaddr[0]=48;Des_shortaddr[1]=120;Des_shortaddr[2]=hextoword1(Des_short_ddr_H);Des_shortaddr[3]=hextoword2(Des_short_ddr_H);Des_shortaddr[4]=hextoword1(Des_short_ddr_L);Des_shortaddr[5]=hextoword2(Des_short_ddr_L);Des_shortaddr[6]='\n';pointer8=&Des_shortaddr[0]; //pointer8:目的地址//----------------HalUARTWrite ( 0, pointer1, 15 );//源地址HalUARTWrite ( 0, pointer7, 7 );HalUARTWrite ( 0, pointer2, 20 ); //目的地址HalUARTWrite ( 0, pointer8, 7 );HalUARTWrite ( 0, pointer3, 12 ); //数据长度HalUARTWrite ( 0, pointer6, 4 );HalUARTWrite ( 0, pointer4, 5 ); //具体数据HalUARTWrite ( 0, pointer5, pkt->cmd.Data[0] ); //pkt->cmd.Data[0]=rxlen,为原始长度HalUARTWrite ( 0, pointer9, 1 ); //换行符HalUARTWrite ( 0, pointer9, 1 );//pointer1=&(pkt->cmd.Data[3]);//HalUARTWrite ( 0, pointer1, 6 );/*####################################################*/break;case SAMPLEAPP_FLASH_CLUSTERID://flashflashTime = BUILD_UINT16(pkt->cmd.Data[1], pkt->cmd.Data[2] );HalLedBlink( HAL_LED_4, 4, 50, (flashTime / 4) );break;}}******************************************************************************************************************************************************************************** 7、定义串口数据处理函数SampleApp_SPI_SendData() (SampleApp.c)我只有两个节点,所以这里采用最简单的单点传送方式.下载协调器程序时目标地址改为0x796F,下载终端程序时目标地址改为0x0000.默认ClusterID为SAMPLEAPP_PERIODIC_CLUSTERID.void SampleApp_SPI_SendData( uint8 *buf, uint8 len ){SampleApp_SPI_SendData_DstAddr.addrMode = (afAddrMode_t)Addr16Bit;SampleApp_SPI_SendData_DstAddr.endPoint = SAMPLEAPP_ENDPOINT;SampleApp_SPI_SendData_DstAddr.addr.shortAddr = 0x796F; //0x796F;0x0000// SampleApp_SendPeriodicMessage(); //测试用if ( AF_DataRequest( &SampleApp_SPI_SendData_DstAddr,(endPointDesc_t *)&SampleApp_epDesc,SAMPLEAPP_PERIODIC_CLUSTERID,len, buf,&SampleApp_TransID,0,AF_DEFAULT_RADIUS ) == afStatus_SUCCESS ){osal_mem_free( databuf ); //必须释放内存,不然造成溢出!}else{osal_mem_free( databuf );}}**************************************************************************************** ****************************************************************************************编译情况:通信结果1:(关于开头的乱码说明参考后篇记录)通信结果2:最大数据只能达到52字节:(但在修改程序过程中,达到过83字节;等修改完整后只有52字节了):测试SampleApp_SPI_SendData()中的osal_mem_free( databuf ).如果不把databuf释放,则数据只能发送几次就停止.下面是添加osal_mem_free( databuf )后两边串口自动发送,测试时间>5分钟,收发一直保持稳定.实物连接:**************************************************************************************** ****************************************************************************************注:串口调试助手A<—>节点A<—>收发----------收发<—>节点B<—>串口调试用手B若串口调试助手A发数据串口调试助手B无反应,在串口配置以及程序编译正确的前提下可参考以下四步:1、节点A是否正确接收串口发送的数据,可以通过串口回显数据进行判断2、节点A是否成功发送数据,可以在成功发送数据的程序后添加一LED闪烁指令以帮助判断3、节点B是否成功接收数据,可以在成功接收数据的程序后添加一LED闪烁指令以帮助判断4、节点B是否把接收数据正确发往串口,可以自己在节点B设置发送一些数据以进行判断我起初也是一堆错误,就是这样一块一块去测试的~今天'阿弥陀佛'同学提了个编译错误的问题:Error[e27]: Entry "MT_NwkCommandProcessing::?relay" in module MT_NWK ( C:\Texas Instrume nts\ZStack-1.4.3-1.2.1\Projects\zstack\Samples\SampleApp\CC2430DB\CoordinatorDB\Obj\MT_NWK.r51 ) redefined in module SampleApp ( C:\TexasInstruments\ZStack-1.4.3-1.2.1\Projects\zstack\Samples\SampleApp\CC2430DB\CoordinatorDB\Obj\Sampl eApp.r51 )类似我以前也碰到过,但已经忘记怎么把它搞定的,这个链接/showthread.php?p=100430里的内容也不甚明白,但'阿弥陀佛'在所调用的函数MT_NwkCommandProcessing()前面加上static搞定,但有警告.有理解的朋友烦请解释下~3Q!********************************************************************************************************************************************************************************。

zigbee技术及应用

zigbee技术及应用

Zigbee技术简介及应用摘要二十一世纪初,信息技术的迅猛发展使人们的生活水平和工作效率极大地提高。

近距离内各种设备的无线通讯成为一个研究热点。

目前也有着几种发展比较成熟的无线通讯技术。

本文介绍的是目前一种比较流行的短距离无线通讯接入技术——Zigbee。

这种技术将使短距离无线通讯技术广泛地应用于生产生活中成为可能。

介绍完该技术后,通过特定的一个例子SampleApp工程对该技术进行进一步说明,该例子是现的功能是:A、B两个节点,当按下A(或B)节点的按键1时,点亮或熄灭B(或A)节点的LED1灯。

关键词:Zigbee技术;无线通讯技术1 Zigbee技术概述及其特征1.1 Zigbee技术概述ZigBee的名称源于蜜蜂的舞蹈,蜜蜂通过跳ZigZag形状的舞蹈交换各种信息。

故将新一代无线通信技术命名为ZigBee。

ZigBee过去又称为"HomeRF Lite"、"RF-EasyLink"或"FireFly"无线电技术,目前统称为ZigBee技术。

ZigBee是在2004年底才由Zigbee联盟正式发布的一种无线传输协议。

2006年12月,该联盟正式推出Zigbee的升级规范——Zigbee2006,也称为“增强型”Zigbee。

Zigbee技术是一种可以实现短距离内双向无线通讯的技术。

Zigbee技术以其复杂程度低、能耗低、成本低取胜于其余的短距离无线通讯技术。

其主要应用于短距离内,传输速度要求不高的电子通讯设备之间的数据传输和典型的有周期性、间歇性和地反应时间的数据的传输。

Zigbee是IEEE802.15.4技术的商业名称,该技术的核心由其制定。

能够在三个不同的频段上通讯。

全球通用的频段是2.4-2.484GHz,欧洲采用的频段是868.0-868.66MHz,美国采用的频段是902-928MHz。

该技术的高层应用和市场推广由Zigbee联盟负责。

Zigbee协议栈中文说明免费

Zigbee协议栈中文说明免费

Zigbee协议栈中文说明1.概述解析ZigBee堆栈架构ZigBee堆栈是在IEEE 标准基础上建立的,定义了协议的MAC和PHY层。

ZigBee设备应该包括该标准定义了RF射频以及与相邻设备之间的通信)的PHY和MAC层,以及ZigBee堆栈层:网络层(NWK)、应用层和安全服务提供层。

图1-1给出了这些组件的概况。

堆栈层每个ZigBee设备都与一个特定模板有关,可能是公共模板或私有模板。

这些模板定义了设备的应用环境、设备类型以及用于设备间通信的簇。

公共模板可以确保不同供应商的设备在相同应用领域中的互操作性。

设备是由模板定义的,并以应用对象(Application Objects)的形式实现(见图1-1)。

每个应用对象通过一个端点连接到ZigBee堆栈的余下部分,它们都是器件中可寻址的组件。

图1-1 zigbe堆栈框架从应用角度看,通信的本质就是端点到端点的连接(例如,一个带开关组件的设备与带一个或多个灯组件的远端设备进行通信,目的是将这些灯点亮)。

端点之间的通信是通过称之为簇的数据结构实现的。

这些簇是应用对象之间共享信息所需的全部属性的容器,在特殊应用中使用的簇在模板中有定义。

图1-1-2就是设备及其接口的一个例子:图1-1-2每个接口都能接收(用于输入)或发送(用于输出)簇格式的数据。

一共有二个特殊的端点,即端点0和端点255。

端点0用于整个ZigBee设备的配置和管理。

应用程序可以通过端点0与ZigBee 堆栈的其它层通信,从而实现对这些层的初始化和配置。

附属在端点0的对象被称为ZigBee设备对象(ZD0)。

端点255用于向所有端点的广播。

端点241到254是保留端点。

所有端点都使用应用支持子层(APS)提供的服务。

APS通过网络层和安全服务提供层与端点相接,并为数据传送、安全和绑定提供服务,因此能够适配不同但兼容的设备,比如带灯的开关。

APS使用网络层(NWK)提供的服务。

NWK负责设备到设备的通信,并负责网络中设备初始化所包含的活动、消息路由和网络发现。

ZigBee协议栈的分析与设计

ZigBee协议栈的分析与设计

ZigBee协议栈的分析与设计ZigBee协议栈的分析与设计引言随着物联网的不断发展,无线传感器网络(WSN)得到了广泛的应用。

ZigBee作为一种低功耗、短距离、低带宽的无线通信协议,逐渐成为物联网中最受欢迎的通信协议之一。

本文将对ZigBee协议栈进行深入的分析与设计,以期更好地理解其工作原理并提供一种优化方案。

一、ZigBee协议栈的结构与功能1. ZigBee协议栈结构ZigBee协议栈由两部分组成:上层和下层。

上层包括应用层(Application Layer)、网络层(Network Layer)和安全层(Security Layer)。

下层包括物理层(Physical Layer)和介质访问控制层(Media Access Control Layer)。

2. ZigBee协议栈功能- 物理层(Physical Layer):负责将数据转换为无线信号,通过无线传输介质进行通信。

ZigBee协议栈支持多种物理层标准,例如2.4GHz、900MHz和868MHz等。

- 介质访问控制层(Media Access Control Layer):负责数据帧的分发和接收,同时处理多跳中继和协议转发。

- 网络层(Network Layer):提供网络拓扑管理、路由选择、数据包传输和安全性等功能。

ZigBee协议栈使用了Ad-hoc On-Demand Distance Vector(AODV)路由协议来实现自组网和动态路由选择。

- 应用层(Application Layer):定义应用程序的协议和接口,包括设备发现、网络配置、设备控制等功能。

- 安全层(Security Layer):提供数据加密和认证等安全机制,确保通信的可靠性和机密性。

二、ZigBee协议栈的分析1. 物理层分析ZigBee协议栈采用低功耗、短距离的射频通信技术。

2.4GHz频段是其最常用的无线传输介质,具有广泛的应用领域。

ZigBee协议栈使用了Direct Sequence Spread Spectrum (DSSS)技术来提高抗干扰性能。

Zigbee 协议栈及应用实现

Zigbee 协议栈及应用实现

Zigbee 协议栈及应用实现1、ZigbeeZigbee 是一种新兴的短距离、低功率、低速率无线接入技术.工作在 2.4GHz 波段,传输速率为 10M~250kb/ s ,传输距离为10~75m. Zigbee 是基于 IEEE 802.15.4 的无线通信协议 ,它的协议结构由物理层(PHY)、介质访问层(MAC)、网络层(NWK)、应用层组成.Zigbee 主要应用在距离短、功耗低且传输速率不高的各种电子设备之间 ,典型的传输数据类型有周期性数据、间歇性数据和低反应数据.因而,它的应用目标主要是:工业控制(如自动控制设备、无线传感器网络) ,医护(如监视和传感) ,家庭智能控制(如照明、水电气计量及报警) ,消费类电子设备的遥控装置、PC外设的无线连接等领域.2、Zigbee 协议栈参考模型及实现(1)物理层的参考模型PHY层定义了物理无线信道和MAC子层之间的接口 ,提供物理层数据服务和物理层管理服务.物理层数据服务从无线物理信道上收发数据 ,物理层管理服务维护一个由物理层相关数据组成的数据库.物理层数据服务包括以下五方面的功能:①激活和休眠射频收发器;②信道能量检测(energy detect) ;③检测接收数据包的链路质量指示(link quality indication ,LQI) ;④空闲信道评估(clear channel assessment ,CCA) ;⑤收发数据.信道能量检测为网络层提供信道选择依据.它主要测量目标信道中接收信号的功率强度 ,由于这个检测本身不进行解码操作 ,所以检测结果是有效信号功率和噪声信号功率之和.链路质量指示为网络层或应用层提供接收数据帧时无线信号的强度和质量信息 ,与信道能量检测不同的是 ,它要对信号进行解码 ,生成的是一个信噪比指标.这个信噪比指标和物理层数据单元共同提交给上层处理.空闲信道评估判断信道是否空闲. IEEE 802.15. 4定义了三种空闲信道评估模式:第一种简单判断信道的信号能量 ,当信号能量低于某一门限值就认为信道空闲;第二种是通过判断无线信号的特征,这个特征主要包括两方面 ,即扩频信号特征和载波频率;第三种模式是前两种模式的综合 ,同时检测信号强度和信号特征 ,给出信道空闲判断.Zigbee 物理层帧结构,其中前导码4Byte ,主要用于前导同步;分组定界 1Byte ,标志分组的开始;物理层头1Byte ,表示数据单元的长度;物理层数据服务单元( PSDU)数据单元用于承载向上层即MAC 层传输数据.(2)MAC层参考模型及实现.MAC子层的参考模型如图 4 所示. MAC子层提供两种服务:MAC 层数据服务和MAC层管理服务(MAC sublayer manage2ment entity , MLME) .前者保证MAC协议数据单元在物理层数据服务中的正确收发 ,后者维护一个存储MAC子层协议状态相关信息的数据库.MAC子层主要功能包括下面六个方面:①协调器产生并发送信标帧 ,普通设备根据协调器的信标帧与协议器同步;②支持PAN 网络的关联(ass ociation)和取消关联(disass ociation)操作;③支持无线信道通信安全;④使用 CSMA - CA 机制访问信道;⑤支持时槽保障(guaranteed time slot , GTS)机制;⑥支持不同设备的MAC层间可靠传输.MAC子层定义了信标帧、数据帧、确认帧和命令帧.信标帧和数据帧包含了高层控制命令或者数据 ,确信帧和命令帧用于 Zigbee 设备MAC子层功能实体间控制信息的收发.MAC子层的帧结构由帧头、MAC 层服务数据单元和帧尾三部分组成. 帧头由帧控制信息2Byte、帧序列号1Byte 和地址信息组成420Byte (命令帧无地址信息) .MAC 子层数据服务单元(MSDU)具有可变长度 nByte ,具体内容由帧类型决定(命令帧无MSDU) .帧尾是帧头和负载数据的 16 位 CRC 校验序列(FCS) 2Byte.(3)网络层参考模型及实现.Zigbee 协议栈的核心部分在网络层.网络层负责拓扑结构的建立和维护、命名和绑定服务 ,它们协同完成寻址、路由、传送数据及安全这些不可或缺的任务 ,支持星形(Star)、树形 (Cluster- Tree)、网格 (Mesh) 等多种拓扑结构.MAC子层的参考模型如图 6 所示.为了满足应用层的要求 ,Zigbee 协议的网络层划分为网络层数据实体(NLDE)和网络层管理实体(NlME) ,NLDE提供相关的 SAP的数据传输服务 ,而 NLME则提供经由相关的 SAP的管理服务.网络层的主要功能包括以下八个方面:①通过添加恰当的协议头能够从应用层生成网络层的 PDU ,即NPDU.②确定网络的拓扑结构.③配置一个新的设备 ,可以是网络协调器也可以向存在的网络中加入设备.④建立并启动无线网络.⑤加入或离开网络.⑥Zigbee 的协调器和路由能为加入网络的设备分配地址.⑦发现并记录邻居表、路由表.⑧信息的接收控制 ,同步 MAC 子层或直接接受信息.网络层定义了数据帧和命令帧 ,它的帧结构由网络层头信息和数据负载构成.网络层帧头信息格式是固定的 ,帧控制2Byte ,目的地址 2Byte ,源地址 2Byte ,网络传输的半径1Byte ,但是地址域和序列号域并非在所有的帧结构中都出现.网络层数据域 nByte.其中目的地址、源地址、半径和序列和称为路由域.网络层数据帧和命令帧的区别在于命令的数据域有1Byte 的NWK命令标识符.(4)ZigBee APIZigBee协议栈支持应用程序接口API函数很多,主要有:ZigBee 设备对象ZDO API、应用支持子层APS API、端点数据发送接收AF API和网络层NWK API。

ZigBee学习之42——协议栈中的串口操作

ZigBee学习之42——协议栈中的串口操作

#endif } //在来看一下串口中断,就是将 U0DBUF 的数据存放到 cfg0->rxBuf 里面,并且更改 rxHead 标志 HAL_ISR_FUNCTION( halUart0RxIsr, URX0_VECTOR ) { cfg0->rxBuf[cfg0->rxHead] = U0DBUF;
if ( cfg->rxHead >= (cfg->rxMax - SAFE_RX_MIN) ) { / /已保 存的数 据已经 超过了 安全界 限,发 送接收 满事件 evt = HAL_UART_RX_FULL; } else if ( cfg->rxHigh && (cfg->rxHead >= cfg->rxHigh) ) { evt = HAL_UART_RX_ABOUT_FULL; } else if ( cfg->rxTick == 0 ) { / /超时 事件 evt = HAL_UART_RX_TIMEOUT; } else { evt = 0; } / /如果 发生事 件,并 且配置 了回调 函数则 调用回 调函数 if ( evt && cfg->rxCB ) { cfg->rxCB( ((cfg->flag & UART_CFG_U1F)!=0), evt ); //(cfg->flag & UART_CFG_U1F)!=0) 判读是那个串口,如果是串口 1 则为 1,否则为 0 } } //下面的没看懂,下面的判断好像是没有用一样,不管是哪个条件都 break 了! if ( cfg == cfg0 ) { break; } else break; } while ( TRUE ); #else return;

Zigbee协议栈RexBee详解

Zigbee协议栈RexBee详解

目录一RexBee基本使用说明 (1)二组网节点查看及通过无线配置其他节点参数 (10)三网络拓扑图及节点路径查看 (13)四巧用NETWORK软件进行组命令帧 (14)一RexBee基本使用说明拿到模块,如果配合我们的开发板,那使用非常方便,如果没有开发板,那也非常简单,只需连RX,TX,VCC,GND这4根线到你们的MCU,就能跟你们进行串口通信,,外观如下图:1如果是有我们开发板,那么将模块插到我们开发板,接上电源,然后开发板上的LED灯会闪烁,说明模块正常运行,接上串口连接到电脑,然后选择相应COM口即可。

有开发板的话,可以略过2,3,4步骤,直接看第5步。

如果没有我们开发板,那么接着往下看。

2首先要找到每个模块的RX,TX,VCC,GND引脚。

1)增强型插针和标准型插针模块(REX3D&REX3DP)的引脚是兼容的,引脚位置如图:1,2引脚为VCC;27,28引脚为GND;13引脚为RX;16引脚为RX;2)增强型贴片和标准型贴片模块(REX3S&REX3SP)的引脚也是兼容的,引脚位置如图:1,2引脚为VCC;30,31,32引脚为GND;18引脚为RX;19引脚为RX;3)超小型模块(REX3U)引脚图:3找到了这4根引脚后,那么只需将他们跟你们的MCU相连即可。

我们的TX接你们的RX,我们的RX接你们的TX,注意,我们的芯片电压是3.3V,如果你们MCU 是5V的话,需要做转换哦,详见各模块Datasheet。

4按上图连接后,然后配置下串口波特率,你们的MCU就能跟我们的模块进行通信了。

5我们的COO的波特率是115200,8,N,1,ROUTER跟ZED的波特率是9600,8,N,1.配置好波特率后,终于可以与我们模块进行通信了。

首先,打开串口调试助手,选择相应COM口。

首先发送AT+VER查看本身是什么节点类型,在发送AT+GETINFO查看工作在什么信道和PANID下(ZIGBEE设备只有在相同的PANID和信道下才能进行通信)发现PANID跟CH相同,那么就可以进行通信了,比如COO要发送01 02 03 04 05 06 到ROUTER,ROUTER收到数据后给COO回复06 05 04 03 02 01,那么直接在COO端发送01 02 03 04 05 06,然后在ROUTER端发送06 05 04 03 02 01即可。

zigbee串口通信课程设计

zigbee串口通信课程设计

zigbee串口通信课程设计一、课程目标知识目标:1. 学生能够理解Zigbee无线通信技术的原理及其在串口通信中的应用。

2. 学生能够掌握Zigbee模块的配置和使用,并了解其通信协议。

3. 学生能够了解串口通信的基本概念,包括串行通信接口、波特率、数据位等。

技能目标:1. 学生能够运用Zigbee模块进行串口通信,实现数据的发送和接收。

2. 学生能够通过编程解决串口通信过程中的常见问题,如数据丢失、校验错误等。

3. 学生能够独立完成Zigbee串口通信系统的搭建和调试。

情感态度价值观目标:1. 学生通过学习,培养对无线通信技术的兴趣,提高对物联网领域的好奇心。

2. 学生能够认识到团队协作的重要性,提高沟通能力和解决问题的能力。

3. 学生能够认识到科技发展对社会进步的推动作用,增强对科技创新的热情。

课程性质:本课程为实践性较强的课程,结合课本知识,通过实际操作培养学生的动手能力和解决问题的能力。

学生特点:学生具备基本的电子知识和编程能力,对新技术充满好奇心,喜欢动手实践。

教学要求:教师需提供详细的操作指导,引导学生掌握Zigbee串口通信技术,注重培养学生的实际操作能力和团队协作能力。

在教学过程中,关注学生的个体差异,给予个性化指导。

通过课程学习,使学生在知识、技能和情感态度价值观方面均取得具体的学习成果。

二、教学内容本课程教学内容紧密结合课程目标,确保学生能够系统地学习和掌握Zigbee 串口通信相关知识。

1. 理论知识:- 串口通信基本原理及接口标准- Zigbee无线通信技术及其特点- 串口通信协议及其配置方法2. 实践操作:- Zigbee模块的安装与配置- 串口通信程序设计及调试- 数据发送与接收功能的实现3. 教学大纲安排:- 第一章:串口通信概述,介绍串口通信的基本原理、接口标准及在物联网中的应用。

- 第二章:Zigbee无线通信技术,讲解Zigbee协议、模块特点及其在串口通信中的应用。

ZigBee学习之42—协议栈中的串口操作讲义

ZigBee学习之42—协议栈中的串口操作讲义

#1楼主:【原创】ZigBee学习之42——协议栈中的串口操作文章发表于:2010-02-27 13:27如果要使用协议栈中提供的串口,则需要定义HAL_UART和HAL_UART TRUE 【hal_board_cfg.h】。

首先初始化串口,在主函数中调用HalDriverInit()时,在函数中初始化串口,主要是配置管脚和DMA通道。

然后在osal_start_system()开始系统后,会调用Hal_ProcessPoll()来读取时间和串口,void Hal_ProcessPoll (){HalTimerTick();#if (defined HAL_UART) && (HAL_UART == TRUE)HalUARTPoll();#endif}//来看下串口poll函数,我们只看UART0的,因为我的开发板使用这个串口void HalUARTPoll( void ){#if ( HAL_UART_0_ENABLE | HAL_UART_1_ENABLE )static uint8 tickShdw;uartCfg_t *cfg;uint8 tick;#if HAL_UART_0_ENABLE//当发生串口接收中断时cfg0就会改变,如果串口没有数据输入cfg0为空,当接收到数据时cfg0将在串口中断服务程序中被改变if ( cfg0 ){cfg = cfg0;}#endif// Use the LSB of the sleep timer (ST0 must be read first anyway).//系统上电后,睡眠定时器就会自动启动做自增计数ST0:即睡眠定时器启动到现在计算值的最低8位tick = ST0 - tickShdw;tickShdw = ST0;//要注意接下来的是个循环do{if ( cfg->txTick > tick ){cfg->txTick -= tick;}else{cfg->txTick = 0;}if ( cfg->rxTick > tick ){cfg->rxTick -= tick;}else{cfg->rxTick = 0;}//是使用DMA方式还是使用中断方式#if HAL_UART_ISR#if HAL_UART_DMAif ( cfg->flag & UART_CFG_DMA ){pollDMA( cfg );}else#endif{pollISR( cfg );//中断方式static void pollISR( uartCfg_t *cfg ){//如果串口没有接收到数据,也就是说没有发生过串口接收中断,那么cfg应为是为空的,则cnt=0//如果发生了串口中断,则cnt计算出串口缓存中还有多少数据没有读出,这个缓存并不是硬件寄存器的缓存,而是程序中开辟一段空间uint8 cnt = UART_RX_A V AIL( cfg );if ( !(cfg->flag & UART_CFG_RXF) ){//这里是针对流控制的,如果又有新的数据接收到了那么就要重置超时时间(超时时间由睡眠定时器来控制),而且需要把已经读出的数据数目减去!// If anything received, reset the Rx idle timer.if ( cfg->rxCnt != cnt ){cfg->rxTick = HAL_UART_RX_IDLE;cfg->rxCnt = cnt;}/* It is necessary to stop Rx flow in advance of a full Rx buffer because* bytes can keep coming while sending H/W fifo flushes.*///当接收缓存超过安全界限的时候停止RX流if ( cfg->rxCnt >= (cfg->rxMax - SAFE_RX_MIN) ){RX_STOP_FLOW( cfg );}//关于安全界限,在程序中有下面一段:/* Need to leave enough of the Rx buffer free to handle the incoming bytes* after asserting flow control, but before the transmitter has obeyed it.* At the max expected baud rate of 115.2k, 16 bytes will only take ~1.3 msecs,* but at the min expected baud rate of 38.4k, they could take ~4.2 msecs.* SAFE_RX_MIN and DMA_RX_DL Y must both be consistent according to* the min & max expected baud rate.*///如果声明了流控制,为保证数据的正确接收需要在RX缓存区中预留出足够的空间。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

//任务初始化函数 void GenericApp_Init( byte task_id ) { halUARTCfg_t uartConfig; GenericApp_TaskID = task_id; GenericApp_TransID = 0; GenericApp_epDesc.endPoint = GENERICAPP_ENDPOINT; GenericApp_epDesc.task_id = &GenericApp_TaskID; GenericApp_epDesc.simpleDesc = (SimpleDescriptionFormat_t *)&GenericApp_SimpleDesc; GenericApp_tencyReq = noLatencyReqs; afRegister( &GenericApp_epDesc ); uartConfig.configured = TRUE; uartConfig.baudRate = HAL_UART_BR_115200; uartConfig.flowControl = FALSE; uartConfig.callBackFunc = rxCB; HalUARTOpen (0,&uartConfig ); //串口初始化 }
//任务初始化函数 void GenericApp_Init( byte task_id ) { halUARTCfg_t uartConfig; GenericApp_TaskID = task_id; GenericApp_TransID = 0; GenericApp_epDesc.endPoint = GENERICAPP_ENDPOINT; GenericApp_epDesc.task_id = &GenericApp_TaskID; GenericApp_epDesc.simpleDesc = (SimpleDescriptionFormat_t *)&GenericApp_SimpleDesc; GenericApp_tencyReq = noLatencyReqs; afRegister( &GenericApp_epDesc );
回调函数:通过指针(函数地址)调用的函数。如果把函数 的地址作为参数传递给另一个函数,当通过这个指针 调用它所指向的函数时,称为函数的回调。
• 使用串口的基本步骤: • ①初始化串口,包括设置波特率、中断等; • ②向发送缓冲区发送数据或者从接收缓冲 区读取数据。
串口工作原理剖析
• 在ZigBee协议栈中,halUARTCfg_t结构体 是如何定义的; • 串口是如何初始化的; • 发送给串口的数据时如何接受的; • 串口是如何向PC机发送数据的。 这些问题涉及如下三个函数……
• ZigBee协议栈中提供的与串口操作有关的 三个函数为 可在zmain.c和hal_uart.c中查看相关函数 • uint8 HalUARTOpen(uint8 halUARTCfg_t *config); • uint16 HalUARTRead(uint8 port,uint8 *buf,uint16 len); • Uint16 HalUARTWrite(uint8 prot,uint *buf,uint16 len);
ZigBee串口应用
一、串口收发基础实验 二、ZigBee协议栈串口应用扩展实验
一、串口收发基础实验
实验课题:串口数据收发基础实验 实验目的:利用串口收发数据 试验步骤:ZigBee协议栈中串口通信的配置使用一个结构 体来实现,该结构体为hal_UARTCfg_t, 不必关心该结构体的具体定义形式,只需要对其功能有个 了解,该结构体将串口初始化的参数集合在一起, 只需要初始化各个参数即可 最后使用HalUARTOpen()函数对串口进行初始化,该函数将 halUARTCfg_t类型的结构体变量作为相关参数
const cId_t GenericApp_ClusterList[GENERICAPP_MAX_CLUSTERS] = { GENERICAPP_CLUSTERID }; const SimpleDescriptionFormat_t GenericApp_SimpleDesc = { GENERICAPP_ENDPOINT, GENERICAPP_PROFID, GENERICAPP_DEVICEID, GENERICAPP_DEVICE_VERSION, GENERICAPP_FLAGS, GENERICAPP_MAX_CLUSTERS, (cId_t *)GenericApp_ClusterList, 0, (cId_t *)NULL }; endPointDesc_t GenericApp_epDesc; byte GenericApp_TaskID; byte GenericApp_TransID; //unsigned char uartbuf[128]; //将这一行注释掉
/* typedef struct { byte endPoint; byte *task_id; SimpleDescriptionFormat_t *simpleDesc; afNetworkLatencyReq_t latencyReq; }endPointDesc_t; */ void GenericApp_MessageMSGCB( afIncomingMSGPacket_t *pckt ); void GenericApp_SendTheMessage( void ); //static void rxCB(uint8 port,uint8 event); //将这一行注释掉
( )
Coordinator.c
• • • • • • • • • • • • • • • • #include "OSAL.h" #include "AF.h" #include "ZDApp.h" #include "ZDObject.h" #include "ZDProfile.h" #include <String.h> #include "Coordinator.h" #include "DebugTrace.h" #if !defined( WIN32 ) #include "OnBoard.h" #endif #include "hal_lcd.h" #include "hal_led.h" #include "hal_key.h" #include "hal_uart.h" //包含头文件
//事件处理函数 UINT16 GenericApp_ProcessEvent( byte task_id, UINT16 events ) { return 0; //本实验没有进行事件处理 }
static void rxCB(uint8 port,uint8 event) { unsigned char uartbuf[128]=" "; HalUARTRead(0,uartbuf,16); //调用函数,从串口读取数据并将其 放在uartbuf数组中 if(osal_memcmp(uartbuf,"",16)) //使用 osal_memcmp()判断接收到的数据是否是“”,返回 TRUE,执行HalUARTWrite()函数 { HalUARTWrite(0,uartbuf,16); //调用函数将接收到的字符输出到 串口 } } //ZigBee协议栈使用条件编译,在GenericApp-Coordinator工程上右键 单击,options/C/C++ Compiler在Defined symbols:下拉框中添加 HAL_UART=TRUE,点击OK即可。
uartConfig.configured = TRUE; uartConfig.baudRate = HAL_UART_BR_115200; uartConfig.flowControl = FALSE; uartConfig.callBackFunc = NULL; //置空,即无需回调函数 HalUARTOpen (0,&uartConfig ); //串口初始化
const cId_t GenericApp_ClusterList[GENERICAPP_MAX_CLUSTERS] = { GENERICAPP_CLUSTERID }; const SimpleDescriptionFormat_t GenericApp_SimpleDesc = { GENERICAPP_ENDPOINT, GENERICAPP_PROFID, GENERICAPP_DEVICEID, GENERICAPP_DEVICE_VERSION, GENERICAPP_FLAGS, GENERICAPP_MAX_CLUSTERS, (cId_t *)GenericApp_ClusterList, 0, (cId_t *)NULL }; endPointDesc_t GenericApp_epDesc; byte GenericApp_TaskID; byte GenericApp_TransID;
PC机
ZigBee网络
vice
Coordinator
Coordinator.c
• • • • • • • • • • • • • • • #include "OSAL.h" #include "AF.h" #include "ZDApp.h" #include "ZDObject.h" #include "ZDProfile.h" #include <String.h> #include "Coordinator.h" #include "DebugTrace.h" #if !defined( WIN32 ) #include "OnBoard.h" #endif #include "hal_lcd.h" #include "hal_led.h" #include "hal_key.h" #include "hal_uart.h"
相关文档
最新文档