Блог посвящен радиоэлектронике, микроконтроллерам, платформе Arduino, а также частично программированию.
- суббота, 19 февраля 2011 г.
- Arduino: изучаем протокол 1-Wire и iButton
- Введение в 1-Wire
- Коротко
- Как это работает?
- Arduino, MK-90 и другие
- Страницы
- 16.04.2011
- Сеть 1-Wire в «полевых условиях»
- 12 комментариев:
- Как перестать бояться и полюбить 1-wire
- Физический уровень
- GPIO адаптер
- Канальный уровень
- Пассивный адаптер
- Аппаратные адаптеры
- Гальваническая развязка
- Эмуляторы адаптеров
- Сетевой уровень
- Низкоуровневая работа
- Высокоуровневая работа
- Драйверы ядра
- Доступ из JavaScript
- Полезные советы
- Сравнение с ModBus
- Выводы
- 📹 Видео
Видео:55. Знакомство с интерфейсом 1-wire (Урок 46. Теория)Скачать
суббота, 19 февраля 2011 г.
Arduino: изучаем протокол 1-Wire и iButton
Потёр площадку фломастером и становится видна заветная надпись:
iButton.com
00000F67CE41
1-Wire
0744 UB1 DS1990A #F5
Ага! 1-Wire!
Так что же это за интерфейс?
Это однопроводной интерфейс, разработан фирмой Dallas Semiconductor (ныне MAXIM) в конце 90-х годов.
Этот интерфейс интересен тем, что для двустороннего обмена требуется всего одна линия! (отсюда и название ?
Возвращаемся к нашему ключу ? На самой таблетке указан тип устройства и, похоже, уникальный номер микросхемы ?
DS1990A – это и есть название нашего устройства.
Смотрим варианты iButton-ов на сайте производителя
Наш ключ — это самая первая модель в списке ?
DS1990A — 64 Bit ID — уникальный серийный номер-ключ
Страничка этого ключика здесь, а здесь можно скачать датащит ?
Число после # определяет форм-фактор ключа – у меня F5.
Итак, наш ключ хранит 64 бита уникальной информации
Питается от 2.8V до 6.0V
К центральной контактной площадке подключается линия данных, а к боковой каёмке – землю.
Ключ может работать в диапазоне температур от -40°C до +85°C – впрочем, это нам не нужно ?
Величина подтягивающего резистора рекомендуется в 2.2k
Так… запомним ?
Каждый DS1990A прошивается уникальным 64-битным номером
первые 8 бит — номер серии устройства (01h)следующие 48 бит — уникальный серийный номер
последние 8 бит — CRC-код предыдущих 56 бит информации ?
(Cyclic redundancy code, CRC — циклический избыточный код) — способ цифровой идентификации некоторой последовательности данных, который заключается в вычислении контрольного значения её циклического избыточного кода.
Далее в датащите перечислены команды, которые понимает ключ:
33h — считать ROM — команда позволяет считать заветные 64-бита данных ключа
F0h — поиск ROM — т.к. к сети 1-wire может быть подключено несколько устройств данная команда используется для идентификации подключённых устройств.
55h — соответствие ROM / CCh — пропуск ROM
— данные команды входят в минимальный набор необходимых команд 1-wire-устройств. Т.к. в ключе DS1990A эти команды не требуются — он на них не отвечает.
Arduino может работать с 1-Wire, используя библиотеку Jim Studt-а – OneWire.
Настало время пообщаться с нашим ключиком! ?
Схема подключения – крайне проста (это ведь 1-Wire! ?
Далее нужно скачать библиотеку OneWire и поместить её в свою директорию libraries.
Видео:DS2413 - двухканальный I/O с шиной 1-WireСкачать
Введение в 1-Wire
Первая статья этого цикла тут
Вторая часть этого цикла тут
Третья часть этого цикла тут
Многим из вас, наверняка, знакомо это устройство. Но не все знают, что это микросхема с интерфейсом 1-wire. В таких корпусах (да и не только таких) компания Maxim, ранее Dallas Semiconductor, выпускает целый ряд устройств: термохроны, микросхемы флеш-памяти, ацп, ключи и многое другое.
Всё это – микросхемы с интерфейсом 1-wire.
Коротко
1-wire это интерфейс, позволяющий строить сети из устройств с топологией общая шина, один ведущий – много ведомых. Каждое устройство имеет свой собственный уникальный 64-битный адрес. Для двухсторонней передачи сигналов, несмотря на название, используется два провода: один общий\земля, а второй для питания и передачи данных. В этом и состоит особенность этой сети, что для питания и данных используется один проводник, хотя в некоторых устройствах опционально присутствует третий вывод для подключения внешнего питания.
По иронии судьбы большое распространение в россии получили самые простые устройства ds1990a, которые используются как ключи от домофонов, дверей, иногда сигнализаций. Это самая простая микросхема-метка, которая содержит только уникальный 64-битный адрес и умеет отвечать всего на пару команд (собственно отзываться на этот адрес). В таком же корпусе, имеющем название iButton существуют и более сложные микросхемы, например термохрон – это микросхема которая умеет мерить и запоминать окружающую температуру через заданный интервал времени, потом эти данные можно считать; есть микросхемы флеш-памяти, которые часто используются для хранения ключей; со всем разнообразием кому интересно может ознакомиться на официальном сайте.
Как это работает?
Пока шина свободна, она подтягивается к положительному уровню питания и удерживается в нем. В этот момент все устройства на шине заряжают внутренний конденсатор и получают энергию. Как только мастер хочет обратиться к какому-либо устройству, он опускает шину в ноль на заданный промежуток времени и возвращает её назад, затем ждет ответа – если на шине присутствует хотя бы один ведомый, он обязан ответить кратковременным опусканием же шины в ноль. Далее примерно таким же образом ведущий передаёт адрес, к кому конкретно он хочет обратится, команду и получает какие-либо данные.
Более-менее общие сведения о 1-Wire можно прочитать в википедии, а если вас заинтересовала специфика и подробности протоколов то можно почитать, например, тут.
Про 1-wire написано достаточно много, но в основном о том как применять и общаться с ними на уровне микроконтроллеров, встраивать в устройства, или просто читать данные с помощью PC, как правило одно-два устройства и на небольших расстояниях. Я не хочу повторяться, а планирую рассказать о том, как мы в современных реалиях на предприятии строили большую сеть, которая на текущий момент охватывает три здания, имеет более 300 1-wire устройств, 3 сервера для сбора и обработки данных и работает 24 часа в сутки 7 дней в неделю, розетки 1-wire установлены в помещениях на ряду с телефонными и ethernet практически в каждой комнате и коридорах.
Так что, если это вам интересно – будем продолжать.
Видео:1-Wire ScannerСкачать
Arduino, MK-90 и другие
Программирование Arduino, оживление микроэвм Электроника МК-90, аппаратный хакинг.
Видео:Введение в шину I2CСкачать
Страницы
Видео:Управление реле по шине 1-wire. Длина шины 300 метровСкачать
16.04.2011
Сеть 1-Wire в «полевых условиях»
- Скачать проект платы-подавителя помех в формате Eagle.
12 комментариев:
Большое спасибо за такую познавательную статью!
У меня возник вопрос. Есть микроконтроллер (какой нить Atmega) и датчик DS18B20, можно ли их соединить кабелем 100м без всяких усилителей (на транзисторах и т.д.), тоесть просто подключить к какому нить пину микроконтроллера. Питание не паразитное.
Да, вполне возможно! Именно такое подключение я и описывал. 100м — «серьезная дистанция» для нежной ножки MCU, посему очень рекомендую, использовать экранированный 3-х проводный кабель сечением 0,75мм и как минимум — два диода Шотки между GND, Data и VCC.
спасибо за ответ!
Еще вопрос: я хочу подключить датчик к одной ноге так как мне надо сделать сеть типа «звезда» в которой будет 10 датчиков (на каждой ветви по одному). Я решил к 10 ножкам микроконтроллера подключить по 1 датчику проводом 100м. Но может вы знаете более подходящее решение? Подключение звездой обязательно
а автор не экспереметировал с датчиками попроще ? то есть цифровыми и БЕЗ 1-WIRE
а то роюсь по прайсам местных магазинов и ничего кроме датчиков от 10 уе (без 1-wire) и DS18B20 не могу найти
а интересно покрутить термодатчик с встроенным АЦП без всякого лишнего и дешевле по идее должно быть
Прошу прощения, что встреваю: а о каких таких датчиках «цифровыми, но не 1-Wire» идет речь?
DS18B20 в своем классе точности и диапазоне — самое удачное решение среди полупроводниковых термодатчиков, 1-Wire позволяет для подключения N датчиков использовать всего один DIO MCU. Мнимая сложность программирования компенсируется многочисленными примерами кода и библиотеками в свободном доступе.
Ну а цена его — 2-3 USD, и если речь про экземпляры за 10 у.е. — это скорее всего не полупроводниковый или лучшая точность (диапазон у полупроводникового шире быть не может).
да действительно порылся на предмет датчиков подешевле — ничего нет ? подороже с более высоким классом точности или в более сложным исполнением
и еще вопросик вы опрашиваете все подряд или или каждый по отдельности
если каждый по отдельности поделитесь или скетчем или куском кода а то роюсь уже несколько часов ничкго путного найти не могу ?
Читайте также: Шины снежинка r13 аи 168
А чем Вас стандартный пример из библиотеки oneWire не устраивает?
Там вполне все вполне прозрачно, лишнее просто выкидывается (или комментируется),а остаток оформляется как своя функция.
«Не вдаваясь в сложности организации сети Ethernet, просто прошу поверить (и с мультиметром проверить) в то, что из-за значительного падения напряжения на длинных и весьма тонких проводах кабеля Cat.5e датчику сети 1-Wire банально не хватает напряжения питания!»
Проблема решается когда cat5 используется в качестве 4х проводной линии с внешним дополнительным питанием: GND, DATA, +12В, +18В.
Схема немного усложняется, добавляется 5В стабилизатор на шину +12В (для питания датчиков), и 12В стабилизатор на шину +18В (для питания относительно слаботочных исполнительных устройств если это необходимо)
Здравствуйте! Прислали из Китая сотню SMD-чипов, написали что это фербиды BLM21AG221. Маркировки на них никакой нет, тестер показывает почти нулевое сопротивление. Это похоже на правду? Есть ли какие-то другие способы проверить что это действительно они?
перезалейте картинки, не видно
Картинки, которые не показаны, из заблокированного аккаунта автора. Связаться с автором уже не представляется возможным ?
Видео:FLprog урок №2 шины данных Uart\I2C\ICSP\OneWireСкачать
Как перестать бояться и полюбить 1-wire
Мне очень нравится протокол 1-wire своей простотой и удобством для применения в системах «умный дом». Недавно я писал программную эмуляцию одной микросхемы и погрузился во внутренности этого протокола. Чтобы накопленные знания могли принести пользу не только мне, я решил написать данную статью. Но в статье я хочу рассказать не про абстрактные диаграммы сигналов и кодирование данных — перепечаток такого материала есть достаточно, а хочу рассказать про более практические вещи. А именно: рассмотрю проверенные лично схемы адаптеров, собранные из простых и доступных деталей, и расскажу, как из Linux получить доступ к устройствам 1-wire. Попутно расскажу про сам протокол, будет и пример низкоуровневой работы, и пример доступа из JavaScript, а также рекомендации владельцам Raspberry Pi. Эта статья в первую очередь для тех, кто хочет разобраться с протоколом практически с нуля, чтобы начать его использовать в своих проектах. Возможно те, кто уже хорошо знаком с протоколом, также найдут что-то новое для себя.
Протокол 1-wire является проводным протоколом (в отличие от беспроводного), для кого-то это преимущество, а для кого-то — недостаток. Сеть 1-wire состоит из шины, к которой подключаются устройства 1-wire. На шине может присутствовать множество «подчиненных» устройств и только один «мастер». Подчиненные устройства могут общаться только с мастером и только по его запросу. Шина 1-wire состоит только из одной линии «данных» (отсюда и название — «однопроводный»), но для работы также необходима линия «земля», а для питания устройств еще и линия «питания». При небольшом количестве подчиненных и их небольшом энергопотреблении возможно также так называемое «паразитное» питание от линии данных. Таким образом, для подключения устройства по 1-wire Вам понадобится 3 (или 2) провода и мастер сети. Мастером сети может быть, например, микроконтроллер или ПК + адаптер 1-wire.
Физический уровень
Как же по одной линии происходит взаимодействие с множеством устройств? На физическом уровне линия устроена по принципу «монтажного И», это значит, что линия будет в состоянии логической «1» (уровень около 5V), если все устройства на линии перевели ее в состояние логической «1», а в состоянии логического «0» (около 0V), если хотя бы одно из устройств перевело ее в состояение логического «0». На практике это реализовывается подключением линии через резистор (называется «резистором подтяжки») к напряжению питания, а каждое из устройств может только замыкать линию с землей при помощи встроенного транзистора. Такой тип выхода устройств называется «открытый коллектор» или «открытый сток», англ. «open-drain». Резистор подтяжки обычно расположен в мастере сети (адаптере).
Очевидно, что при паразитном питании ток поступает через резистор подтяжки, и чем больше ток потребления устройств, тем ниже будет проседать напряжение линии. Стандартом регламентировано напряжение лиии 4.5-5.5V, хотя многие устройства и могут работать при значительно более низких напряжениях, но не все. Для снижения проседания напряжения можно уменьшить сопротивление резистора подтяжки, но согласно стандарту, сопротивление не должно быть менее 500 Ом. На практике сопротивление резистора подтяжки можно взять 1кОм, если будет использоваться паразитное питание, и, например, 4.7кОм, если питание будет по отдельной линии.
GPIO адаптер
Простейший адаптер 1-wire можно построить с помощью GPIO:
По такой схеме устроен «адаптер» при использовании GPIO микроконтроллера, работающего от напряжения 5V, соответсвенно на его портах допустимо напряжение до 5V. Но на портах Raspberry Pi допустимо напряжение до 3.3V, поэтому резистор подтяжки можно подключать только к 3.3V. Такой адаптер будет работать с некоторыми устройствами, но, как уже говорилось, не все устройства могут работать с пониженным напряжением. Эту проблему легко решить с помощью двунаправленого преобразователя логических уровней:
Диод между истоком и стоком на схемах иногда не обозначают, но он всегда есть в реальных транзисторах.
Схема адаптера с использованием GPIO для Raspberry Pi будет выглядеть следующим образом:
В этой схеме убран резистор подтяжки, подключенный к истоку, с этим «хаком» схема продолжит работать. Т.к. напряжение на GPIO (и на истоке) станет меньше чем 3.3V (напряжение на затворе) на величину напряжения затвор-исток, при которой открывается транзистор. Напряжения на GPIO будет достаточно, чтобы GPIO его воспринимал как логическую «1».
Канальный уровень
Для понимания принципа работы следующего типа адаптера, разберемся, как работает мастер 1-wire на канальном уровне. В 1-wire есть всего четыре примитива канального уровня: отправка ресет, чтение присутствия, отправка бита 0, отправка бита 1 и она же по совместительству чтение бита. Для понимания принципа будет достаточно рассмотреть только два последних: отправка бита 0 реализуется путем установки на линии логического «0» в течение 60-120мкс, отправка бита 1 — путем установки «0» в течение около 8мкс, чтение бита — путем последующего чтения состояния линии, если линия вернулась в «1», значит подчиненное устройство передало бит 1, если задержалась в «0» не менее, чем на 15мкс — значит подчиненное таким способом передало бит 0.
Пассивный адаптер
Следующий типа адаптера построен на использовании UART. Если по UART на скорости 115200 BAUD передать байт FFh, то на TX появится логический «0» только во время передачи стартового бита, это около 8мкс, подчиненные устройства это воспримут как отправку бита 1, а если передать байт 00h — появится логический «0» примерно на 78мкс, подчиненные устройства это воспримут как отправку бита 0. А что если TX соединить с RX? Мы будем получать из UART ровно то, что передали: передали FFh — получили FFh. А если эту линию принудительно задержать в логическом «0» чуть дольше, то получим уже не FFh, а, например, FEh, FCh, F8h, F0h и т.д. Таким простым способом реализуется чтение бита. Схема адаптера, построенного на использовании UART, он еще называется «пассивным» адаптером, будет такой:
По такой схеме также часто строится «адаптер» для микроконтроллера, имеющего аппаратный UART. В схеме необходимо использовать только диод Шоттки, т.к. важно малое падение напряжение на диоде. Диод в этой схеме — это «хак» для преобразования выхода «пуш-пулл» (англ. push-pull) в подобие выхода «открытый коллектор». В выходе пуш-пулл к выходу коммутируется транзисторами либо земля, либо напряжение питания, а в выходе открытый коллектор коммутируется только земля, а для «обозначения» логической «1», выход переводится в высокоимпедансное состояние, в этом состоянии выход можно подтянуть резистором к любому напряжению и он беспрепятственно приобретает это напряжение.
Здесь стоит упомянуть адаптер для RS232, хоть этот интерфейс уже практически и не встречается. На канальном уровне UART и RS232 это один и тот же протокол, но на физическом они отличаются: в UART используется напряжение 0V и 5V (или 3.3V, такой адаптер будет немного позже), а в RS232 — +12V и -12V соответственно. Вот схема адаптера 1-wire для RS232, взятая из Dallas Application Note 74:
Читайте также: Зимние шины 245 55r19
Как мы помним, в Raspberry Pi на всех портах допустимо напряжение до 3.3V, поэтому нужен вот такой «пассивный» адаптер для UART 3.3V:
В этой схеме также необходимо использовать только диод Шоттки.
Аппаратные адаптеры
Существует еще и третий тип адаптеров — аппаратные, это микросхемы-конвертеры в 1-wire, выпускаются они для трех протоколов: USB, UART, i2c. У них есть преимущества по сравнению с предыдущими типами, например, в «пассивном» адаптере используется прием/передача целого байта для приема/передачи одного бита, а в аппаратном на этом получаем выигрыш в 8 раз (на самом деле аппаратно реализованы и другие функции: ресет, алгоритм поиска), кроме скорости это и упрощение, и сокращение кода, что очень актуально для микроконтроллеров.
Но главное преимущество аппаратных адаптеров это «активная» подтяжка. Разберемся с этим подробнее, для наглядности рассмотрим случай с паразитным питанием. При кратковременном нахождении линии в логическом «0», устройства питаются от своих встроенных конденсаторов, разряжая их, а при возвращении линии в логическую «1», конденсаторы начинают заряжаться, потребляя повышенный ток от линии. Как мы помним, ток идет через резистор подтяжки, имеем RC-цепь с переходным процессом с постоянной времени t=R*C, что проявляется в медленном нарастании напряжения на линии. Очевидным выходом в этой ситуации является кратковременное уменьшение сопротивления резистора подтяжки для сокращения постоянной времени переходного процесса. Эта техника и называется активной подтяжкой, реализовывается путем коммутации линии с напряжением питания на несколько микросекунд (вспоминаем тип выхода пуш-пулл). Это очень помогает на длинных или не очень качественных линиях, т.к. сами проводники также имеют сопротивление.
Конверторы из USB и i2c мне не доводилось использовать, а вот схему с применением микросхемы-конвертера из UART (DS2480B) я приведу, но позже и в чуть более продвинутом исполнении.
Гальваническая развязка
В предыдущих рассмотренных схемах линии земля, питание и данные прямо или косвенно соединяли внутренние схемы всех устройств. Такой вариант подойдет, если устройства будут под Вашим контролем и в безопасной среде, скажем в пределах квартиры или дома. Но если, например, датчик, работающий по 1-wire необходимо установить на крышу (метеостанция), то необходимо задуматься о защите. В данном случае речь идет о защите внутренних схем дорогостоящего оборудования от повышенного напряжения или статических разрядов. Защитить ПК или Raspberry Pi можно, отвязав его гальванически от всех линий 1-wire.
Развязывать необходимо две вещи: питание (и вместе с ним землю) и сигналы. Питание адаптера можно обеспечить от отдельного БП или использовав DC-DC преобразователь с гальванической развязкой (например B0505S). Сигналы можно развязать с помощью оптронов, это пара светодиод-фототранзистор в закрытом общем корпусе. Оптрон позволяет передавать сигнал только в одном направлении, а линия 1-wire является двунаправленной и, к сожалению, нет простых схем сделать двунаправленную гальваническую развязку. Это же касается GPIO, USB и i2c. А вот в UART обе линии RX и TX являются однонаправленными, поэтому получится сделать адаптер как пассивный, так и на аппаратном 1-wire-UART конвертере. Необходимо учесть, что в пассивном адаптере используется скорость UART 115200 BAUD, а аппаратный производит обмен данными на скорости 9600 BAUD. При выборе оптронов необходимо обращать внимание на параметры tON, tOFF, они должны быть существенно меньше 1/BAUD.
К сожалению у меня не нашлось быстрых оптронов, а PC817C, которые были в наличии, уверенно работали только до 19200 BAUD. Примерно таким образом я бы реализовал пассивный адаптер с гальванической развязкой, но, в отличие от остальных схем, эту схему я не проверял:
Полевой транзистор в этой схеме использован для создания большого входного сопротивления «приемной» части. Бонусом гальванической развязки является то, что схема одинаково будет работать и при напряжении UART 5V, и при 3.3V.
И, как было обещано, схема адаптера с применением 1-wire-UART конвертера (микросхема DS2480B) с гальванической развязкой:
Это самый совершенный из всех перечисленных адаптеров.
Приведу также свой вариант его реализации на макетной плате:
Две перемычки используются для подачи GND и +5V на DC-DC в случае UART 5V, а при подключении к UART 3.3V одна убирается и контакт подключается к +5V, второй перемычкой землю также можно сделать отдельной от земли UART.
Эмуляторы адаптеров
За неимением микросхемы DS2480B можно воспользоваться ее программной эмуляцией на любом микроконтроллере AVR, который имеет аппаратный UART. Такой МК установлен практически во всех Arduino. Здесь приведу схему, как из популярного программатора USBasp на микроконтроллере ATmega8A сделать 1-wire адаптер:
Для прошивки Вам, естественно, понадобится второй программатор. Код эмулятора и готовую прошивку можно скачать отсюда, код взят из проекта tinyowd, в эмуляторе не реализована активная подтяжка и некоторые функции.
Сетевой уровень
На сетевом уровне мастер при общении с подчиненными устройствами уже может оперировать байтами. Как мы помним, на канальном уровне при отправке бита 1 происходит и одновременное чтение, и в ответ можно получить бит 0. Таким образом при отправке байта, на его основе формируется байт ответа, в котором некоторые биты могут быть обнулены.
Все подчиненные устройства «слышат» мастера одновременно, но отвечать должно только одно. Для этого после начальной процедуры «отправка ресет, чтение присутствия» осуществляется процедура «адресации подчиненного», после которой весь последующий обмен данными осуществляется только с выбранным подчиненным, а все остальные устройства эти данные игнорируют до следующего цикла «отправки ресет».
Существует всего четыре команды сетевого уровня, которые понимают все без исключения подчиненные: CCh (SKIPROM), 33h (READROM), 55h (MATCHROM), F0h (SEARCHROM). Но есть и некоторые другие, например, ECh (ALARM), A5h (RESUME) и Overdrive-варианты предыдущих команд, которые понимают не все устройства. На самом деле две первые команды адресуют не одно а все устройства, первая (SKIPROM) используется для широковещательной рассылки команд, например «запустить на всех устройствах измерение температуры», а сама температура будет прочитана позже по отдельности с каждого устройства. Вторая (READROM) используется только когда известно, что устройство на шине может быть только одно. Но для проверки на сетевом уровне есть еще контрольная сумма адреса, так что, если ответят несколько устройств, контрольная сумма это позволит выявить.
Адреса 1-wire, их еще называют идентификаторами, имеются только у подчиненных устройств. Адреса имеют длину 8 байт, из которых независимые только 7, а восьмой байт содержит контрольную сумму этих семи байтов адреса. Адреса всех устройств уникальны, они прошиваются при изготовлении и изменить их уже нельзя. Первый байт адреса всегда одинаков для одного типа микросхем, т.е. по нему можно однозначно определить название микросхемы. Этот байт носит название «адрес семейства».
После процедуры «адресации подчиненного» последующий обмен данными уже относится к сеансовому и более высоким уровням модели ISO OSI и может отличаться для разных семейств устройств.
Низкоуровневая работа
Продемонстрирую, насколько просто происходит работа с DS2480B. Для этого в одном терминале из командной строки bash запускаем:
Эта команда будет читать из UART и выводить на экран в шестнадцатеричном формате каждый прочитанный байт. В другом терминале будем отправлять байты в UART.
Первым делом отпрявляем Break для сброса DS2480B, для этого снижаем скорость UART ниже 9600 BAUD и предаем 00h, DS2480B при чтении в стоп-бите обнаружит логический «0», воспримет это как команду сброса и приведет свое состояние в исходное (окажется в режиме команд):
После чего возвращаем скорость на 9600 BAUD:
Отправляем любую команду (в данном случае это команды DS2480B) для калибровки скорости DS2480B, на которую DS2480B никак не отреагирует, например, безобидную команду чтения параметра конфигурации 01h:
Отправляем команду C1h, которая генерирует «отправку ресет» на шине 1-wire, в ответ получим CDh если на 1-wire последовал импульс «присутствия», или EDh если «присутствия» не последовало (ответ наблюдаем в другом терминале):
Читайте также: Изменение давления в шинах при движении
Переключаем DS2480B в режим данных, в ответ ничего не получаем:
В режиме данных все байты, которые передаются в UART транслируются конвертером побитно в 1-wire и при передаче битов 1 автоматически происходит чтение бита, которое может обнулять биты в исходном байте. Модифицированный таким образом байт конвертер отправляет обратно в UART. Отправляем команду 33h, теперь это уже команда READROM сетевого уровня протокола 1-wire, в ответ получим 33h без изменений:
В ответ на READROM устройство (для простоты подключаем на шину только одно устройство) отправит свой ID, для этого ему необходимо послать 64 единичных бита (идентификаторы состоят из 8 байт), которые в ответе будут модифицированы:
Вот что будет в другом терминале после выполнения всех вышеперечисленых команд:
Идентификатор подчиненного устройства здесь будет 288df444020000a6, где 28 — адрес семейства (датчики температуры DS18B20), a6 — контрольная сумма адреса, проверять ее должны мы, а не DS2480B.
Естественно, в Linux так никто не работает с 1-wire. Но при программировании микроконтроллеров или драйверов, все происходит именно подобным образом.
Высокоуровневая работа
В ОС Linux есть два подхода к высокоуровневой работе с устройствами 1-wire:
- с помощью приложений в пространстве пользователя,
- с помощью драйверов ядра.
Первый способ исторически появился раньше и на сегодняшний день все еще является более предпочтительным. Самой полной реализацией является пакет owfs, в котором есть поддержка большого числа адаптеров и подчиненных устройств. Приложение, как правило, получает доступ к адаптеру через файл устройства в /dev/ и всю низкоуровневую работу с ним выполняет самостоятельно.
При работе с драйверами ядра, вся низкоуровневая работа с устройствами выполняется в ядре, которое предоставляет доступ приложениям к 1-wire через интерфейс netlink и дополнительно через специальную файловую систему /sys/ .
Драйверы ядра
Драйверы ядра делятся на драйверы для адаптеров и драйверы для подчиненных устройств. Драйверы адаптеров создают уровень абстракции W1, объединяя шины 1-wire от всех доступных адаптеров. Далее есть два варианта использования уровня абстракции W1: использование его в приложениях, например, в owfs как еще один вид «адаптера», или использование поверх него драйверов подчиненных устройств (тоже в ядре).
Для работы с 1-wire с помощью драйверов ядра достаточно загрузить драйвер адаптера. Например, для DS2490 (это аппаратный 1-wire-USB конвертер):
Для DS2482 (это аппаратный 1-wire-i2c конвертер) предварительно необходимо загрузить драйвер для конкретного i2c контроллера и затем сообщить ему адрес адаптера на шине i2c:
В случае Raspberry Pi в файле /boot/config.txt добавить строку, или можно даже несколько:
Тогда при загрузке ядра модуль w1-gpio загрузится автоматически. К сожалению, в ядре (на момент написания статьи это linux-rpi-5.4.y) драйверы для DS2480B и пассивного адаптера не реализованы.
При загрузке любого драйвера адаптера автоматически загрузится модуль wire , который запустит периодический поиск подчиненных устройств на шине адаптера и автоматически загрузит модули для найденных подчиненных устройств. В каталоге /sys/bus/w1/devices/ появятся подкаталоги с именами, равными идентификаторам найденных устройств, в подкаталогах единственным полезным является файл w1_slave .
Несмотря на простоту этого способа, я его не рекомендую по причине того, что драйверы все еще сырые, для некоторых устройств реализован не весь функционал, а для многих устройств драйверов вообще нет.
Центральной частью пакета owfs является демон owserver , который работает с адаптерами через файлы устройств в /dev/ или через другие интерфейсы ядра и предоставляет доступ ко всем устройствам 1-wire для других приложений по собственному протоколу поверх TCP, мультиплексируя запросы от клиентов и кешируя ответы от устройств.
Для установки owfs необходимо выполнить аналоги следующих команд для своего дистрибутива:
Или скомпилировать из исходных кодов отсюда: github.com/owfs/owfs/releases
Следующим шагом необходимо добавить адаптеры в файл конфигурации. Пример файла конфигурации /etc/owfs.conf :
В owfs нет поддержки адаптера, использующего GPIO, поэтому единственным способом получить доступ к GPIO из owfs является использование драйвера ядра w1-gpio и получение к нему доступа через уровень абстракции W1. Такой способ потребует запуска owserver от имени root . В любом случае, я не рекомендую адаптер на GPIO для серьезного использования, т.к. он реализован программно (техника bitbang) и грузит процессор.
После запуска owserver , к нему можно обращаться командами, например:
Как можно заметить, контрольная сумма адреса не указывается, owserver сам ее вычисляет. К owserver также можно обращаться и с другого хоста:
Естественно, для этого в /etc/owfs.conf должно быть:
Следует предостеречь, что в owserver нет никаких разграничений прав доступа, поэтому любой, кто может подключиться к порту owserver может как читать, так отправлять команды и записывать на подчиненные устройства.
Для языков программирования C, python, perl, php есть библиотеки, из которых тем же способом через TCP можно получить доступ к owserver . Протокол у owserver очень простой, поэтому можно легко написать реализацию для любого другого языка.
Доступ из JavaScript
Еще один демон из пакета owfs, который может быть полезен — owhttpd , он также обращается к owserver по TCP, а с другой стороны предоставляет доступ на порту 2121 по http. Но самое полезное находится в нем по адресу http://сервер:2121/json/ , что открывает возможности для обращения к устройствам 1-wire из веб-страницы на JavaScript с помощью XMLHttpRequest.
Здесь то же самое предостережение: доступ к owhttpd также позволяет как читать, так и записывать на подчиненные устройства всем, кто может подключиться к порту owhttpd . Поэтому приведенный выше способ годится только, например, для вэб-интерфейсов администратора для внутреннего использования.
Полезные советы
Т.к. owserver обращается к адаптерам через файлы устройств в /dev/ , то можно с помощью udev передать права на устройства другому пользователю, например, создать пользователя owfs и от его имени запускать owserver . Для этого в файле /etc/udev/rules.d/85-onewire.rules добавить строки примерно с таким содержимым:
Если необходимо организовать несколько 1-wire шин, то потребуется несколько UART интерфейсов. Для этого можно восопользоваться несколькими USB-UART конвертерами. А в Raspberry Pi 4 можно активировать до пяти аппаратных UART, для этого в /boot/config.txt нужно добавить:
Файлы устройств после перезагрузки будут называться /dev/ttyAMA[0..4] , эти UARTы будут работать на выводах:
Напомню, что так же, как и в случае с GPIO, если мы используем встроенный UART на Raspberry Pi, необходимо применение преобразователя логических уровней или гальванической развязки, т.к. все GPIO на Raspberry Pi работают с напряжением до 3.3V.
Сравнение с ModBus
Для понимания, какое положение занимает 1-wire в сравнении с другими подобными протоколами для автоматизации, я провел сравнение с популярным протоколом ModBus. ModBus также использует модель мастер-подчиненные и в связке с RS485 также может работать используя всего два провода.
Как можно заметить, 1-wire более медленный, не такой гибкий и не такой помехозащищенный, что не дает ему права называться «промышленным». Но его характеристик более чем достаточно для домашней автоматизации в системах «умный дом». А используемые напряжения и простота «адаптера» для микроконтроллера делают его идеальным для разработки собственных устройств на МК.
Выводы
Протокол 1-wire на самом деле является очень легким в освоении. Я надеюсь, что статья поможет пролить свет на многие ранее не понятные моменты, которые могли быть препятствием на пути к использованию данного протокола.
Для знакомства с протоколом владельцам Raspberry Pi я рекомендую начать со сборки адаптера на GPIO. В файле /boot/config.txt добавить:
Установить owfs и записать в /etc/owfs.conf всего три строки:
Владельцам ПК или ноутбука рекомендую приобрести USB-UART конвертер (он Вам еще не раз пригодится, они бывают на микросхемах FT232, PL2303, CP210X и др. — подойдет любой) и собрать пассивный адаптер. Установить owfs и записать в /etc/owfs.conf тоже всего три строки:
И в том и в другом случае после перезагрузки выполнить:
Следующим шагом рекомендую сборку адаптера на DS2480B с гальванической развязкой.
Приведу несколько полезных 1-wire подчиненных устройств, которые стоит попробовать:
- Свежие записи
- Нужно ли менять пружины при замене амортизаторов
- Скрипят амортизаторы на машине что делать
- Из чего состоит стойка амортизатора передняя
- Чем стянуть пружину амортизатора без стяжек
- Для чего нужны амортизаторы в автомобиле
📹 Видео
Лекция 309. 1-wire интерфейсСкачать
Опрос дискретных входов по шине 1-wire. Длина шины 300 метровСкачать
FLProg урок внеплановый#7 I2C OneWireСкачать
Работа с 1-wire ds18b20. Примеры проектов.Скачать
Передача данных по 1wire от датчика DS18b20 на расстояние 5 метров.Скачать
Arduino и 1 wire: ds2408 + ds2406Скачать
Протокол обмена данными 1-Wire (Microlan)Скачать
USB - 1-wire конвертер. Подключение датчиков температуры DS18B20 по USB.Скачать
Лекция "Интерфейсы (часть II). I2C. 1-Wire"Скачать
Как подключить и пользоваться датчиками температуры шины 1-Wire?Скачать
Логический LIN пробник, цифровой тестер лин, к лайн шины автомобиля. На Ардуино, OLED I2C, TJA 1020Скачать
Связь между МК по 1WIRE ТестСкачать
Особенности работы с библиотекой Wire в среде Arduino IDEСкачать
Умная теплица Nextion + 1 WireСкачать