2245|1

11

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

关于CC4i30无线发送的问题 [复制链接]

大神帮忙指导一下为什么这个程序无法进入中断,也无法发送数据?
利尔达的CC430F5137板子
#include "../inc/RF_Toggle_LED_Demo.h"

#define  Channel_number      3
#define  PACKET_LEN         Channel_number*2*6                        // PACKET_LEN <= 61

// 433MHz下的发射功率宏定义
#define  PATABLE_VAL        (0xC0)          // 0XC4-- 10 dBm;
                                            // 0X50-- 0  dBm;
                                            // 0X2D-- -6 dBm;
                                            // 0X26-- -12dBm;
                                            // 0x05-- -30dBm;

extern RF_SETTINGS rfSettings;

unsigned int i = 0, RX=0;

unsigned char transmitting = 1;

unsigned int index = 1,j=0;
unsigned int TX=0,TXX=0;
  
unsigned char results[PACKET_LEN];
unsigned short result0;
unsigned short result1;
unsigned short result2;

void main( void )
{  
  // Stop watchdog timer to prevent time out reset
  WDTCTL = WDTPW + WDTHOLD;

  // Increase PMMCOREV level to 2 for proper radio operation
  SetVCore(2);                           
  
  ResetRadioCore();     
  InitRadio();
  
  Strobe( RF_SIDLE );
  Strobe( RF_SFRX  );
  
  TransmitOn();  
  InitADC();

  
  _EINT();  
  while (1)
  {
    __no_operation();
   
      TransmitOn();  
      transmitting = 1;

      //getresult();
      
       for(index = 0;index<2;)
    {
        result0 = ADC12MEM0;
        results[index+0]=result0>>8; //high
        results[index+1]=result0;     //low
        
        index=index+2;   
    }
   
       index = 0;  // Reset the index; Set Breakpoint here
      //Strobe( RF_SFTX );//FLUSH THE TX FIFO
      _NOP();
      Transmit( (unsigned char*)results,sizeof results);
      TX++;
  }
}


