大神帮忙指导一下为什么这个程序无法进入中断,也无法发送数据?
利尔达的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<Channel_number;)
{
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<n;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<Channel_number;)
{
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<n;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);
}
此帖出自
小平头技术问答
一周热门 更多>