Самодельный логический анализатор. Доработка логического анализатора из китая. Вид печатной платы и расположение компонентов

Жаропонижающие средства для детей назначаются педиатром. Но бывают ситуации неотложной помощи при лихорадке, когда ребенку нужно дать лекарство немедленно. Тогда родители берут на себя ответственность и применяют жаропонижающие препараты. Что разрешено давать детям грудного возраста? Чем можно сбить температуру у детей постарше? Какие лекарства самые безопасные?

Что такое логический анализатор? Это такой прибор… для логического анализа))) Сразу приходит на ум фильм с Робертом Де Ниро

Зачем я его купил? Ну конечно же занимать логическим анализом))). А точнее анализом логических уровней разных микроконтроллеров и периферии к ним. То что принято называть реверс инжинирингом.

Недавно разбирался с двумя ультразвуковыми датчиками DYP-ME007Y, . И, когда в очередной раз захотелось посмотреть, какие сигналы бегают от датчика к микроконтроллеру и обратно, вспомнил о таком чудном приборе. И тут подвернулся ОН по цене менее $6.




На входе анализатора стоят токоограничивающие резисторы 100 Ом, подтягивающие к земле резисторы 100 КОм и конденсаторы 5 пФ. Все честно, как в описании.

Самое вкусное в данном анализаторе это то, что подходит .
Доступны версии для OSX, Linux и Windows на 32 и 64 бита.
Saleae Logic 1.2.3 под Windows 7 заработал с пол пинка, софт запустился, железо опозналось, не смотря на надпись версии «Beta».

Интересные плюшки в программе Saleae Logic

Триггер срабатывания записи логической последовательности на каждый канал

  • На изменения логического уровня в «0»
  • На изменение логического уровня в «1»

  • На положительный импульс заданной длительности
  • На отрицательный импульс заданной длительности
Подсчет статистических показаний по текущему измерению

Декодирования протоколов: Async Serial, I2C, SPI, Hide, 1-Wire, Atmel SWI, BISS C, CAN, DMX-512, HD44780, HDLC, HGMI CEC, I2S/ PCM, JTAC, LIN, MDIO, Manchester, Midi, Modbus, PS/2 Keyboard/Mouse, SMBus, SWD, Simple Parallel, UNI/O, USB LS и FS

Ведение журнала по декодируемому протоколу

Позанимаемся логическим анализом.

Для начала разбираюсь с ультразвуковыми датчиками, о которых писал в начале обзора.

Если один работает точно по даташиту: короткий импульс на «триггер» запускает ультразвуковой импульс и по длительности эхо измеряется расстояние. То второй и третий (с мигающим светодиодом) примерно раз в 100мс без каких либо внешних пинков сам мерит расстояние и посылает его на скорости 9600 в виде четырех байт (включая контрольную сумму). Программа Saleae Logic позволяет включить декодирование сигнала последовательной шины в последовательность байт. Датчики второго типа отлично работают с отключенным выводом «TRIG», хотя может и ждут какой нибудь команды на этом входе, но сие даже волшебный приборчик не покажет.

Далее захотелось посмотреть ШИМ сигнал Aтмеги 168? Включил все шесть каналов поддерживающих PWM на разный уровень и с удивлением обнаружил, что частота двух каналов ШИМ отличается от 4-х других. Задействованы разные таймеры?



Далее посмотрел работу шины I2C. И опять софт нормально справился с декодированием.Можно видеть пакеты записи в регистры при работе

Подключил ленту с - анализатор нормально проглотил 800КГц и успешно расшифровал протокол DFX-512

RF-приемник на 315МГц, подключенный напрямую к анализатору, получил сигнал с , и выдал манчестреский код. После подбора скорости манчестреский код превращается умной программкой в последовательность байт.

Интересно, а как с точностью измерения временных интервалов? Точного генератора импульсов у меня под рукой не оказалось, но Ардуиновская tone(1000) на 1000Гц


и tone(20000) на 20КГц дают довольно точный результат.

Небольшой итог

Логический анализатор очень нужная и полезная вещь для тех, кто занимается раскапыванием китайской периферии к микроконтроллерам (Назовем красиво - реверс инжинирингом)
Из достоинств данной железки хочу отметить:
  • Привлекательную цену
  • Совместимость с довольно удобным софтом Saleae Logic
  • Защита на входе в виде шинного формирователя LVC245A
  • Малые габариты
Явных недостатков у этой железки для себя не нашел. Жаль, что я не приобрел логический анализатор раньше -сколько времени бы я сэкономил во многих проектах.

Сейчас стоит задача анализа логических уровней на 12В, давно хотел разобраться с датчиками ABS своего авто. Думаю, что резисторный делитель и 5-ти вольтовый стабилитрон на каждом входе будет в самый раз.

В данной статье представлен простой логический анализатор работающий с оболочками USBee v1.1.57 и Logic v1.1.15. Собран на микросхеме распространенной микросхеме CY7C68013A фирмы Cypress. У меня имелась готовая плата с этой микросхемой заказанная с сайта Aliexpress. Вот такой у нее вид:

Хотел на ней сделать LPT порт, но потом надобность в нем пропала и так она валялась не востребованная. Понадобился мне простой логический анализатор. Решено было сделать на этой плате. На просторах интернета много схем на этой микросхеме. Требовалось добавить буфер для передачи данных, сделать защиту по входу и возможность выбора с какой оболочкой работать. Плата расширения одевается сверху основной платы. Скажу сразу, что схема, плата, прошивки и все необходимое для работы с данным логическим анализатором находится внизу статьи. В качестве буфера использовалась микросхема 74LVC4245 , можно применить 74LVC8T245A они полностью идентичны. Защитную функцию по входу выполняют диодные сборки BAV99. И так родилась такая схема:


Джампером J1 выбираем направление передачи данных. В замкнутом состоянии на прием данных, в разомкнутом на передачу. Есть такая оболочка как USBee AX Test Pod . Она содержит много тестовых утилит при помощи нее можно протестировать работу собранного устройства. Одна из возможностей это генерировать на выводах XP3 разные частоты. Правда самому задавать их нельзя. Выводится сразу 8 разных частот. Также можно устанавливать в 0 или 1 выходы и много других тестов. Джампером XP5 выбираем с какой оболочкой будем работать USBee v1.1.57 или Logic v1.1.15 . В U2 и U3 соответственно загружается прошивка для разных оболочек. Джампер XP4 это защита от записи. Нужен будет при старте оболочки от Logic. Джампером J2 задаем напряжение входных уровней. Если он замкнут то входной уровень сигнала должен быть 3.3 V. Так же предусмотрена возможность установить уровень сигнала такой каким напряжение питается диагностируемое устройство но не больше 5V. Для этого размыкаем J2 и напряжение питания диагностируемой платы подаем на 10 вывод XP3. Так же не забываем соединить между собой общий провод анализатора с диагностируемой платой. Для начала нам нужно доработать основную плату т.е удалить микросхему памяти 24C128.

У моей платы также не было соединения GND USB разъема и GND CY7C68013A пришлось соединить проводком.


Больше никаких изменений делать не нужно.

Теперь изготавливаем нашу платку размером 41мм х 58мм. В итоге получаем такой результат:



Соединяем две платы:



Для начала работы нам нужно прошить микросхемы памяти. Для этого устанавливаем утилиту от Cypress CySuiteUSB_3_4_7_B204 . Убираем с платы джампер XP5 и подключаем плату к ПК, в диспетчере устройств появится неизвестное устройство.


Устанавливаем драйвера из файла Driver_Cypress_win7 win8. Указываем диспетчеру, что искать драйвера в этой папке. Система сама установит необходимый драйвер. Появится новое устройство в контроллерах USB:


Запускаем установленную программку Control Center . Перед нами откроется окно, где в верху должно быть наше устройство.

Выбираем вкладку Option затем EZ-USB Interface:

Откроется следующее окно:


Ничего здесь не меняем. Нам нужна только кнопка S EEPROM. Джампером XP5 выбираем одну их микросхем памяти. Нажимаем S EEPROM и указываем где хранится наша прошивка. Выбираем прошивку в зависимости от типа памяти и нажимаем "Открыть". Цифры в конце названия прошивки указывают для какого типа памяти прошивка. Для 24C01 нужно выбирать USBeeAX_01, а для 24C02 USBeeAX_01.


Пойдет процесс заливки информации. При удачной прошивке должно быть сообщение как на скриншоте. Кол-во байт может отличаться в зависимости от выбранной прошивке.


Нажимаем кнопку сброс на плате и видим в диспетчере устройств новое неопознанное устройство. Устанавливаем драйвера. В автоматическом режиме драйвера не установятся. В ручном режиме указываем, что установить с диска и выбираем драйвер из папки Driver Cypress win7_win8. У меня на Windows 8.1 заработало с драйвером EZ-USB FX1 No EEPROM (3.4.5.000).

Хоть и изредка, но возникает нужда отследить что происходит на каких-то логических линиях, причем синхронно на 4-8. Давно хотел заиметь для этих целей логический анализатор (дальше - ЛА) и наконец созрел.
Коротко для нетерпеливых - брать можно. Полностью соответствует заявленным характеристикам, софт вполне юзабельный. Подробнее - под катом:)

Что такое логический анализатор и для чего он нужен

