TI中文支持网
TI专业的中文技术问题搜集分享网站

I2C从机问题

使用MSP430FR2311 I2C作为从机,主机读取数据失败,跟踪发现主机发送起始信号后状态返回失败

从机代码如下:

P1DIR &= ~(BIT2|BIT3); //设置为输入方向 
P1REN &= ~(BIT2|BIT3); //上拉下拉禁止使能P1SEL1 &= ~(BIT2|BIT3); //设置管脚复用P1SEL0 |= (BIT2|BIT3);

//Disable the USCI module
UCB0CTLW0 |= UCSWRST;

//Clear USCI master mode
UCB0CTLW0 &= ~UCMST;

//Configure I2C as Slave and Synchronous mode
UCB0CTLW0 |= UCMODE_3 + UCSYNC;

//Set up the slave address.
UCB0I2COA0 = SMspI2c_SlaveAddr | UCOAEN; // own address is 0x48 + enable
UCB0CTLW0 &= ~UCSWRST; // clear reset register
//Clear the I2C interrupt source.
UCB0IFG &= ~(UCRXIFG0 | UCTXIFG0);
//Enable the interrupt masked bit
UCB0IE |= (UCRXIE0 | UCTXIE0);
__bis_SR_register(GIE);

#pragma vector = USCI_B0_VECTOR
__interrupt void USCIB0_ISR(void)
{
SMspIo_OutputLevel(PortRedLed,SBase_IoLevel_High); switch(__even_in_range(UCB0IV,UCIV__UCBIT9IFG))
{
case 0x00: break; // Vector 0: No interrupts break;
case 0x02: break; // Vector 2: ALIFG break;
case 0x04: break; // Vector 4: NACKIFG break;
case 0x06: break; // Vector 6: STTIFG break;
case 0x08: break; // Vector 8: STPIFG break;
case 0x0a: break; // Vector 10: RXIFG3 break;
case 0x0c: break; // Vector 14: TXIFG3 break;
case 0x0e: break; // Vector 16: RXIFG2 break;
case 0x10: break; // Vector 18: TXIFG2 break;
case 0x12: break; // Vector 20: RXIFG1 break;
case 0x14: break; // Vector 22: TXIFG1 break;
case 0x16: // Vector 24: RXIFG0 break; //RXData = UCB0RXBUF;
break; case 0x18: // Vector 26: TXIFG0 break;
UCB0TXBUF = 0xA5;
break; case 0x1a: break; // Vector 28: BCNTIFG break;
case 0x1c: break; // Vector 30: clock low timeout break;
case 0x1e: break; // Vector 32: 9th bit break;
default: break;
}
}

LUCA WANG:

修改主机端端口配置后,跟踪发现发送设备地址后没有返回正确的状态。主机发送的设备地址为0x48,示波器可以抓到0x48的波形

LUCA WANG:

使用MSP430FR2311 I2C作为从机,主机发送从机地址后,没有返回正确的状态(没有收到ACK???)。示波器能量到发送出去的从机地址波形

从机代码如下:

P1SEL0 |= BIT2 | BIT3; //Disable the USCI module UCB0CTLW0 = UCSWRST;

//Clear USCI master mode UCB0CTLW0 &= ~UCMST;

//Configure I2C as Slave and Synchronous mode UCB0CTLW0 |= UCMODE_3 | UCSYNC;

//Set up the slave address. UCB0I2COA0 = SMspI2c_SlaveAddr | UCOAEN; // own address is 0x48 + enable //UCB0CTLW1 &= ~UCETXINT; UCB0CTLW0 &= ~UCSWRST; // clear reset register //Clear the I2C interrupt source. UCB0IFG &= ~(UCRXIFG0 | UCTXIFG0); //Enable the interrupt masked bit UCB0IE |= (UCRXIE0 | UCTXIE0); __bis_SR_register(GIE);

Gary Gao:

回复 LUCA WANG:

没看到你的GPIO口使能。 PM5CTL0 &= ~LOCKLPM5;

请参考下面的官方例程

/* –COPYRIGHT–,BSD_EX

* Copyright (c) 2014, Texas Instruments Incorporated

* All rights reserved.

*

* Redistribution and use in source and binary forms, with or without

* modification, are permitted provided that the following conditions

* are met:

*

* * Redistributions of source code must retain the above copyright

* notice, this list of conditions and the following disclaimer.

*

* * Redistributions in binary form must reproduce the above copyright

* notice, this list of conditions and the following disclaimer in the

* documentation and/or other materials provided with the distribution.

*

* * Neither the name of Texas Instruments Incorporated nor the names of

* its contributors may be used to endorse or promote products derived

* from this software without specific prior written permission.

*

* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"

* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,

* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR

* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR

* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,

* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,

* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;

* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,

* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR

* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,

* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

*

*******************************************************************************

*

* MSP430 CODE EXAMPLE DISCLAIMER

*

* MSP430 code examples are self-contained low-level programs that typically

* demonstrate a single peripheral function or device feature in a highly

* concise manner. For this the code may rely on the device's power-on default

* register values and settings such as the clock configuration and care must

* be taken when combining code from several examples to avoid potential side

* effects. Also see www.ti.com/grace for a GUI- and www.ti.com/msp430ware

* for an API functional library-approach to peripheral configuration.

*

* –/COPYRIGHT–*/

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

// MSP430FR413x Demo – eUSCI_B0 I2C Slave TX multiple bytes to MSP430 Master

//

// Description: This demo connects two MSP430's via the I2C bus. The master

// reads from the slave. This is the SLAVE code. The TX data begins at 0

// and is incremented each time it is sent. A stop condition

// is used as a trigger to initialize the outgoing data.

// The USCI_B0 TX interrupt is used to know

// when to TX.

// ACLK = default REFO ~32768Hz, MCLK = SMCLK = default DCODIV ~1MHz.

//

// *****used with "MSP430G6021_euscib0_i2c_10.c"****

//

// /|\ /|\

// MSP430FR4133 10k 10k MSP430FR4133

// slave | | master

// —————– | | —————–

// | 5.2/UCB0SDA|<-|—-|->|P5.2/UCB0SDA |

// | | | | |

// | | | | |

// | P5.3/UCB0SCL|<-|——>|P5.3/UCB0SCL |

// | | | |

//

// Cen Fang

// Texas Instruments Inc.

// June 2013

// Built with IAR Embedded Workbench v5.60 & Code Composer Studio v5.5

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

#include <msp430.h>

volatile unsigned char TXData;

int main(void)

{

WDTCTL = WDTPW | WDTHOLD;

// Configure GPIO

P5SEL0 |= BIT2 | BIT3; // I2C pins

// Disable the GPIO power-on default high-impedance mode to activate

// previously configured port settings

PM5CTL0 &= ~LOCKLPM5;

// Configure USCI_B0 for I2C mode

UCB0CTLW0 = UCSWRST; // Software reset enabled

UCB0CTLW0 |= UCMODE_3 | UCSYNC; // I2C mode, sync mode

UCB0I2COA0 = 0x48 | UCOAEN; // own address is 0x48 + enable

UCB0CTLW0 &= ~UCSWRST; // clear reset register

UCB0IE |= UCTXIE0 | UCSTPIE; // transmit,stop interrupt enable

__bis_SR_register(LPM0_bits | GIE); // Enter LPM0 w/ interrupts

__no_operation();

}

#if defined(__TI_COMPILER_VERSION__) || defined(__IAR_SYSTEMS_ICC__)

#pragma vector = USCI_B0_VECTOR

__interrupt void USCIB0_ISR(void)

#elif defined(__GNUC__)

void __attribute__ ((interrupt(USCI_B0_VECTOR))) USCIB0_ISR (void)

#else

#error Compiler not supported!

#endif

{

switch(__even_in_range(UCB0IV, USCI_I2C_UCBIT9IFG))

{

case USCI_NONE: break; // Vector 0: No interrupts

case USCI_I2C_UCALIFG: break; // Vector 2: ALIFG

case USCI_I2C_UCNACKIFG: break; // Vector 4: NACKIFG

case USCI_I2C_UCSTTIFG: break; // Vector 6: STTIFG

case USCI_I2C_UCSTPIFG: // Vector 8: STPIFG

TXData = 0;

UCB0IFG &= ~UCSTPIFG; // Clear stop condition int flag

break;

case USCI_I2C_UCRXIFG3: break; // Vector 10: RXIFG3

case USCI_I2C_UCTXIFG3: break; // Vector 14: TXIFG3

case USCI_I2C_UCRXIFG2: break; // Vector 16: RXIFG2

case USCI_I2C_UCTXIFG2: break; // Vector 18: TXIFG2

case USCI_I2C_UCRXIFG1: break; // Vector 20: RXIFG1

case USCI_I2C_UCTXIFG1: break; // Vector 22: TXIFG1

case USCI_I2C_UCRXIFG0: break; // Vector 24: RXIFG0

case USCI_I2C_UCTXIFG0:

UCB0TXBUF = TXData++;

break; // Vector 26: TXIFG0

case USCI_I2C_UCBCNTIFG: break; // Vector 28: BCNTIFG

case USCI_I2C_UCCLTOIFG: break; // Vector 30: clock low timeout

case USCI_I2C_UCBIT9IFG: break; // Vector 32: 9th bit

default: break;

}

}

赞(0)
未经允许不得转载:TI中文支持网 » I2C从机问题
分享到: 更多 (0)