Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

Нужен совет по I2C slave в AVR Mega 8. Портит последний байт при приеме ... (+)

Отправлено Ivax 02 февраля 2007 г. 06:56


Всё делал по апноте AVR311. Тактовая передатчика 100 кГц. При чтении последний байт в посылке искажен. Если в посылку добавить 1 байт то будет портиться он и т.д. Ошибка возникает примерно в 10% случаев.

Мега работает на 4 МГц. В апноте написано что тактовая МК должна быть минимум в 16 раз выше скорости передачи по I2C, т.е. в данном случае 1,6 МГц. Или я неправильно понял?

Если у Меги тактовая 2 МГц то вообще ничего принять не удается. При 4-х ошибки, только при 8-ми всё без ошибок. Почему так?

Программную реализацию мастера проверял анализатором I2C в эмуляторе Keil-а. Временные параметры протокола выдержанны полностью. Память I2C на той-же шине читается-пишется без ошибок. В чем может быть причина?

Откуда мега знает что байт последний если у неё приемник аппаратный?

Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
введите число 90:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru