要使用ZStack就不得不先了解ZStack的OSAL工作原理
http://blog.****.net/qinpeng_zbdx/article/details/20990797
http://wenku.baidu.com/link?url=OILW1kTqP0nnNnLmuiCa9v...
了解事情的本质后,操作就很简单了
根据这篇博客可以很清楚的了解如何在ZStack下使用CC2530开发板进行串口通信
http://home.eeworld.com.cn/my/space-uid-530276-blogid-227205.html
在基于ZigBee协议的应用开发中,用户只需要实现应用程序框架即可。
在APP层,整个程序要实现的功能都在这三个文件里
YourName.c,YourName.h 和OSAL_YourName.c 文件
在YourName.c文件里,定义了这两个函数:
YourName_Init( task_id )函数 -- 初始化
YourName_ProcessEvent( task_id, events )函数 -- 判断由参数传递的事件类型,然后执行相应的事件处理函数
OSAL_YourName.c 中有两个重要的东西
数组taskArr:存放着所有任务的事件处理函数的地址
函数osalInitTasks:所有的初始化工作都在这里完成,自动分配给每个任务一个ID
const pTaskEventHandlerFn tasksArr[] = {
macEventLoop,
nwk_event_loop,
Hal_ProcessEvent,
#if defined( MT_TASK )
MT_ProcessEvent,
#endif
APS_event_loop,
#if defined ( ZIGBEE_FRAGMENTATION )
APSF_ProcessEvent,
#endif
ZDApp_event_loop,
#if defined ( ZIGBEE_FREQ_AGILITY ) || defined ( ZIGBEE_PANID_CONFLICT )
ZDNwkMgr_event_loop,
#endif
SerialApp_ProcessEvent
};void osalInitTasks( void )
{
uint8 taskID = ; tasksEvents = (uint16 *)osal_mem_alloc( sizeof( uint16 ) * tasksCnt);
osal_memset( tasksEvents, , (sizeof( uint16 ) * tasksCnt)); macTaskInit( taskID++ );
nwk_init( taskID++ );
Hal_Init( taskID++ );
#if defined( MT_TASK )
MT_TaskInit( taskID++ );
#endif
APS_Init( taskID++ );
#if defined ( ZIGBEE_FRAGMENTATION )
APSF_Init( taskID++ );
#endif
ZDApp_Init( taskID++ );
#if defined ( ZIGBEE_FREQ_AGILITY ) || defined ( ZIGBEE_PANID_CONFLICT )
ZDNwkMgr_Init( taskID++ );
#endif
SerialApp_Init( taskID );
}
所有的任务状态都被初始化为0,代表现在没有需要相应的事件。
void SerialApp_Init( uint8 task_id )
{
halUARTCfg_t uartConfig; SerialApp_TaskID = task_id;
SerialApp_RxSeq = 0xC3; afRegister( (endPointDesc_t *)&SerialApp_epDesc ); RegisterForKeys( task_id ); uartConfig.configured = TRUE;
uartConfig.baudRate = SERIAL_APP_BAUD;
uartConfig.flowControl = TRUE;
uartConfig.flowControlThreshold = SERIAL_APP_THRESH;
uartConfig.rx.maxBufSize = SERIAL_APP_RX_SZ;
uartConfig.tx.maxBufSize = SERIAL_APP_TX_SZ;
uartConfig.idleTimeout = SERIAL_APP_IDLE;
uartConfig.intEnable = TRUE;
uartConfig.callBackFunc = SerialApp_CallBack;
HalUARTOpen (SERIAL_APP_PORT, &uartConfig); #if defined ( LCD_SUPPORTED )
HalLcdWriteString( "SerialApp", HAL_LCD_LINE_2 );
#endif ZDO_RegisterForZDOMsg( SerialApp_TaskID, End_Device_Bind_rsp );
ZDO_RegisterForZDOMsg( SerialApp_TaskID, Match_Desc_rsp );
}static void SerialApp_CallBack(uint8 port, uint8 event)
{
(void)port;
unsigned char Uartbuf[];
unsigned char Outbuf[]; Outbuf[] = 'H';
Outbuf[] = 'E';
Outbuf[] = 'L';
Outbuf[] = 'L';
Outbuf[] = 'O';
Outbuf[] = 'W';
Outbuf[] = 'O';
Outbuf[] = 'R';
Outbuf[] = 'L';
Outbuf[] = 'D';
char len; len=HalUARTRead(,Uartbuf,);
if(len)//whatever it is
{
HalUARTWrite(,Outbuf,);
len=;
}
}
关于串口的配置在SerialApp_Init函数里uartConfig.callBackFunc 上边的那些,比特率之类的。
用ZStack安装路径里的SerialApp,改一改就能实现