어떤 i2c 칩이랑 avr이랑 통신하려니 안되서 ti 칩으로 바꾸고 나니 잘되는데 -_-
이제야 와서 이유를 찾아보게 되는데..
TI 칩에서 I2C로 Alternative Function을 사용하게 되면 open drain으로 설정되는데,
아마도 AVR atmel 은 pull-up이 되면서 모종의 문제가 발생하는 듯하다.
[링크 : http://cooa.tistory.com/entry/20030676476]
이제야 와서 이유를 찾아보게 되는데..
TI 칩에서 I2C로 Alternative Function을 사용하게 되면 open drain으로 설정되는데,
아마도 AVR atmel 은 pull-up이 되면서 모종의 문제가 발생하는 듯하다.
When using the I2C module, in addition to configuring the pin to open drain, the GPIO Alternate Function Select (GPIOAFSEL) register bits for the I2C clock and data pins should be set to 1 (see examples in “Initialization and Configuration” on page 185). |
15.2 Functional Description Each I2C module is comprised of both master and slave functions which are implemented as separate peripherals. For proper operation, the SDA and SCL pins must be connected to bi-directional open-drain pads. A typical I2C bus configuration is shown in Figure 15-2 on page 399. See “Inter-Integrated Circuit (I2C) Interface” on page 546 for I2C timing diagrams. |
[링크 : http://cooa.tistory.com/entry/20030676476]
'embeded > Cortex-M3 Ti' 카테고리의 다른 글
LM3S 내장 온도센서 계산하기(internal temperature sensor) (0) | 2012.06.28 |
---|---|
uart 인터럽트 / 폴링 충돌 (0) | 2012.06.18 |
TI stellarisware / driverlib 기본설정 (uart예제) (4) | 2012.02.05 |
Cortex-M3 인터럽트 관련 문서 (0) | 2012.01.31 |
Cortex-M3 예제소스 (0) | 2012.01.27 |