Если коротко, то это что-то вроде очень грубого многоканального осциллографа. Очень грубого - он показывает лишь два уровня, 0 и 1, то есть превысил ли наблюдаемый сигнал заданный уровень или нет. Поэтому он и называется логическим, его предназначение - наблюдать логические сигналы, то есть логические нули и единицы.
Это бывает нужным, например, при отладке какого-то интерфейса с несколькими линиями - работа с памятью, синхронное управление чем-то, многопроводные интерфейсы и т.п. Его используют так же при реверс-инжиниринге, когда нужно изучить работу какого-то устройства, определить используемый протокол связи и даже получить дамп данных, передаваемых, например, по синхронному UART.
Многие ЛА кроме непосредственно записи сигналов могут их декодировать по определенным протоколам, хотя это и не является обязательным свойством ЛА. Особо навороченные могут даже с достаточной уверенностью автоматически определить используемый протокол, но это уже зависит от софта, прилагаемого к ЛА.

Доставка

Дошел просто мгновенно - 29 марта я заказал, а 11 апреля он уже лежал у меня в отделении. Шел обычной почтой, упакован был в стандартный желтый пакет с пупыркой. Ничего экстраординарного:)

Характеристики со страницы продавца

Особенности:
- маленький и легкий
- максимальная частота сэмплов: 100MHz на 3 каналах, 50MHz на 6 каналах, 32MHz на 9 каналах, 16MHz на 16 каналах
- большой объем сохраняемых сэмплов, поддержка сжатия
- встроенный ШИМ-генератор
- совместим с USB2.0/3.0
- мощный и легкий в использовании софт
- поддержка автоматического обновления онлайн
Характеристики:
- число каналов: 16
- максимальная частота сэмплирования: 100MHz
- ширина полосы измерения: 20MHz
- минимальная ширина захватываемого импульса: 20ns
- максимальный размер сохраняемых сэмплов: 10G/канал
- допустимое входного напряжение: -50V / +50V
- входное сопротивление и емкость: 220KΩ, 12pF
- настраиваемый уровень триггера: -4V ~ +4V, шаг: 0.01V
- количество каналов ШИМ-генератора: 2
- диапазон частот ШИМ: 0.1 ~ 10MHz
- шаг настройки частоты ШИМ-генератора: 10ns
- шаг настройки ширины импульса ШИМ-генератора: 10ns
- выходное напряжение ШИМ-генератора: +3.3V
- выходное сопротивление ШИМ-генератора: 50Ω
- потребление в режиме ожидания: 100mA
- максимальный потребляемый ток: 150mA
- размеры: 95mm * 55mm * 23mm
- поддерживаемые операционные системы: Windows XP, Vista, Windows 7/8/10(32/64bit)
- поддерживаемые стандартные протоколы: UART/RS-232/485, I2C, SPI, CAN, DMX512, HDMI CEC, I2S/PCM, JTAG, LIN, Manchester, Modbus, 1-Wire, UNI/O, SDIO, SMBus, USB1.1, PS/2, NEC InfraRed, Parallel, и т.д.…

Комплектация

Комплект состоял из двух пакетов - в одном был кабель USB, в другом сам анализатор со всеми причиндалами:

Кабель на вид очень неплох, толстый, но довольно мягкий. Оценить сечение проводов питания в нем мне нечем, да это и неважно при заявленном потреблении анализатора. А вот его мягкость - это большой плюс при работе с такой небольшой и легкой коробочкой.
Среди причиндалов было: сам анализатор, три гребенки по девять проводов разного цвета, две гребенки по два провода, клипсы 20 штук, диск с программой и бумажка с адресом откуда качать свежий софт:


Вот бумажка покрупнее:

Сам анализатор выполнен в симпатичном корпусе вполне оригинального дизайна (по сравнению с набившими оскомину квадратными коробками, в которые китайцы лепят все что могут). Хотя кажется у Гаинты (Gainta) я видел среди типовых корпусов такой… Тем не менее смотрится очень хорошо. Сделано все очень аккуратно, нигде нет лишних зазоров, ничего не перекошено:)
На лицевом шильдике обозначено название модели, приведены краткие характеристики и разрисовано назначение пинов входного разъема. Кроме того есть индикатор, показывающий статус анализатора - в простое он плавно загорается и гаснет, во время сэмплирования часто мигает.
На одном из торцов входной разъем на 20 контактов - 16 каналов, две земли и два выхода ШИМ-генератора. На другом торце - USB-разъем:





В комплекте идут три гребенки по 9 проводов и две по два провода. Если с двухпроводными еще можно придумать что-то - например, одна для земли, вторая для двух каналов или для ШИМ-генератора, то зачем ТРИ большие гребенки - непонятно… Не иначе, одна из них запасная:)

При подключении двух девятиконтактных гребенок мы получаем все 16 каналов и две земли. Длина проводов на всех гребенках - 20 см, все провода оканчиваются изолированными термоусадкой «мамами» для подключения клипс. На каждой гребенке один провод имеет белую термоусадку - предполагается, что это земля, чтобы труднее было перепутать, остальные с черной термоусадкой:

Клипс - ровно 20 штук. То есть можно ими подключить все 20 контактов входного разъема - 16 каналов, 2 земли и 2 ШИМ-генератора. Вряд ли такое когда-то понадобится, но за нежадность китайцам плюс:) Цвета клипс особым разнообразием не страдают, в отличии от проводов:


