Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Voprosy_Otvety_-8011-ПУ (3).doc
Скачиваний:
225
Добавлен:
30.01.2015
Размер:
889.86 Кб
Скачать

12. Интерфейс i2c.

1 Описание интерфейса i2c

Этот интерфейс был предложен фирмой Philips®, которая применила его для организации связи между микросхемами в своих телевизорах. I2C (аббревиатура слов Inter-Integrated Circuit), и представляет собой двунаправленную асинхронную шину с последовательной передачей данных. Физически шина I2C представляет собой две сигнальные линии, одна из которых (SCL) предназначена для передачи тактового сигнала, а вторая (SDA) для обмена данными. Для управления линиями применяются выходные каскады с открытым коллектором, поэтому линии шины должны быть подтянуты к источнику питания +5 В через резисторы сопротивлением 1...10 кОм, в зависимости от физической длины линий и скорости передачи данных. Длина соединительных линий в стандартном режиме может достигать 2-х метров, скорость передачи данных – 100 кбит/с.

Все абоненты шины делятся на два класса – "Master" и "Slave". Устройство "Master" генерирует тактовый сигнал (SCL) и, как следствие, является ведущим. Оно может самостоятельно выходить на шину и адресовать любое "Slave"-устройство с целью передачи или приёма информации. Все "Slave"-устройства "слушают" шину на предмет обнаружения собственного адреса и, распознав его, выполняют предписываемую операцию. Кроме того, возможен так называемый "MultiMaster"-режим, когда на шине установлено несколько "Master"-абонентов, которые либо совместно разделяют общие "Slave"-устройства, либо попеременно являются то "Master"-устройствами, когда сами инициируют обмен информацией, то "Slave", когда находятся в режиме ожидания обращения от другого "Master"-устройства. Режим "MultiMaster" требует арбитража и распознавания конфликтов. Естественно, он сложнее в реализации (имеется ввиду программная реализация) и, как следствие, реже используется в реальных изделиях.

В начальный момент времени – в режиме ожидания – обе лини SCL и SDA находятся в состоянии лог. 1 (транзистор выходного каскада с открытым коллектором закрыт). В режиме передачи (рисунок 1) бит данных SDA стробируется положительным импульсом SCL. Смена информации на линии SDA производится при нулевом состоянии линии SCL. "Slave"-устройство может "придерживать" линию SCL в нулевом состоянии, например, на время обработки очередного принятого байта, при этом "Master"-устройство обязано дождаться освобождения линии SCL, прежде чем продолжать передачу информации. 

Рисунок 1 – Диаграмма процесса передачи данных по шине I2C

Для синхронизации пакетов шины I2C различают два условия – "START" и "STOP", ограничивающие начало и конец информационного пакета (рисунок 2). Для кодирования этих условий используется изменение состояния линии SDA при единичном состоянии линии SCL, что недопустимо при передаче данных. "START"-условие образуется при отрицательном перепаде линии SDA, когда линия SCL находится в единичном состоянии, и наоборот, "STOP"-условие образуется при положительном перепаде линии SDA при единичном состоянии линии SCL. 

Рисунок 2 – Диаграмма "START" / "STOP" условий шины I2C

Передача данных начинается по первому положительному импульсу на линии SCL, которым стробируется старший бит первого информационного байта. Каждый информационный байт (8 битов) содержит 9 тактовых периодов линии SCL. В девятом такте устройство-получатель выдаёт подтверждение (ACK) – отрицательный импульс, свидетельствующий о "взаимопонимании" передатчика и получателя. Следует отметить, что любой абонент шины, как "Master", так и "Slave" может в разные моменты времени быть как передатчиком, так и получателем и в соответствии с режимом обязан либо принимать, либо выдавать сигнал ACK, отсутствие которого интерпретируется как ошибка.

Чтобы начать операцию обмена, устройство "Master" выдаёт на шину "START"-условие, за которым следует байт с адресом "Slave"-устройства (рисунок 3), состоящий из семибитового адреса устройства (биты 1...7) и однобитового флага операции – "R/W" (бит 0), определяющего направление обмена, причём 0 означает передачу от "Master" к "Slave" (рисунок 3а), а 1 – чтение из "Slave" (рисунок 3б). Все биты по шине I2C передаются в порядке старший-младший, то есть первым передаётся 7-ой бит, последним 0-ой. За адресом могут следовать один или более информационных байтов (в направлении, определённом флагом R/W), биты которых стробируются сигналом SCL из "Master"-устройства.

