Описание протокола обмена SSI-интерфейса
В режиме ожидания, т.е. когда энкодер не опрашивается, сигнал на проводе "Clock+" (относительно "Clock+") положительный (High). С первым спадом сигнала с High на Low данные в датчике "замораживаются", т.е. энкодер подготавливается к передаче. С последующим фронтом сигнала (с Low на High) начинается передача данных, причем старшим битом (разрядом) вперед. Для надежного приема информации (учитывая емкостные задержки в линии связи) желательно, чтобы мастер (процессор) считывал бит с последующим спадом сигнала с High на Low. Таким образом, последовательность действий мастера следующая (на примере приема первых двух бит информации):
1. на провод "Clock+" подать уровень Low.
2. задержка // для обеспечения необходимой частоты такта (100kHz-1mHz).
3. на провод "Clock+" подать уровень High.
3. задержка //
4. на провод "Clock+" подать уровень Low.
5. опросить провод Data (Low или High?), записать первый бит информации.
6. задержка //
7. на провод "Clock+" подать уровень High.
8. задержка //
9. на провод "Clock+" подать уровень Low.
10. опросить провод Data (Low или High?), записать второй бит информации.
и т.д. начиная с пункта 6.
Для опроса сенсора мастеру необходимо генерировать тактов на один больше чем разрешение датчика, т.е. для случая разрешения энкодера 24 бита надо подать 24+1 = 25 тактов.
Тактовая частота может составлять 100кгц - 1мгц. Время между тактовыми посылками должна составлять более 15мкс. После последнего переданного бита датчик передает Low-сигнал в течении около 15мкс, что для мастера может означать конец передачи данных. Таким образом, следующая тактовая посылка от мастера должна прийти по истечении этого (15мкс) времени. Если такт придет раньше, то датчик начнет повторять передачу данных с самого начала, т.е. старые, не актуализированные данные. Таким образом, можно использовать этот режим (передавая, например, 24+1 тактов вместо 12+1) для контроля достоверности переданных данных, сравнивая принятые данные между собой. Лишь по истечении 15мкс данные внутри датчика (в выходных сдвиговых регистрах) актуализируются.
Для связи мастера с датчиком на большом расстоянии и/или в условиях больших помех необходимо использовать Line Driver, например, типа 65176.
Перекодировка с Gray-code в Binary может осуществлятся, например, с помощью логических элементов "исключающее или"