С другой стороны, если проявлять минимальную внимательность, то можно и не перепутать ничего, глядя не только на клипсы, но и на провода, подключенные к ним.
Сзади у клипс торчат обычные четырехгранные штырьки как на IDC-разъемах:


«Мамы» проводов одеваются на эти штырьки довольно туго и сами соскакивать не проявляют желания, соединение довольно надежное.
Устройство клипс элементарное:




Никаких фиксаторов или защелок, задняя часть просто стягивается, а внутренняя пластина вынимается после поворота на 90 градусов. Штырек просто припаян, что не может не радовать в плане ремонтопригодности:)
Для подключения к проводу нужно надавить на заднюю часть, из носика выходит и раскрывается миниатюрный зажимчик. Задняя часть отпускается и под действием пружины зажимчик входит обратно, одновременно закрываясь:




Держит провод уверенно, как достаточно толстый, около 1.5мм, так и тоненький, где-то 0.3мм:




В целом качеством эти клипсы не блещут, но вполне работоспособны в большинстве случаев.

Работа анализатора, софт

Предварительно сразу нужно оговорить один момент: этот анализатор не имеет собственной памяти, все сэмплы сразу же передаются на компьютер, где и сохраняются. Правда, в характеристиках имеется упоминание о сжатии, так что, скорее всего, он не передает тупо 100 мегабит на канал при частоте сэмплирования 100 МГц. Тем не менее, при высоких частотах он очень требователен к качеству канала USB. В идеале корневой хаб, к которому подключен анализатор, не должен обслуживать никаких других клиентов. У меня, например, он заработал на полной скорости только в разъеме на передней панели компа. А на нетбуке он так и не смог обеспечить 50 МГц на 6 каналов, хотя на 5 каналов уже работал, и 100 МГц на три канала обеспечивал.

Итак, софт. Изначально я не обратил внимание на бумажку, где был адрес сайта с софтом, поэтому достал из закромов внешний DVD и честно попытался поставить программу с него. Программа поставилась, но вот драйвера не захотели вставать (Windows XP). Поиском в инете вышел на этот сайт, указанный в бумажке, и скачал оттуда чуть более свежую версию программы. Хотя драйвера в ней были вроде бы такими же, но из новой версии они встали нормально и анализатор ожил:)

Интерфейс программы на первый взгляд очень простой (да и на второй тоже, если честно). Сначала даже непонятно каким образом вообще можно делать в ней что-то полезное:) Но по мере углубления уважение к нему начинает расти:) В целом у меня сложилось такое впечатление от программы: совершенно ненавязчива, ничего лишнего, но вполне достаточна для большинства задач. Есть и мелкие недочеты, конечно, но они не сильно портят впечатление.
Вот так выглядит окно программы:


Быстрыми кликами можно настроить частоту сэмплирования и глубину (количество) сохраняемых сэмплов:


С выбором больших частот сэмплирования автоматически будет ограничиваться и число доступных каналов.
В самих каналах можно выбрать для каждого из них его имя, расположение, размер по вертикали. Для одного из каналов можно установить условие триггера - по фронту, по спаду, по высокому уровню, по низкому уровню или без триггера. Если триггер до этого был установлен на другом канале, он там сбросится, то есть триггер возможно установить на любом канале, но только на одном.
В общих настройках можно убрать лишние каналы и установить граничное напряжение, относительно которого будут считаться нули и единицы:

Под рукой у меня была платка, в которой можно было обнаружить лишь SPI и USB, вот их я и решил посмотреть. На скриншотах будут уже настроенные каналы, изначально же никаких данных на сигналах нет и каналы называются просто - Chanel 0, Chanel 1 и т.д.
Первые два канала я подключил к USB, 4 следующих - к SPI и запустил анализатор. Вот что получил в целом:


Это все 2 секунды наблюдения:) Теперь нужно подключить декодирование. Выбираем в списке нужный протокол:

И появляется окно настройки этого протокола.
Для USB:


Для SPI:


Как видно, у SPI довольно богатые настройки, позволяющие смотреть этот протокол во всех его проявлениях.
После назначения каналов сигналам протокола программа предлагает автоматически переименовать каналы по названиям сигналов, это у меня на скриншотах уже как раз и сделано. И теперь над графиками при достаточном увеличении будут показываться данные согласно протоколу. Например, вот один их фреймов USB:


Как видно, программа не просто показывает численные значения передаваемых байтов, но и их внутрипротокольное значение - CRC, SYNC, ACK и т.д. Правда, есть места, которые мы с программой не поняли, такое ощущение, что скорость USB резко замедляется в какие-то моменты:

А вот кусок обмена по SPI:

Вот так это будет выглядеть в файле:

