This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

MSP430F5510的硬件SPI问题,连续读会出现丢失第一个数据的情况

Other Parts Discussed in Thread: MSP430FG4618, CC1101, MSP430F2132

//                   MSP430F550x
//                 -----------------
//             /|\|                 |
//              | |                 |
//              --|RST          P4.7|-> LED
//                |                 |
//                |             P3.2|-> Serial Clock Out (UCB0SCK)
//                |             P3.1|<- Data In  (UCB0SOMI)
//                |             P3.0|-> Data Out (UCB0SIMO)
//                |             P3.0|-> Data Out (UCB0STE)

参考的例程为 slac129a.zip (MSP430FG4618/F2013 Experimenter’s Board Software),使用到的2个功能为:

char TI_CC_SPIReadReg(char addr)
{
  char x;

  TI_CC_CSn_PxOUT &= ~TI_CC_CSn_PIN;        // /CS enable
  while (!(UCB0IFG &= ~UCRXIFG));                // Wait for TX to finish
  UCB0TXBUF = (addr | TI_CCxxx0_READ_SINGLE);// Send address
  while (!(UCB0IFG &= ~UCRXIFG));                // Wait for TX to finish
  UCB0TXBUF = 0;                            // Dummy write so we can read data
  // Address is now being TX'ed, with dummy byte waiting in TXBUF...
  while (!(UCB0IFG &= ~UCRXIFG));                // Wait for RX to finish
  // Dummy byte RX'ed during addr TX now in RXBUF
  UCB0IFG &= ~UCRXIFG;                       // Clear flag set during addr write
  while (!(UCB0IFG &= ~UCRXIFG));                // Wait for end of dummy byte TX
  // Data byte RX'ed during dummy byte write is now in RXBUF
  x = UCB0RXBUF;                            // Read data
  TI_CC_CSn_PxOUT |= TI_CC_CSn_PIN;         // /CS disable

  return x;
}

 

void TI_CC_SPIReadBurstReg(char addr, char *buffer, char count)
{
  char i;

  TI_CC_CSn_PxOUT &= ~TI_CC_CSn_PIN;        // /CS enable
  while (TI_CC_SPI_USCIB0_PxIN&TI_CC_SPI_USCIB0_SOMI);// Wait for CCxxxx ready
  UCB0IFG &= ~UCRXIFG;                       // Clear flag
  UCB0TXBUF = (addr | TI_CCxxx0_READ_BURST);   // Send address
  while (!(UCB0IFG &= ~UCRXIFG));                // Wait for TXBUF ready
  UCB0TXBUF = 0;                            // Dummy write to read 1st data byte
  // Addr byte is now being TX'ed, with dummy byte to follow immediately after
  while (!(UCB0IFG &= ~UCRXIFG));                // Wait for end of addr byte TX
  UCB0IFG &= ~UCRXIFG;                       // Clear flag
  while (!(UCB0IFG &= ~UCRXIFG));                // Wait for end of 1st data byte TX
  // First data byte now in RXBUF
  for (i = 0; i < (count-1); i++)
  {
    UCB0TXBUF = 0;                          //Initiate next data RX, meanwhile..
    buffer[i] = UCB0RXBUF;                  // Store data from last data RX
    while (!(UCB0IFG &= ~UCRXIFG));              // Wait for RX to finish
  }
  buffer[count-1] = UCB0RXBUF;              // Store last RX byte in buffer
  TI_CC_CSn_PxOUT |= TI_CC_CSn_PIN;         // /CS disable
}

现在的问题是,时钟系统采用ACLK=32.768、SMCK=24.576MHz,当启动F5510的硬件SPI并配置端口后,CC1101模块上电,设置相关参数。为验证SPI,采用了以下2种方式对CC1101的寄存器进行读写:

方法1、连续方式的单个读寄存器,即循环使用  TI_CC_SPIReadReg() 读一批寄存器的值,结果为正确。

  for (i=0; i<32; i++) RxBuf[i] = TI_CC_SPIReadReg(i);

方法2、使用例程的 TI_CC_SPIReadBurstReg(0, RxBuf, 32)  读同一批寄存器的值,结果出现第一个结果丢失的现象、其余全部正确。即期望的第1个数据不见了,第2个数据被保存在了RxBuf[0],第3个数据被保存在了RxBuf[1],第4个数据被保存在了RxBuf[2],...,第32个数据被保存在了RxBuf[30](正确位置应该是保存在RxBuf[31])。

补充:方法2如果用于MSP430F2132+CC1101、DCO_1MHz则不会发生这种数据丢失的现象。

请求帮助分析原因并解决这个BUG,谢谢。