void getresult(void)
{
    for(index = 0,j=0;j     {
        result0 = ADC12MEM0;
        result1 = ADC12MEM1;
        result2 = ADC12MEM2;
        results[index+0]=result0>>8;
        results[index+1]=result0;      
        results[index+2]=result1>>8;
        results[index+3]=result1;      
        results[index+4]=result2>>8;
        results[index+5]=result2;
        
        
        index=index+6;
        j++;
    }
}
void InitADC(void)
{
  P2SEL |= 0x01;
  //REFCTL0 |= REFMSTR + REFVSEL_0 + REFON + REFTCOFF;    // Enable internal 1.5V reference
  //ADC12CTL0 = ADC12ON+ADC12SHT0_2+ADC12MSC; // Turn on ADC12, set sampling time//A0//256 ADC12CLK
                                            // set multiple sample conversion
  
  ADC12CTL0 = ADC12ON+ADC12SHT0_8+ADC12MSC;
  ADC12CTL1 = ADC12SHP+ADC12CONSEQ_2;
   
  //ADC12CTL1 = ADC12SHP+ADC12CONSEQ_3;       // Use sampling timer, set mode//3-Sequence of Conversions
  //ADC12IE = 0x01;                           // Enable ADC12IFG.0  //Enable interrupt
  //ADC12MCTL0 = ADC12INCH_0;                 // ref+=AVcc, channel = A0
  //ADC12MCTL1 = ADC12INCH_1;                 // ref+=AVcc, channel = A1
  //ADC12MCTL2 = ADC12INCH_2+ADC12EOS;                 // ref+=AVcc, channel = A2
  //ADC12MCTL3 = ADC12INCH_3;        // ref+=AVcc, channel = A3, end seq.
  
  ADC12CTL0 |= ADC12ENC;                    // Enable conversions
  ADC12CTL0 |= ADC12SC;                     // Start conversion
}


void delayms(unsigned int n)
{
  unsigned int i,j;
  for(i=0;i   {
    for(j=0;j<800;j++);
  }
}



void InitRadio(void)
{
  // Set the High-Power Mode Request Enable bit so LPM3 can be entered
  // with active radio enabled
  PMMCTL0_H = 0xA5;
  PMMCTL0_L |= PMMHPMRE_L;
  PMMCTL0_H = 0x00;
  
  WriteRfSettings(&rfSettings);
  
  WriteSinglePATable(PATABLE_VAL);
}

void Transmit(unsigned char *buffer, unsigned char length)
{
  RF1AIES |= BIT9;                          
  RF1AIFG &= ~BIT9;                         // Clear pending interrupts
  RF1AIE |= BIT9;                           // Enable TX end-of-packet interrupt
  
  WriteBurstReg(RF_TXFIFOWR, buffer, length);     
  
  Strobe( RF_STX );                         // Strobe STX   
}

void TransmitOn(void)
{  
  RF1AIES |= BIT9;                          // Falling edge of RFIFG9
  RF1AIFG &= ~BIT9;                         // Clear a pending interrupt
  RF1AIE  |= BIT9;                          // Enable the interrupt
  
  Strobe( RF_STX );                     
}

void ReceiveOff(void)
{
  RF1AIE &= ~BIT9;                          // Disable RX interrupts
  RF1AIFG &= ~BIT9;                         // Clear pending IFG

  // It is possible that ReceiveOff is called while radio is receiving a packet.
  // Therefore, it is necessary to flush the RX FIFO after issuing IDLE strobe
  // such that the RXFIFO is empty prior to receiving a packet.
  Strobe( RF_SIDLE );
  Strobe( RF_SFRX  );                       
}

#pragma vector=CC1101_VECTOR
__interrupt void CC1101_ISR(void)
{
  switch(__even_in_range(RF1AIV,32))        // Prioritizing Radio Core Interrupt
  {
    case  0: break;                         // No RF core interrupt pending                                            
    case  2: break;                         // RFIFG0
    case  4: break;                         // RFIFG1
    case  6: break;                         // RFIFG2
    case  8: break;                         // RFIFG3
    case 10: break;                         // RFIFG4
    case 12: break;                         // RFIFG5
    case 14: break;                         // RFIFG6         
    case 16: break;                         // RFIFG7
    case 18: break;                         // RFIFG8
    case 20:                                // RFIFG9
      if(transmitting)                    // TX end of packet
      {
        //RF1AIE &= ~BIT9;                    // Disable TX end-of-packet interrupt                        
        TXX++;
      }
      else while(1);                             // trap
      break;
    case 22: break;                         // RFIFG10
    case 24: break;                         // RFIFG11
    case 26: break;                         // RFIFG12
    case 28: break;                         // RFIFG13
    case 30: break;                         // RFIFG14
    case 32: break;                         // RFIFG15
  }  
  //__bic_SR_register_on_exit(LPM3_bits);     
}
#include "../inc/RF_Toggle_LED_Demo.h"

#define  Channel_number      3
#define  PACKET_LEN         Channel_number*2*6                        // PACKET_LEN <= 61

// 433MHz下的发射功率宏定义
#define  PATABLE_VAL        (0xC0)          // 0XC4-- 10 dBm;
                                            // 0X50-- 0  dBm;
                                            // 0X2D-- -6 dBm;
                                            // 0X26-- -12dBm;
                                            // 0x05-- -30dBm;

extern RF_SETTINGS rfSettings;

unsigned int i = 0, RX=0;

unsigned char transmitting = 1;

unsigned int index = 1,j=0;
unsigned int TX=0,TXX=0;
  
unsigned char results[PACKET_LEN];
unsigned short result0;
unsigned short result1;
unsigned short result2;

void main( void )
{  
  // Stop watchdog timer to prevent time out reset
  WDTCTL = WDTPW + WDTHOLD;

  // Increase PMMCOREV level to 2 for proper radio operation
  SetVCore(2);                           
  
  ResetRadioCore();     
  InitRadio();
  
  Strobe( RF_SIDLE );
  Strobe( RF_SFRX  );
  
  TransmitOn();  
  InitADC();

  
  _EINT();  
  while (1)
  {
    __no_operation();
   
      TransmitOn();  
      transmitting = 1;

      //getresult();
      
       for(index = 0;index<2;)
    {
        result0 = ADC12MEM0;
        results[index+0]=result0>>8; //high
        results[index+1]=result0;     //low
        
        index=index+2;   
    }
   
       index = 0;  // Reset the index; Set Breakpoint here
      //Strobe( RF_SFTX );//FLUSH THE TX FIFO
      _NOP();
      Transmit( (unsigned char*)results,sizeof results);
      TX++;
  }
}


void getresult(void)
{
    for(index = 0,j=0;j     {
        result0 = ADC12MEM0;
        result1 = ADC12MEM1;
        result2 = ADC12MEM2;
        results[index+0]=result0>>8;
        results[index+1]=result0;      
        results[index+2]=result1>>8;
        results[index+3]=result1;      
        results[index+4]=result2>>8;
        results[index+5]=result2;
        
        
        index=index+6;
        j++;
    }
}
void InitADC(void)
{
  P2SEL |= 0x01;
  //REFCTL0 |= REFMSTR + REFVSEL_0 + REFON + REFTCOFF;    // Enable internal 1.5V reference
  //ADC12CTL0 = ADC12ON+ADC12SHT0_2+ADC12MSC; // Turn on ADC12, set sampling time//A0//256 ADC12CLK
                                            // set multiple sample conversion
  
  ADC12CTL0 = ADC12ON+ADC12SHT0_8+ADC12MSC;
  ADC12CTL1 = ADC12SHP+ADC12CONSEQ_2;
   
  //ADC12CTL1 = ADC12SHP+ADC12CONSEQ_3;       // Use sampling timer, set mode//3-Sequence of Conversions
  //ADC12IE = 0x01;                           // Enable ADC12IFG.0  //Enable interrupt
  //ADC12MCTL0 = ADC12INCH_0;                 // ref+=AVcc, channel = A0
  //ADC12MCTL1 = ADC12INCH_1;                 // ref+=AVcc, channel = A1
  //ADC12MCTL2 = ADC12INCH_2+ADC12EOS;                 // ref+=AVcc, channel = A2
  //ADC12MCTL3 = ADC12INCH_3;        // ref+=AVcc, channel = A3, end seq.
  
  ADC12CTL0 |= ADC12ENC;                    // Enable conversions
  ADC12CTL0 |= ADC12SC;                     // Start conversion
}


void delayms(unsigned int n)
{
  unsigned int i,j;
  for(i=0;i   {
    for(j=0;j<800;j++);
  }
}



void InitRadio(void)
{
  // Set the High-Power Mode Request Enable bit so LPM3 can be entered
  // with active radio enabled
  PMMCTL0_H = 0xA5;
  PMMCTL0_L |= PMMHPMRE_L;
  PMMCTL0_H = 0x00;
  
  WriteRfSettings(&rfSettings);
  
  WriteSinglePATable(PATABLE_VAL);
}

void Transmit(unsigned char *buffer, unsigned char length)
{
  RF1AIES |= BIT9;                          
  RF1AIFG &= ~BIT9;                         // Clear pending interrupts
  RF1AIE |= BIT9;                           // Enable TX end-of-packet interrupt
  
  WriteBurstReg(RF_TXFIFOWR, buffer, length);     
  
  Strobe( RF_STX );                         // Strobe STX   
}

void TransmitOn(void)
{  
  RF1AIES |= BIT9;                          // Falling edge of RFIFG9
  RF1AIFG &= ~BIT9;                         // Clear a pending interrupt
  RF1AIE  |= BIT9;                          // Enable the interrupt
  
  Strobe( RF_STX );                     
}

void ReceiveOff(void)
{
  RF1AIE &= ~BIT9;                          // Disable RX interrupts
  RF1AIFG &= ~BIT9;                         // Clear pending IFG

  // It is possible that ReceiveOff is called while radio is receiving a packet.
  // Therefore, it is necessary to flush the RX FIFO after issuing IDLE strobe
  // such that the RXFIFO is empty prior to receiving a packet.
  Strobe( RF_SIDLE );
  Strobe( RF_SFRX  );                       
}

#pragma vector=CC1101_VECTOR
__interrupt void CC1101_ISR(void)
{
  switch(__even_in_range(RF1AIV,32))        // Prioritizing Radio Core Interrupt
  {
    case  0: break;                         // No RF core interrupt pending                                            
    case  2: break;                         // RFIFG0
    case  4: break;                         // RFIFG1
    case  6: break;                         // RFIFG2
    case  8: break;                         // RFIFG3
    case 10: break;                         // RFIFG4
    case 12: break;                         // RFIFG5
    case 14: break;                         // RFIFG6         
    case 16: break;                         // RFIFG7
    case 18: break;                         // RFIFG8
    case 20:                                // RFIFG9
      if(transmitting)                    // TX end of packet
      {
        //RF1AIE &= ~BIT9;                    // Disable TX end-of-packet interrupt                        
        TXX++;
      }
      else while(1);                             // trap
      break;
    case 22: break;                         // RFIFG10
    case 24: break;                         // RFIFG11
    case 26: break;                         // RFIFG12
    case 28: break;                         // RFIFG13
    case 30: break;                         // RFIFG14
    case 32: break;                         // RFIFG15
  }  
  //__bic_SR_register_on_exit(LPM3_bits);     
}
 
点赞 关注

回复
举报

11

帖子

0

TA的资源

一粒金砂(中级)

沙发
 
复制的时候多复制了一遍。。。。
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表