Кроме того, можно сохранять не сэмплы, а данные декодированного протокола. Вот, например, кусок сохраненного обмена по CAN в моей машине (скриншотов, к сожалению, не делал):
Time [s],Packet,Type,Identifier,Control,Data,CRC,ACK 0.0002935s,0,DATA,0x0591,0x08,0x01 0x00 0x00 0x00 0x00 0x00 0x00 0x00,0x284A,ACK 0.0016248s,1,DATA,0x05D1,0x02,0x10 0x00,0x0249,ACK 0.0023359s,2,DATA,0x0635,0x03,0x00 0x00 0xFD,0x0D93,ACK 0.0033871s,3,DATA,0x0470,0x08,0x40 0x01 0x00 0x46 0x00 0x00 0x00 0x1F,0x5D2D,ACK 0.0046378s,4,DATA,0x0531,0x04,0x01 0x40 0xF0 0xB1,0x40D3,ACK 0.005489s,5,DATA,0x05C1,0x04,0x00 0x00 0x00 0x20,0x0AA2,ACK 0.0063502s,6,DATA,0x065F,0x08,0x01 0x5A 0x5A 0x5A 0x36 0x31 0x5A 0x43,0x3840,ACK 0.0075009s,7,DATA,0x0651,0x08,0x80 0x02 0x50 0xAF 0x38 0x57 0x00 0x00,0x50D4,ACK 0.0086621s,8,DATA,0x0621,0x08,0x20 0x2C 0x69 0x18 0x81 0x64 0xFD 0x00,0x4FE1,ACK 0.0233258s,9,DATA,0x0291,0x05,0x00 0x00 0x00 0x00 0x00,0x1DE1,ACK 0.0333432s,10,DATA,0x03E1,0x08,0x20 0x00 0x30 0x01 0xA2 0x00 0x84 0x00,0x50DB,ACK 0.0432946s,11,DATA,0x03C3,0x08,0xAB 0x00 0x00 0x00 0xA8 0xF0 0x00 0x64,0x0F7B,ACK 0.0444855s,12,DATA,0x040C,0x08,0x00 0x01 0x01 0x01 0x00 0x00 0x00 0x00,0x290F,ACK 0.053637s,13,DATA,0x0470,0x08,0x40 0x01 0x00 0x46 0x00 0x00 0x00 0x1F,0x5D2D,ACK 0.0548882s,14,DATA,0x0531,0x04,0x01 0x40 0x00 0x41,0x191A,ACK 0.0632503s,15,DATA,0x0291,0x05,0x00 0x00 0x00 0x00 0x00,0x1DE1,ACK 0.0666019s,16,DATA,0x0497,0x08,0x00 0x00 0x00 0x00 0x64 0x00 0x00 0x20,0x501A,ACK 0.0733737s,17,DATA,0x0151,0x04,0x00 0xE0 0xB0 0x50,0x5718,ACK 0.0833265s,18,DATA,0x02C1,0x06,0x00 0x00 0x00 0x00 0x06 0x00,0x5677,ACK 0.0843872s,19,DATA,0x0359,0x08,0xB8 0x01 0x00 0x00 0x00 0x2B 0x40 0x00,0x4875,ACK 0.0856485s,20,DATA,0x035B,0x08,0x08 0xB4 0x0C 0xB5 0x0B 0xFF 0x02 0x80,0x157E,ACK 0.0868492s,21,DATA,0x0369,0x08,0x3F 0x00 0x00 0x00 0x00 0x00 0x00 0x00,0x45C9,ACK 0.0881104s,22,DATA,0x0381,0x06,0x01 0x00 0x00 0x00 0x00 0x00,0x18D3,ACK 0.0892516s,23,DATA,0x0397,0x08,0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00,0x4293,ACK 0.0905824s,24,DATA,0x03B5,0x06,0x00 0x00 0x00 0x00 0x00 0x00,0x007C,ACK 0.0916936s,25,DATA,0x0457,0x03,0x01 0x40 0x00,0x6539,ACK 0.0925447s,26,DATA,0x04B9,0x06,0x00 0x00 0x00 0x00 0x00 0x00,0x11A3,ACK 0.0936154s,27,DATA,0x0400,0x08,0x0C 0x01 0x09 0x05 0xAC 0x00 0x00 0x00,0x3DDD,ACK

Что еще есть? при ведении курсора по графику канала автоматически показывается ширина текущего импульса, период, частота и заполнение (актуально для ШИМ). Можно вывести два или три маркера и таскать их по графику, при этом они будут притягиваться к ближайшим фронтам и спадам. Справа будет выводиться информация о точном времени маркера и временном промежутке между ними:


Тут маркеры стоят на началах фреймов USB, которые, как известно, с довольно высокой точностью следуют каждую миллисекунду, что анализатор и подтверждает. Или, скорее, подтверждает свою достаточно хорошую точность:)

ШИМ-генератор

Ну, тут все просто. Он есть, оба канала, все работает. Быстро включить-выключить каждый из каналов можно прямо в главном окне наверху, нажав на соответствующую надпись (PWM1 PWM2). Зеленая - активен, красная - отключен. Настройки генератора вызываются в отдельном окне:


