关于ZStack-CC2530-2.3.0-1.4.0中simpleApp例子的 终端节点如何向协调器发送数据,以及数据的接收

上一篇文章写到终端节点向应用层发送绑定确认,即zb_BindConfirm函数,我们可以看下源代码。

 

void zb_BindConfirm( uint16 commandId, uint8 status )
{
  (void)commandId;

  if ( ( status == ZB_SUCCESS )&& ( myAppState == APP_START ) )//条件成立
  {
    myAppState =APP_BOUND;//将应用状态修改为 绑定状态

    //Startreporting sensor values
   myApp_StartReporting();//开始传输函数
  }
  else
  {
    // Continueto discover a collector
   osal_start_timerEx( sapi_TaskID, MY_FIND_COLLECTOR_EVT,myBindRetryDelay );
  }

 

查看传输函数源代码:

 

void myApp_StartReporting( void )
{
  osal_start_timerEx( sapi_TaskID,MY_REPORT_TEMP_EVT, myTempReportPeriod );//传输温度事件
  osal_start_timerEx( sapi_TaskID,MY_REPORT_BATT_EVT, myBatteryCheckPeriod );//传输电压事件
  HalLedSet( HAL_LED_1, HAL_LED_MODE_ON);//点亮LED_1;

}

我们看终端节点sapi层如何处理这两个时间,首先找到SAPI_ProcessEvent函数中的:

 

 if ( events & ( ZB_USER_EVENTS) )
  {
    // Userevents are passed to the application
#if ( SAPI_CB_FUNC )
   zb_HandleOsalEvent( events );//事件处理函数
#endif

    // Do notreturn here, return 0 later
  }

 

进入到函数中去:

 

void zb_HandleOsalEvent( uint16 event )
{
  uint8 pData[2];

  if ( event & MY_START_EVT)
  {
   zb_StartRequest();
  }
  if ( event & MY_REPORT_TEMP_EVT)
  {
    // Read andreport temperature value
    pData[0] =TEMP_REPORT;//要发送的数据的类型
    pData[1]=  myApp_ReadTemperature();//利用此函数接收读取的温度值
   zb_SendDataRequest( 0xFFFE, SENSOR_REPORT_CMD_ID, 2, pData, 0,AF_ACK_REQUEST, 0 );//发送数据
   osal_start_timerEx( sapi_TaskID, MY_REPORT_TEMP_EVT,myTempReportPeriod );
  }

  if ( event &MY_REPORT_BATT_EVT )
  {
    // Readbattery value
    // Ifbattery level low, report battery value
    pData[0] =BATTERY_REPORT;//要发送的数据的类型
    pData[1]=  myApp_ReadBattery();//利用此函数接收读取的温度值
   zb_SendDataRequest( 0xFFFE, SENSOR_REPORT_CMD_ID, 2, pData, 0,AF_ACK_REQUEST, 0 );//发送数据
   osal_start_timerEx( sapi_TaskID, MY_REPORT_BATT_EVT,myBatteryCheckPeriod );
  }

  if ( event &MY_FIND_COLLECTOR_EVT )
  {
    // Find andbind to a collector device
   zb_BindDevice( TRUE, SENSOR_REPORT_CMD_ID, (uint8 *)NULL );
  }

}

 

好,然后我们看下协调器是怎么接收数据的,首先切换工作空间为协调器模式,查看sapi.c文件,查看SAPI_ProcessEvent函数,找到:

case AF_INCOMING_MSG_CMD:
         pMSGpkt = (afIncomingMSGPacket_t *) pMsg;
         SAPI_ReceiveDataIndication(pMSGpkt->srcAddr.addr.shortAddr,pMSGpkt->clusterId,
                                   pMSGpkt->cmd.DataLength,pMSGpkt->cmd.Data);//协调器在此函数中进行数据的接收工作。
         break;

 

查看此函数:

 

void SAPI_ReceiveDataIndication( uint16 source, uint16 command,uint16 len, uint8 *pData  )
{
#if defined ( MT_SAPI_CB_FUNC )
 
  if ( SAPICB_CHECK( SPI_CB_SAPI_RCV_DATA_IND ))
  {
   zb_MTCallbackReceiveDataIndication( source, command, len,pData  );
  }
  else
#endif  //MT_SAPI_CB_FUNC
  {
#if ( SAPI_CB_FUNC )//编译通过
   zb_ReceiveDataIndication( source, command, len,pData  );
#endif
  }
}

 

查看源代码:

 

oid zb_FindDeviceConfirm( uint8 searchType, uint8 *searchKey,uint8 *result )
{
}

CONST uint8 strDevice[] = "Device:0x";
CONST uint8 strTemp[] = "Temp: ";
CONST uint8 strBattery[] = "Battery: ";
void zb_ReceiveDataIndication( uint16 source, uint16 command,uint16 len, uint8 *pData  )
{
  uint8 buf[32];
  uint8 *pBuf;
  uint8 tmpLen;
  uint8 sensorReading;

  if (command ==SENSOR_REPORT_CMD_ID)//条件成立
  {
    // Receivedreport from a sensor
   sensorReading = pData[1];

    // Iftool available, write to serial port

    tmpLen =(uint8)osal_strlen( (char*)strDevice );
    pBuf =osal_memcpy( buf, strDevice, tmpLen );
    _ltoa(source, pBuf, 16 );
    pBuf +=4;
    *pBuf++ = '';

    if (pData[0] == BATTERY_REPORT )//如果是电压传送,执行下面函数
    {
     tmpLen = (uint8)osal_strlen( (char*)strBattery );
     pBuf = osal_memcpy( pBuf, strBattery, tmpLen );

     *pBuf++ = (sensorReading / 10 ) +'0';    //convent msb to ascii
     *pBuf++ ='.';                           // decimal point ( battery reading is in units of 0.1 V
     *pBuf++ = (sensorReading % 10 ) +'0';    //convert lsb to ascii
     *pBuf++ = ' ';
     *pBuf++ = 'V';
    }
   else//如果是温度传送,执行下面函数
    {
     tmpLen = (uint8)osal_strlen( (char*)strTemp );
     pBuf = osal_memcpy( pBuf, strTemp, tmpLen );

     *pBuf++ = (sensorReading / 10 ) +'0';    //convent msb to ascii
     *pBuf++ = (sensorReading % 10 ) +'0';    //convert lsb to ascii
     *pBuf++ = ' ';
     *pBuf++ = 'C';
    }

    *pBuf++ ='\r';
    *pBuf++ ='\n';
    *pBuf ='\0';

#if defined( MT_TASK)//若定义了MT_TASK ,则执行下面函数即串口函数,发送到PC机上显示。
    debug_str((uint8 *)buf );
#endif

    // canalso write directly to uart

  }
}

到此为止,终端节点向协调器发送数据,协调器接收数据并发送到串口 

完成。。。


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: zstack-cc2530-2.3.0-1.4.0是一个基于CC2530芯片的ZigBee协议栈版本,用于构建低功耗、无线传感网络。它支持ZigBee协议的各种功能,如网络组建、设备发现、数据传输等。同时,它还提供了丰富的API接口和开发工具,方便开发人员进行应用开发和调试。 ### 回答2: zstack-cc2530-2.3.0-1.4.0是一款嵌入式无线协议栈软件,主要应用于物联网领域的传感、控制设备等智能硬件,使其能够实现无线通信、数据采集和云端对接。该协议栈基于IEEE 802.15.4标准,采用Zigbee协议,支持网络拓扑结构包括星型、点对点、树状和网状等。 zstack-cc2530-2.3.0-1.4.0的特点是具有高度的可靠性、稳定性和安全性。其采用AES加密算法,能够保证通信数据的隐私安全;同时支持信号质量监测和链路质量反馈,能够实现网络拓扑的优化和故障检测等功能;此外,该协议栈还支持OTA升级和协议栈配置等高级功能,便于对智能硬件进行远程维护和管理。 除此之外,zstack-cc2530-2.3.0-1.4.0还具有易于开发和适配的特点。该协议栈提供了丰富的API接口和开发工具包,支持多种开发环境和硬件平台,方便开发人员进行二次开发和定制化,大大降低了开发成本和周期。同时,该协议栈还通过Zigbee联盟的认证,确保了其在标准兼容性、互操作性和稳定性等方面的表现。 总之,zstack-cc2530-2.3.0-1.4.0是一款功能强大、易于开发和适配、具有高可靠性和安全性的无线协议栈软件,可以广泛应用于物联网领域的智能硬件。 ### 回答3: zstack-cc2530-2.3.0-1.4.0 是一种无线通信模块,它是针对 TI 公司的 CC2530 系统级芯片设计的。该模块运行在 2.4GHz ISM 频段,可以实现高质量的数据传输,并且在无线网络实现高度的可靠性和安全性。该模块具有协同处理、内存、收发、MAC 和 PHY 等多种功能,可以应用于多种物联网场景。 zstack-cc2530-2.3.0-1.4.0 支持运行 ZigBee 网络协议栈,并提供了丰富的接口和 API,以便用户能够快速、轻松地开发具有丰富功能的 ZigBee 产品。该模块基于 Z-Stack 协议栈,支持 ZDO、ZCL 等多个协议,可以实现灵活、可靠、高效的无线通信。 该模块还支持 OTA(空升级)功能,可以让用户通过无线网络升级设备固件。同时,该模块还具有低功耗模式,可以使设备的电池寿命更长。 总之,zstack-cc2530-2.3.0-1.4.0 是一种高度可靠、灵活、安全性强的无线通信模块,可以为物联网应用提供强有力的支持,并且具有广泛的适用性和灵活性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值