|
|
  |
Как грамотно принять данные по I2C?, Без лишних циклов ожидания... |
|
|
|
Apr 8 2011, 15:38
|
Участник

Группа: Участник
Сообщений: 27
Регистрация: 5-05-10
Из: Гомель, Беларусь
Пользователь №: 57 090

|
Вопрос может и туповат, но для меня, как начинающего, актуален... Разжевывать не обязательно, можно просто поделиться ссылками на материал по теме. Проблема следующая: есть контроллер (STM8) с аппаратным IIC на борту. Также в проекте будет использоваться UART... И если с передачей все почти понятно (вкидываю данные в кольцевой буфер, а дальше парится аппаратура и обработчик IRQ), то с приемом у меня ступор... А именно: работаю с PCF8583, я конечно знаю, когда она мне что-то пришлет, мастер я всетаки, но шина довольно медленная, и тупо крутиться в цикле опроса флагов - терять время... С UART то же самое... Я спрашиваю, мне отвечают. Вопрос: Как это делается правильно? В ОС функция выглядит обычно как что-то типа Read(дескриптор устройства, *куда читать, количество байт, которые читать); как это реализуется? Ведь не могу же я вывалиться из функции не возвратив данные, а то, что к ее вызову они еще не готовы может быть легко... Вообще программу собирался реализовывать в виде событийной системы по примеру отсюда. Но как прикрутить грамотную работу с приемом данных разобраться не могу.
Сообщение отредактировал N1X - Apr 8 2011, 15:42
|
|
|
|
|
Apr 8 2011, 20:00
|
Участник

Группа: Участник
Сообщений: 27
Регистрация: 5-05-10
Из: Гомель, Беларусь
Пользователь №: 57 090

|
Ну про состояния я естественно понимаю... Но просто к примеру, нужно получить время из PCF8583, это где-то 3 байта на вскидку (здесь не суть). Итого я выставляю запрос на старт, закидываю в буфер адрес регистра, который будем читать, а после этого нужен еще и рестарт шины... Итого перед непосредственно чтением еще 3 операции...
Предположим мы попадаем в функцию приема, которая нам должна вернуть эти самые 3 байта, а их еще и в помине нет... Так вот как сделать так, чтобы проц не тупо циклился в ожидании, а выполнил еще пару полезных действий? (Дело не в том, что у меня критичное к времени приложение, я то подожду, просто хочу понять как это правильно делается...)
Я рассматривал кой-какие сырцы на sourceforge, но они были под msp430, который я не знаю, поэтому трудно судить что и зачем там делается... Да и опыта мало... STM8 я назвал просто для представления с чем имею дело, а так меня интересует именно общая схема реализации или ссылка на литературу... Своего опыта нет...
|
|
|
|
|
Apr 8 2011, 21:53
|
Гуру
     
Группа: Свой
Сообщений: 2 702
Регистрация: 14-07-06
Пользователь №: 18 823

|
Цитата(N1X @ Apr 8 2011, 18:38)  Но как прикрутить грамотную работу с приемом данных разобраться не могу. Альтернатива одному обработчику - два обработчика!  Вообще-то эти вещи протоколо-зависимые. Обычно автомат состояний управляет процессом. Типа так http://caxapa.ru/193312.htmlНу а лихие обработчики прерываний складывают принятое в линейные или циклические буферы. Добавлю, что типичный программистский прием - это выполнение функции, в которую передается указатель на структуру, в которой находится вся интересующая информация - что принято, что не принято, кто у принятого байта папа-мама и прочее. Затем структура разбирается на атомы или анализируется что-то нужное. Или функция возвращает, что все байты приняты, а что принято, ищется в другом месте. Да в конце концов вспомните, как это сделано в Windows! Да и книжки бывают полезны, на форумах не учат, а калечат!
--------------------
Уходя, оставьте свет...
|
|
|
|
|
Apr 10 2011, 08:45
|
Участник

Группа: Участник
Сообщений: 27
Регистрация: 5-05-10
Из: Гомель, Беларусь
Пользователь №: 57 090

|
Спасибо всем за информацию, буду переваривать  ЗЫ: а форум калечит только если его бездумно использовать...
Сообщение отредактировал N1X - Apr 10 2011, 08:46
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|