Что еще про него сказать - не знаю даже:)

Внутренности

Построение, как я подозреваю, классическое - входное согласование, компараторы триггера, ПЛИС и контроллер с USB. Я вообще подозреваю, что это клон того же Saleae:)








Вторая сторона платы совершенно пуста.
Все очень аккуратно, никаких соплей, неотмытого флюса и т.п. Внутренности не нарушают гармонию внешности:)

Итог

Аппарат мне понравился. Все, что в нем заявлено - работает. Софт произвел очень приятное впечатление. Честно говоря, даже не ожидал от китайцев такой работы:) Есть и недостатки, но мелкие - хотелось бы, например, присваивать сигналам разные цвета. Но это уже скорее придирки.

В этой статье пойдет речь о логическом анализаторе — незаменимом инструменте для реверс-инжиниринга, да и вообще полезном в хозяйстве приборе. Для тех кто ни разу с подобным прибором не сталкивался скажу, что логический анализатор это что-то типа осциллографа, но у него много каналов и он может различать только два состояния сигнала: логический ноль и единицу. Используется оно в основном чтоб присосаться к какой-нибудь шине данных и считывать с неё то, что по ней передается, в компьютер. Ну а на компьютере работает специальный софт который эти данные отображает в дружественном для пользователя виде. Если бы программа просто показывала нам набор единиц и нулей растянутых во времени, то толку от этого было бы мало ибо анализ таких данных очень сложен и может взорвать моск даже опытному инженеру. Поэтому, все нормальные программы умеют декодировать протоколы типа 1-Wire, i2c, SPI, UART и так далее. Собранный мной анализатор поддерживает две популярные программы Saleae Logic и USBee Suite .

Сердцем девайса является контроллер CY7C68013A широко известный на просторах интернетов. Именно на нем народ клепает приборы вроде моего. К сожалению, у нас я не смог найти такой, пришлось покупать (13$) на Ebay небольшую отладочную платку с этим контроллером, а потом варварски его оттуда выковыривать. Кстати на той же плате есть почти все что нам потребуется для изготовления девайса (кроме буфера). Сама платка выглядит вот так:

Шаг выводов у контроллера очень мелкий, и если у вас не возникает желания «подковать блоху», то можно оставить контроллер на своем месте просто подпаяв к этой плате буфер. Но тут есть один момент об который я ломал голову почти целый день — этой на плате стоит не совсем та микросхема памяти. В первых нескольких байтах этой микросхемы должен быть записан идентификатор устройства и производителя (PID и VID). Как потом оказалось эта EEPROM память, может быть использована программой контроллера для каких-то своих целей. Прошивка предполагает, что к контроллеру подключена память 24lc02 ну а фактически китайцы туда присобачили 24lc128. Из-за разницы в адресации к ячейкам, прошивка не может записать (или прочитать?) что-то в какую-то ячейку памяти и девайс не стартует. Однако те самые первые байты с PID и VID пишутся/читаются правильно даже с микросхемой памяти большего объёма. Микросхема достаточно редкая (потому что старая) и я не нашел её не местном радиобазаре и втыкал всякие по очереди из тех что были в наличии. Успешно заработала 24lc04, а 24lc16 и всё что больше — работать правильно отказались. Эта проблема была только с софтом от Saleae, что же касается USBee, то там все работало без замены микросхемы. Кстати у контроллера CY7C68013A есть одна примечательная особенность: Он не имеет ни какой энергонезависимой памяти в которой хранится его прошивка. Она записывается в контроллер драйвером и остается в нем пока есть питание. Таким образом меняя VID и PID в микросхеме памяти, мы можем превратить девайс во что угодно 🙂 Теперь посмотрим из чего же сделан наш девайс:

А собственно ничего почти в нем и нет:

  • Сам контроллер CY7C68013A
  • Микросхема памяти
  • Буфер
  • Стабилизатор на 3.3 в

Ну и всякая типовая обвязка. Кстати на конденсаторах народ народ на форумах экономить не рекомендует, иначе самопроизвольные сбросы и прочие сюрпризы вам гарантированы. Отдельно стоит рассказать о назначении перемычек. Нафига нужна JP3 я пока не понял, но на всякий случай поставил, так как во многих подобных девайсах она есть. Без неё всё пока работает нормально. Перемычка JP1 управляет защитой от записи, её наличие разрешает запись чего-либо в микросхему. JP2 нужна для того чтоб временно отсоединять память от контроллера для её дальнейшей прошивки. Как это сделать сейчас разберемся. Кстати, прошить её можно обычным программатором для подобных микросхем, но для удобства лучше воспользоваться моим способом. Первым делом нужно скачать (и установить!) Cypress SuiteUSB 3.4, сделать это можно на официальном сайте или у меня . Затем необходимо снять перемычку JP2, а перемычку JP1 установить. После этого подключаем девайс и видим появилось новое устройство. После установки драйверов оно должно отображаться так:

