編譯出來的hex燒入後無反應

編譯出來的hex燒入後無反應
需要將底下的
C:\Texas Instruments\ZStack-CC2530-2.4.0\Projects\zstack\Tools\CC2530DB\f8w2530.xcl
修改到hex生成模式
找到下列這幾行
// Include these two lines when generating a .hex file for banked code model:
//-M(CODE)[(_CODEBANK_START+_FIRST_BANK_ADDR)-(_CODEBANK_END+_FIRST_BANK_ADDR)]*\
//_NR_OF_BANKS+_FIRST_BANK_ADDR=0x8000
將前面的註解去掉
// Include these two lines when generating a .hex file for banked code model:
-M(CODE)[(_CODEBANK_START+_FIRST_BANK_ADDR)-(_CODEBANK_END+_FIRST_BANK_ADDR)]*\
_NR_OF_BANKS+_FIRST_BANK_ADDR=0x8000
在重新編譯所生成的檔案就可以燒入並且會動
但是要是編成可以直接燒入執行的模式
會出現一個warring就是開啟這個所出現的
但不會有問題

z-stack cc2530 SPI code

z-stack cc2530 SPI code:
/*******************************************************
 *                 INCLUDES
 *******************************************************/
#include "hal_types.h"
#include "hal_spi.h"
#include "OSAL.h"
#include "OnBoard.h"
#include "hal_assert.h"

/******************************************************
 *                     CONSTANTS
 ******************************************************/
/*
  //control軟體控制
  P1.4 - CS
  //spi硬體控制
  P1.5 - CLK
  P1.6 - MOSI
  P1.7 - MISO
*/

#define HAL_SPI_CS_PORT 1
#define HAL_SPI_CS_PIN  4
#define HAL_SPI_CLK_PORT 1
#define HAL_SPI_CLK_PIN  5
#define HAL_SPI_MOSI_PORT 1
#define HAL_SPI_MOSI_PIN  6
#define HAL_SPI_MISO_PORT 1
#define HAL_SPI_MISO_PIN  7

/**************************************************

 *                       MACROS

 **************************************************/
#define HAL_IO_SET(port, pin, val)        HAL_IO_SET_PREP(port, pin, val)
#define HAL_IO_SET_PREP(port, pin, val)   st( P##port##_##pin## = val; )
#define HAL_CONFIG_IO_OUTPUT(port, pin, val)      HAL_CONFIG_IO_OUTPUT_PREP(port, pin, val)
#define HAL_CONFIG_IO_OUTPUT_PREP(port, pin, val) st( P##port##SEL &= ~BV(pin); \
                                                      P##port##_##pin## = val; \
                                                      P##port##DIR |= BV(pin); )
#define HAL_CONFIG_IO_PERIPHERAL(port, pin)      HAL_CONFIG_IO_PERIPHERAL_PREP(port, pin)
#define HAL_CONFIG_IO_PERIPHERAL_PREP(port, pin) st( P##port##SEL |= BV(pin); )
/*******************************************************
 *                   FUNCTIONS - API
 *******************************************************/

void HalSpi_HW_Init(void);

void HalSpiInit(void)
{
  HalSpi_HW_Init();
}

static void halSpi_ConfigSPI(void)
{
   uint8 baud_exponent;
   uint8 baud_mantissa;

  PERCFG |= 0x02;
  //設定硬體控制腳位
  HAL_CONFIG_IO_PERIPHERAL(HAL_SPI_CLK_PORT,  HAL_SPI_CLK_PIN);
  HAL_CONFIG_IO_PERIPHERAL(HAL_SPI_MOSI_PORT, HAL_SPI_MOSI_PIN);
  HAL_CONFIG_IO_PERIPHERAL(HAL_SPI_MISO_PORT, HAL_SPI_MISO_PIN);
  //設定傳輸速度
  baud_exponent = 10;
  baud_mantissa =  0;

  /* Configure SPI */
  U1UCR  = 0x80;
  U1CSR  = 0x00;
  //U1GCR  = HAL_SPI_TRANSFER_MSB_FIRST | HAL_SPI_CLOCK_PHA_0 | HAL_SPI_CLOCK_POL_LO | baud_exponent;//正緣觸發,正緣接收資料
  U1GCR  = HAL_SPI_TRANSFER_MSB_FIRST | 0x40 | HAL_SPI_CLOCK_POL_LO | baud_exponent;//正緣觸發,負緣接收資料
  U1BAUD = baud_mantissa;
}

void HalSpi_HW_Init(void)
{
  //設定基本output模式
  HAL_CONFIG_IO_OUTPUT(HAL_SPI_CS_PORT,    HAL_SPI_CS_PIN,    1);
  halSpi_ConfigSPI();
}

static void spi_tx(uint8 x)
{
  U1CSR &= ~((1<<2) | (1<<1));
  U1DBUF = x;
  while( !(U1CSR & (1<<1)) );
}

void HalSpi_Ad7763_Read(uint8 addr, uint8 *recv_data)
{
    //將CS腳位到LOW
    HAL_IO_SET(HAL_SPI_CS_PORT, HAL_SPI_CS_PIN, 0);  //begin
    addr &= 0x3f;//ADE7765讀取 8bit→0 7bit→0
    spi_tx(addr);//傳送
    spi_tx(0);
    *recv_data = U1DBUF;//接收
    spi_tx(0);
    *(recv_data+1) = U1DBUF;
    spi_tx(0);
    *(recv_data+2) = U1DBUF;
    asm("NOP");
    asm("NOP");
    asm("NOP");
    asm("NOP");
    //將CS腳位到HIGH
    HAL_IO_SET(HAL_SPI_CS_PORT, HAL_SPI_CS_PIN, 1);  //end
}

void HalSpi_Ad7763_Write(uint8 addr, uint16 send_data)
{
    //將CS腳位到LOW
    HAL_IO_SET(HAL_SPI_CS_PORT, HAL_SPI_CS_PIN, 0);  //begin
    addr |= 0x80;//ADE7765寫入 8bit→1 7bit→0
    spi_tx(addr);
    spi_tx((send_data&0xff00)>>8);
    spi_tx(send_data&0x00ff);
    asm("NOP");
    asm("NOP");
    asm("NOP");
    asm("NOP");
    //將CS腳位到HIGH
    HAL_IO_SET(HAL_SPI_CS_PORT, HAL_SPI_CS_PIN, 1);  //end
}

使用z-stack內部function且return處理

使用z-stack內部function
例如:
ZDP_NwkAddrReq()
ZDP_IEEEAddrReq()
等等....
使用方法請查看Z-Stack API.pdf
發送端送出指令給各個device
假設有device回應會在以下函數做處理並且return (並非所有函數都會預設啟動)
ZDP_NWKAddrRsp() 
ZDP_IEEEAddrRsp()
等等....

這時候發送端會接收到return的值
這時候就要做register
在你的
void SampleApp_Init( uint8 task_id )
裡面加上
ZDO_RegisterForZDOMsg(SampleApp_TaskID, NWK_addr_rsp);
NWK_addr_rsp在Z-Stack API.pdf裡面的文件有寫到對應的function
例如:
ZDP_NWKAddrRsp()→NWK_addr_rsp
ZDP_IEEEAddrRsp()→IEEE_addr_rsp 
接下來就要處理接收後的值
也就是在
uint16 SampleApp_ProcessEvent( uint8 task_id, uint16 events )
加上而外的判斷事件

switch ( MSGpkt->hdr.event )
裡面額外加上
case ZDO_CB_MSG:
例如:
if ( events & SYS_EVENT_MSG ) {
  MSGpkt = (afIncomingMSGPacket_t *)osal_msg_receive( SampleApp_TaskID );
  while ( MSGpkt ) {
    switch ( MSGpkt->hdr.event ) {  
    case AF_INCOMING_MSG_CMD:
      SampleApp_MessageMSGCB( MSGpkt );
      break;
    case ZDO_CB_MSG:
      zdoapp_ProcessZDOMsgs( (zdoIncomingMsg_t *)MSGpkt );
      break; 
    default:
      break;
    }
    osal_msg_deallocate( (uint8 *)MSGpkt );
    MSGpkt = (afIncomingMSGPacket_t *)osal_msg_receive( SampleApp_TaskID );
  }  
  return (events ^ SYS_EVENT_MSG);
}

接下來就在副程式
zdoapp_ProcessZDOMsgs( (zdoIncomingMsg_t *)MSGpkt )
去解析收到的值
例如:解析NWK_addr_rsp
void zdoapp_ProcessZDOMsgs(zdoIncomingMsg_t *inMsg )
{
  ZDO_NwkIEEEAddrResp_t *pAddrRsp;
  switch ( inMsg->clusterID ) {
  case NWK_addr_rsp:
    pAddrRsp = ZDO_ParseAddrRsp( inMsg );
    if ( pAddrRsp ) {
      if ( pAddrRsp->status == ZSuccess ) {
        pAddrRsp->nwkAddr;//short address
        pAddrRsp->extAddr;//MAC address
      }
      osal_mem_free( pAddrRsp );
    }
    break;
  }
}
要看如何解析的話請到
ZDProfile.c
因為要看他如何編譯就可以解析