要使用ZStack就不得不先了解ZStack的OSAL工作原理

http://blog.csdn.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 = 0;

  tasksEvents = (uint16 *)osal_mem_alloc( sizeof( uint16 ) * tasksCnt);
  osal_memset( tasksEvents, 0, (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[10];
  unsigned char Outbuf[10];

  Outbuf[0] = 'H';
  Outbuf[1] = 'E';
  Outbuf[2] = 'L';
  Outbuf[3] = 'L';
  Outbuf[4] = 'O';
  Outbuf[5] = 'W';
  Outbuf[6] = 'O';
  Outbuf[7] = 'R';
  Outbuf[8] = 'L';
  Outbuf[9] = 'D';           
  char len;

  len=HalUARTRead(0,Uartbuf,10);
  if(len)//whatever it is
  {
    HalUARTWrite(0,Outbuf,10);
    len=0;
  }
}

 

关于串口的配置在SerialApp_Init函数里uartConfig.callBackFunc 上边的那些,比特率之类的。

用ZStack安装路径里的SerialApp,改一改就能实现

 

posted on 2017-04-09 12:51  Mr.Winter  阅读(2169)  评论(0编辑  收藏  举报