Понятно, что контроллер не обнаружил микросхемы памяти и не понимает кто он из-за невозможности прочитать VID и PID. Когда контроллер находится в таком режиме, мы можем записать что-то в EEPROM память при помощи специальной утилиты которую мы установили ранее. Возвращаем перемычку JP2 на место при этом не отключая устройство! Теперь нужно запустить программу Usb control center и выбрать в списке слева наше устройство «Cypress EZ-USB FX2LP EEPROM missing «. Потом нужно в меню выбрать пункт Program FX2 -> Small EEPROM и в открывшемся окне выбрать тот файл содержимое которого нужно прошить в EEPROM. Если вы желаете использовать софт Saleae Logic , то нужно прошить туда вот . А если хочется юзать USBee Suite, то . Когда все успешно прошьётся, то внизу окна появится соответствующая надпись:

Если там ошибка, то не установлены перемычки JP1 и JP2. Теперь можно устанавливать софт и пробовать запустить анализатор. Софт Saleae Logic скачать можно на официальном сайте или , а USBee Suite или у меня . Установка ни каких проблем вызвать не должна, везде нажимаем «далее» и со всем соглашаемся 🙂 Особо активно я пока этот анализатор не использовал, поэтому о софте подробнейшего рассказа не будет, расскажу только базовые возможности этих двух софтин. Ну а начну с чего попроще: Saleae Logic. Софт умеет декодировать следующие протоколы:

  • DMX-512
  • I2S / PCM
  • Manchester
  • 1-Wire
  • Async Serial
  • Simple Parallel
  • UNI/O

Данные после декодирования можно выгрузить в текстовый файл или сохранить в сыром виде а потом анализировать. Например вот так выглядит обмен данными между термометром DS18B20 и контроллером:


А вот тут я шлю привет через :

Захват данных может начаться как в ручном режиме так и по триггеру. Достоинство этой программы в простоте и интуитивно понятном интерфейсе. А еще она не очень требовательна к ресурсам по сравнению со следующей программой USBee Suite . Сразу после запуска у нас появятся 8 цифровых каналов и один аналоговый, которого в нашей конструкции физически нет. Поэтому его можно отключив нажатием крестика около него. Ну или можно припаять АЦП и немного обвязки и он начнет работать. Но мне с моим нормальным осциллографом это нафиг не нужно и я не стал заморачиваться. Программа умеет понимать следующие протоколы

  • Sync Serial
  • Parallel bus
  • Async Serial
  • SMBus
  • 1-Wire

Самый главный плюс — оно понимает USB, пока он мне не нужен, но скоро буду раскуривать и вот тогда анализатор будет как раз кстати. Я попробовал снять те же самые данные что и выше, при помощи этой программы. Опять тот же самый 1-Wire термометр от Dallas semiconductor:

и опять те же данные отправляемые через :

Меня удивило то, что не смотря на всю свою крутость обе программы не умеют делать автодетект скорости UARTa. Что касается остальных протоколов, то до них еще не дошла очередь, но я обязательно их испытаю. Ни какого корпуса для девайса у меня нет, но возможно в ближайшем будущем он появится. Еще рекомендую купить цветных проводков, ведь каждому каналу в программах соответствует свой цвет и это очень удобно. Не лишними будут так же хваталки, которыми удобно присасываться почти к любому месте на плате:

Называются они «Test Hook Clip Probes» если кто будет искать в магазинах заморских. Продаются они сразу по 20 штук на DealExtreme. Предвидя вопросы на счёт платы, скажу сразу что она сделана обычным ЛУТом. Ничего ни где не отвалилось. Контроллер был припаян при помощи паяльника, матов и фена. Главное не торопиться. Ну а все остальные детальки очень большие и паяются феном или паяльником легко и непринужденно. Кстати, моя первая плата в Eagle, так что прошу не судить строго 🙂

Саму печатку можно скачать . Предложения и комментарии принимаются.

Логический анализатор - незаменимый помощник при отладке цифровой схемотехники. Давайте рассмотрим основные приёмы работы с логическим анализатором Saleae Logic Analyzer и его китайскими аналогами.

Для работы нам понадобится:

  • соединительные провода (рекомендую вот такой набор);
  • макетная плата (breadboard).

1 Технические характеристики логического анализатора Saleae logic analyzer

Логический анализатор - это инструмент для временного анализа цифровых сигналов. Это незаменимый, действительно незаменимый инструмент при отладке цифровой электроники. Оригинальные анализаторы от именитых производителей стоят больших денег. У наших китайских друзей можно купить такое устройство за копейки. Поэтому если у вас его ещё нет - обязательно приобретите. Возможности данного небольшого устройства весьма внушительны.

В таблице перечислены основные параметры логического анализатора, моей китайской копии анализатора фирмы Saleae .

2 Установка драйвера для логического анализатора Saleae