При совершении операции чтения "Master" абонент должен сопровождать прочитанный байт сигналом ACK, если необходимо прочитать следующий байт, и не выдавать сигнал ACK, если собирается закончить чтение пакета (см. рисунок 3б).

Допускается многократное возобновление "Slave"-адреса в одном цикле передачи, то есть передача повторного "START"-условия без предварительного "STOP"-условия (рисунок 3в). 

Рисунок 3 – Формат операций чтения/записи

Необходимо отметить некоторые особенности микросхем памяти, работающих по интерфейсу I2C, и процедур обмена данными с ними. Во-первых, энергонезависимая память данных этих микросхем разбита на страницы памяти, поэтому при записи байта вначале происходит копирование всей страницы во внутреннюю оперативную память микросхемы, где производится изменение нужной ячейки. После этого, производится стирание старой страницы и запись на её место новой. Ещё одной особенностью является то, что старшие четыре бита адреса "Slave" всегда должны быть равны 1010. Это требование регламентировано самой фирмой Philips.

Теперь рассмотрим процедуры "общения" ведущего с микросхемой памяти. Прежде всего, он обязан сформировать на шине условие "START", вслед за которым послать байт с адресом ведомого и установленным признаком записи. Получив подтверждение приёма, ведущий продолжает передачу, посылая один или два байта адреса (зависит от ёмкости микросхемы) ячейки памяти. Приём каждого из них должен быть подтверждён "Slave"-устройством. В отличие от привычного программистам принятого в IBM PC порядка первым в данном случае передаётся байт со старшими разрядами адреса.

Дальнейшие действия зависят от того, намерен ли ведущий читать данные, хранящиеся в массиве памяти ведомого, или записывать их туда. Для записи одного или нескольких байтов их достаточно передать вслед за адресом. Первый попадёт в заданную ячейку, после чего внутренний контроллер микросхемы памяти автоматически инкрементирует адрес. Поэтому повторять его передачу не требуется. Следующий байт будет направлен в следующую ячейку и так далее до верхней границы страницы записи (в соответствующем числе младших разрядов адреса ячейки – все единицы), после чего заполнение страницы продолжится с нижней границы (в младших разрядах – все нули). Число байт данных, передаваемых в одном сеансе, не ограничено, но сохранятся лишь последние из них в количестве, не превышающем длины страницы.

Страничная запись значительно сокращает время, требуемое для перезаписи всего массива памяти или большей его части, но кроме неё иногда предусматривается и мультибайтная запись, отличие которой состоит в том, что адреса последовательно записываемых ячеек могут находиться на смежных страницах, пересекая их границу.

В любом случае после передачи и подтверждения приёма всех данных для программирования ведущий подаёт команду "STOP", запускающую в микросхеме внутренний автомат записи. Время записи здесь довольно большое – около 10 мс. Если данные переданы в мультибайтном режиме и находятся на разных страницах, продолжительность записи удваивается – автомат программирует две страницы.

До окончания процедуры программирования микросхема памяти не реагирует ни на какие внешние сигналы и в течение этого времени на повторные обращения ведущего по её адресу не откликается. Этим пользуются для определения момента завершения программирования.

Перед чтением данных не требуется обязательно указывать адрес ячейки. Если ведущий обращается к микросхеме памяти, установив в младшем бите байта адреса "Slave" признак чтения, в ответ ему будет передан байт из ячейки, следующей за той, с которой выполнялась последняя операция записи или чтения, после чего счётчик адреса будет автоматически инкрементирован. Продолжая посылать импульсы SCL, ведущий может последовательно и неоднократно прочитать весь массив данных. Возврата к началу страницы на её границе при чтении не происходит, а за адресом последней ячейки всего массива следует нулевой. Сигнал окончания чтения – отсутствие подтверждения ведущим приёма последнего или единственного байта данных и следующая за этим команда "STOP".

При необходимости адрес читаемой ячейки задают в явном виде следующим образом (см. рисунок 3в). Прежде всего, ведущий обращается к микросхеме памяти с признаком записи и посылает ему один или два байта адреса ячейки. Получив подтверждение, он немедленно посылает новую команду "START", а за ней – адрес "Slave" с признаком чтения и выполняет описанную выше процедуру. Первым ему будет передан байт из ячейки с указанным адресом.

Все вышеописанные процедуры обмена данными относятся и к микросхемам часов реального времени, за исключением того, что некоторые ячейки памяти у них представляют собой регистры счётчиков даты времени и, соответственно, изменяются самой микросхемой, хотя ничто не запрещает изменять их и ведущему (так производится установка времени). 

Соседние файлы в предмете Интерфейсы Периферийных Устройств