реклама на сайте
подробности

 
 
> Twi в SAM7s128, он же I2C
Nikitoc
сообщение Sep 10 2009, 13:30
Сообщение #1


Местный
***

Группа: Validating
Сообщений: 207
Регистрация: 14-01-09
Из: Днепропетровск
Пользователь №: 43 367



Всем доброго времени суток! Я понимаю, что тема избитая, но перечитав с дюжину веток на этом и других форумах, я решения так и не нашел. Надеюсь на понимание уважаемых форумчан. Собственно не могу добиться хотя бы изменения состояния на линиях TWD и TWCK у at91sam7128. Привожу кусок кода который использую для инициализации интерфейса:

/* Function of definition I2C */
void I2C_INIT () {
pPIO -> PIO_PDR = pPIO -> PIO_PDR | 0x18; // disable PA3 PA4 I/O for using by I2C
pPIO -> PIO_PPUDR = 0xFFFFFFE7; // Отключаю pull-up резисторы везде кроме 3 и 4 линий
pPIO -> PIO_ASR = pPIO -> PIO_ASR | 0x18; // наверное необязательно, но указываю что линии 3 и 4 - это периферия А
pPIO -> PIO_MDER = pPIO -> PIO_MDER | 0x18; // линии 3 и 4 с открытым стоком
pP_M_C -> PMC_PCER = pP_M_C -> PMC_PCER | 0x200; // clock enable I2C
AT91C_BASE_TWI -> TWI_CR = AT91C_TWI_SWRST; // программный сброс
AT91C_BASE_TWI -> TWI_CWGR = 0x8383; // частота ~200kHz
AT91C_BASE_TWI -> TWI_MMR = AT91C_TWI_IADRSZ_1_BYTE | ((unsigned int) 0x42 << 16); // adress and size of internal adress
}
/********************************************************/

записи:

/********************************************************/
void I2C_WR (int intadress) {
int status;
AT91C_BASE_TWI -> TWI_IADR = intadress;
AT91C_BASE_TWI -> TWI_MMR &= 0xFFFFEFFF;
AT91C_BASE_TWI -> TWI_CR = AT91C_TWI_START | AT91C_TWI_MSEN | AT91C_TWI_STOP;


//* Set Data register for start transmission
AT91C_BASE_TWI -> TWI_THR = 0xAA; // !!!!!!!!! Здесь ничего не происходит!!!! Содержимое регистра THR и TXDATA не изменяются

status = AT91C_BASE_TWI -> TWI_THR; //..чтение этого регистра дает 0x00 !!!!
//* Wait end transmission
status = AT91C_BASE_TWI -> TWI_SR;
while (!(status & AT91C_TWI_TXCOMP)) {
status = AT91C_BASE_TWI -> TWI_SR;
}
}
///////////////////////////////////////////////////////////////////////////////
Если честно перепробовал кучу вариантов реализации, с учетом рекомендаций Atmel (на их сайте), уже голова кругом. Подскажите, где я делаю что-то неправильно?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
apic
сообщение Sep 10 2009, 20:52
Сообщение #2


Частый гость
**

Группа: Свой
Сообщений: 86
Регистрация: 18-06-05
Из: Москва
Пользователь №: 6 116



Нужно использовать прерывания TWI, тогда будет работать.
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Sep 10 2009, 20:58
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(apic @ Sep 11 2009, 00:52) *
Нужно использовать прерывания TWI, тогда будет работать.

Нет, не будет.
Go to the top of the page
 
+Quote Post
DmitryM
сообщение Sep 11 2009, 04:31
Сообщение #4


Знающий
****

Группа: Свой
Сообщений: 583
Регистрация: 7-06-06
Из: Таганрог
Пользователь №: 17 840



Цитата(aaarrr @ Sep 11 2009, 00:58) *
Нет, не будет.


Камень AT91SAM7S64. Периферия TLV320AIC20, LM8333, FM1073V23. Используется аппаратный TWI, прекрасно работает. Обработчик по прерываниям. Весьма странно, что бытует мнение о неработоспособном TWI в SAM'ах.
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Sep 11 2009, 11:40
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(DmitryM @ Sep 11 2009, 08:31) *
Камень AT91SAM7S64. Периферия TLV320AIC20, LM8333, FM1073V23. Используется аппаратный TWI, прекрасно работает. Обработчик по прерываниям.

Рад за вас, Вам повезло.

Цитата(DmitryM @ Sep 11 2009, 08:31) *
Весьма странно, что бытует мнение о неработоспособном TWI в SAM'ах.

А для тех, кому не так повезло, Атмел сочинил чудный документ, в котором, например, предлагается решать проблему зависания шины добавлением транзисторов, коммутирующих питание слейвов (стр.7), и убить себя об стену ничего не делать, если в системе есть слейвы, использующие clock stretching (стр.27-28).

И пусть каждый сам для себя решает, продолжать ли ему есть кактус использовать TWI, добавляя ненужные транзисторы и выбирая "подходящие" слейвы, или просто заменить драйвер на bit-bang.
Кстати, в линуксовом кернеле так и поступили.
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 9th August 2025 - 02:55
Рейтинг@Mail.ru


Страница сгенерированна за 0.01403 секунд с 7
ELECTRONIX ©2004-2016