Для данного логического анализатора - китайской копии - к счастью, подходит драйвер от оригинала. Заходим на официальный сайт , скачиваем программу для своей операционной системы и устанавливаем её. Драйверы будут установлены вместе с программой. Кстати, обзор возможностей программы в виде инструкции на английском языке приложен в конце данной статьи.

Если у вас копия другой фирмы, например, USBee AX Pro, то с большой долей вероятности для него также подойдут драйверы от производителя анализатора-оригинала.

3 Примеры работы с логическим анализатором

Для первого эксперимента возьмём преобразователь USB-UART на микросхеме FTD1232. Подключим анализатор к порту USB. Выводы каналов с 1 по 6 подключим к выводам USB-UART преобразователя. По большому счёту, больше всего нас интересует только две линии - Rx и Tx, можно обойтись только ими. Преобразователь определился в системе как COM-порт. Запустим любую терминалку (вот, например, неплохая программа для работы с COM-портом) и подключимся к порту.


Подключение USB-UART конвертера на микросхеме FTD1232 к логическому анализатору

Запускаем программу Saleae Logic . Если драйверы для анализатора установлены корректно, в заголовке программы будет указано Connected - подключено. Допустим, мы не знаем на каком канале будет сигнал, а на каком нет, поэтому не будем выставлять триггер для начала захвата сигнала. Просто нажмём на стрелки большой зелёной кнопки Start (Старт) и выставим в поле Duration (Длительность), скажем, 10 секунд. Это время, в течение которого логический анализатор будет собирать приходящие по всем 8-ми каналам данные после нажатия кнопки «Старт». Запускаем захват и одновременно отправляем в COM-порт какое-нибудь сообщение. Через 10 секунд анализатор закончит сбор данных и выведет результат в поле просмотра сигналов. В данном случае сигнал будет лишь на одном канале, который присоединён к выводу Tx (передатчик) USB-UART преобразователя.


Для наглядности можно настроить декодер перехваченных данных. Для этого в правом столбце находим поле Analyzers , нажимаем иконку в виде плюса - «Добавить», указываем тип - Async Serial . Появится окно с выбором настроек. В первое поле вводим номер канала, на котором у вас данные. Остальное оставим как есть. После нажатия кнопки Save (Сохранить), над полем соответствующего канала появятся метки голубого цвета с отображением значений байтов, которые были перехвачены. Нажав на шестерёнку в данном дешифраторе, можно задать режим отображения значений - ASCII, HEX, BIN или DEC. Если вы передавали в COM-порт строку, выберите режим ASCII, и увидите тот текст, который был вами передан в порт.


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

Аналогичным образом подключим логический анализатор к преобразователю USB-RS485. Линии данных всего две, поэтому можно установить триггер срабатывания по фронту любого из каналов: сигнал в протоколе RS-485 дифференциальный и фронты импульсов появляются одновременно на каждом из каналов, но в противофазе.


Нажмём кнопку «Старт» в программе анализатора. С помощью нашей терминалки подключимся к USB-RS485 конвертеру и передадим какие-нибудь данные. По срабатыванию триггера программа начнёт собирать данные, по завершению выведет их на экран.


Программа Saleae Logic позволяет экспортировать сохранённые данные в виде изображений и текстовых данных, сохранять настройки программы, аннотации и декодеры каналов.

Последний пример в данном небольшом обзоре - захваченный кадр данных, переданный по последовательному протоколу SPI. В канале 2 виден сигнал выбора ведомого, в канале 0 - тактовые импульсы, а в канале 1 - собственно данные от ведущего устройства к ведомому.


Выводы

Логический анализатор может быть очень полезен при разработке и настройке всевозможных электронных устройств, при написании программного обеспечения, работающего в связке с железом, при работе с микроконтроллерами, ПЛИС и микропроцессорами, для анализа работы различных устройств и протоколов обмена данными, и для многих других применений. Кроме того, он портативен и не нуждается в отдельном питании.

Скачать инструкцию по работе с программой для логического анализатора Saleae

  • Скачать инструкцию по работе с программой для логического анализатора Saleae с Depositfiles.com
  • Скачать инструкцию по работе с программой для логического анализатора Saleae c File-upload.com
  • Скачать инструкцию по работе с программой для логического анализатора Saleae c Up-4ever.com
  • Скачать инструкцию по работе с программой для логического анализатора Saleae c Hitfile.com
Поддержите проект — поделитесь ссылкой, спасибо!
Читайте также
Рамблер почта (вход, настройка, работа с входящими) и ее место среди других сервисов бесплатных электронных ящиков Рамблер почта (вход, настройка, работа с входящими) и ее место среди других сервисов бесплатных электронных ящиков Полное толкование ошибок Полное толкование ошибок Как бесплатно защитить компьютер от вирусов без антивируса Защищен ли данный компьютер от вирусов Как бесплатно защитить компьютер от вирусов без антивируса Защищен ли данный компьютер от вирусов