为什么读取UCB0RXBUF是在发送中断中?

[复制链接]
 楼主| wuhany 发表于 2016-10-23 18:32 | 显示全部楼层 |阅读模式
msp430g2xx3_uscib0_i2c_09例程,i2c从机接收数据的程序,请高手指点一下,为什么读取UCB0RXBUF是在发送中断中?
heweibig 发表于 2016-10-23 18:34 | 显示全部楼层
楼主程序可以公开吗?贴程序看下吧,这么说看不出什么原因
 楼主| wuhany 发表于 2016-10-23 18:35 | 显示全部楼层

#include <msp430.h>

unsigned char *PRxData; // Pointer to RX data
unsigned char RXByteCtr;
volatile unsigned char RxBuffer[128]; // Allocate 128 byte of RAM

int main(void)
{
BCSCTL2|=DIVS_3;
WDTCTL = WDTPW + WDTHOLD; // Stop WDT
P1SEL |= BIT6 + BIT7; // Assign I2C pins to USCI_B0
P1SEL2|= BIT6 + BIT7; // Assign I2C pins to USCI_B0
UCB0CTL1 |= UCSWRST; // Enable SW reset
UCB0CTL0 = UCMODE_3 + UCSYNC; // I2C Slave, synchronous mode
UCB0I2COA = 0x48; // Own Address is 048h
UCB0CTL1 &= ~UCSWRST; // Clear SW reset, resume operation
UCB0I2CIE |= UCSTPIE + UCSTTIE; // Enable STT and STP interrupt
IE2 |= UCB0RXIE; // Enable RX interrupt

while (1)
{
PRxData = (unsigned char *)RxBuffer; // Start of RX buffer
RXByteCtr = 0; // Clear RX byte count
__bis_SR_register(CPUOFF + GIE); // Enter LPM0 w/ interrupts
// Remain in LPM0 until master
// finishes TX
__no_operation(); // Set breakpoint >>here<< and read
} // read out the RxData buffer
}

//------------------------------------------------------------------------------
// The USCI_B0 data ISR is used to move received data from the I2C master
// to the MSP430 memory.
//------------------------------------------------------------------------------
#pragma vector = USCIAB0TX_VECTOR
__interrupt void USCIAB0TX_ISR(void)
{
*PRxData++ = UCB0RXBUF; // Move RX data to address PRxData
RXByteCtr++; // Increment RX byte count
}

//------------------------------------------------------------------------------
// The USCI_B0 state ISR is used to wake up the CPU from LPM0 in order to
// process the received data in the main program. LPM0 is only exit in case
// of a (re-)start or stop condition when actual data was received.
//------------------------------------------------------------------------------
#pragma vector = USCIAB0RX_VECTOR
__interrupt void USCIAB0RX_ISR(void)
{
UCB0STAT &= ~(UCSTPIFG + UCSTTIFG); // Clear interrupt flags
if (RXByteCtr) // Check RX byte counter
__bic_SR_register_on_exit(CPUOFF); // Exit LPM0 if data was
} // received
jiahy 发表于 2016-10-23 18:40 | 显示全部楼层
我觉得这里是一个示例程序,当发送完数据,此时产生发送中断。当发送中断发生时,执行*PRxData++ = UCB0RXBUF; RXByteCtr++; ,也就是接收数据
 楼主| wuhany 发表于 2016-10-23 19:39 | 显示全部楼层
在德州仪器技术支持社区找到是这样解释的,和大家分享一下:
MSP430G2553的数据发送接收共用一个中断向量的,另一个向量状态向量。因此#pragma vector = USCIAB0TX_VECTOR ,实际也是接收数据的中断头向量。它有四个状态改变的标志位:UCALIFG、UCNACKIFG、 UCSTTIFG、 UCSTPIFG,如果中断使能话,就会引起中断。具体的各个含义中断标志位可以查看数据手册。上面接收是代码主要功能,配置好参数,进入低功耗模式,当接收IIC数据start信号,进入#pragma vector = USCIAB0RX_VECTOR 后,退出低功耗,然后在另一个中断里接收数据。 其实就是一个数据起始和结束向量。
shimx 发表于 2016-10-23 19:41 | 显示全部楼层
楼主是准备自己解决所有的问题的 。
 楼主| wuhany 发表于 2016-10-23 19:42 | 显示全部楼层
嗯,我再好好缕一缕吧,有了好消息及时通知大家,结贴喽
yujielun 发表于 2016-10-23 22:37 | 显示全部楼层
发送中断读取?
yujielun 发表于 2016-10-23 22:38 | 显示全部楼层
不是接受中断吗?
l科科1987 发表于 2016-10-23 23:25 | 显示全部楼层
MSP430G2553的数据发送接收共用一个中断向量的
hudi008 发表于 2016-10-24 16:55 | 显示全部楼层
读取在发送中断里面?
hudi008 发表于 2016-10-24 16:57 | 显示全部楼层
你的发送程序有问题吗?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

879

主题

10435

帖子

4

粉丝
快速回复 在线客服 返回列表 返回顶部