Хакаем CAN шину авто. VAG диагностический бортовой компьютер

Моя цель - предложение широкого ассортимента товаров и услуг на постоянно высоком качестве обслуживания по самым выгодным ценам.

С огромным увлечением исследую протоколы CAN шины и разрабатываю устройства взаимодействующие с автомобилем. У меня уже есть голосовое управление центральным замком, виртуальная панель приборов и даже мобильное приложение для моей Skoda Octavia A5.

Теперь я решил разработать диагностический бортовой компьютер для автомобилей группы VAG (VW, Audi, Skoda, Seat). Моими техническими требованиями было: OLED дисплей, лёгкая установка и подключение, множество диагностических параметров. В качестве компонентной базы выбрал:

  • STM32F103C8T6 — дешёвый МК с поддержкой CAN шины на отладочной плате
  • 2,8" OLED 256*64 — дисплей с достаточным количеством точек на драйвере SSD1322
  • SN65HVD230DR — CAN приёмопередатчик с питанием 3.3 В
  • Mini-360 — импульсный регулируемый понижающий DC-DC стабилизатор напряжения на чипе MP2307



Процесс разработки разбил на 3 этапа и каждый из этапов принёс мне кучу нового опыта и удовольствия:

  • Разработка печатной платы в Proteus
  • Разработка прошивки для STM32
  • Разработка корпуса из акрила


▍ Разработка печатной платы в Proteus


Первая рабочая версия была собрана на макетке за один вечер и ещё день потребовался для выяснения, что приёмопередатчику для функционирования нужен резистор (Rs — GND), который включает режим HIGH SPEED MODE:



На всякий случай оставлю свои заметки здесь из даташита на SN65HVD230DR.

Убедившись, что на макетной плате всё работает, я перешёл к разработке печатной платы в Proteus 8. Можно было бы все компоненты дисплея и Blue Pill перенести на одну плату, но я поленился так много паять, для первой версии и так сойдёт!



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



Конечно в первой версии трудно всё продумать, но не предусмотреть кнопку ВЫКЛЮЧЕНИЯ, для этого нужен талант. Устройство подключается в OBD2 разъём, в котором всегда присутствует напряжение 12 В. Придётся теперь скальпелем дорабатывать печатную плату, чтобы установить тумблер включения. Хотя возможно имеет смысл сделать включение/выключение на программном уровне, определяя, что двигатель заведён по CAN шине или повышенному напряжению бортовой сети.

▍ Разработка прошивки для STM32


Это мой первый опыт работы с STM32, но каких-то сложностей я пока не испытал. Разработку веду в STM32CubeIDE, код решил писать на Си и так как я новичок в этом деле, то отказываться от HAL не стал, хотя в процессе разработки осознал его избыточность. После выпуска стабильной прошивки займусь оптимизацией и погружусь в изучении STM32 более серьёзно, чтобы исключить HAL и уменьшить размер прошивки.



В бортовом компьютере самое главное это отображаемые диагностические параметры. Для компьютерной диагностики моей Skoda Octavia я использую автомобильный сканер VCDS.



Если подслушать сниффером, как VCDS общается с машиной по CAN шине, то можно воспроизвести протокол в моём бортовом компьютере. Более подробно я рассказывал как исследую CAN шину в прошлой статье.



В машинах группы VAG выпущенных с 2004 по 2012 года для диагностики двигателя и коробки передач используется протокол либо TP2.0 (KWP2000), либо UDS, на машинах после 2012 только UDS.

UDS очень удобный для программиста протокол, длина CAN фрейма всегда 8 байт, запрос состоит из одного фрейма и ответ, чаще всего тоже из одного фрейма. А в TP2.0 применяется несколько проверок целостности пакета, но зато TP2.0 обращается к группе параметров и за один запрос можно получить до 4 различных параметров.



На экране бортового компьютера отображаются 4 параметра, это оптимальное количество по нескольким причинам: а) полная группа TP2.0; б) видны пропуски зажигания всех 4-х цилиндров сразу; в) элементы оптимального размера. Точный список параметров, которые будет показывать прибор я ещё не сформировал, но есть параметры, которые очень важны:

  • Уровень масла в двигателе
  • Наддув турбины (реальный)
  • Наддув турбины (ожидаемый)
  • Пропуски зажигания в цилиндрах
  • Углы откатов зажигания в цилиндрах
  • Температура коробки передач DSG/AISIN

Таким образом в бортовом компьютере будет десяток экранов с различными параметрами, переключение между экранами осуществляется с помощью кнопок вперёд/назад.

▍ Разработка корпуса из акрила


Пообщавшись с сообществом автолюбителей на drive2.ru поступило предложение сделать бескорпусное устройство, тогда каждый желающий сможет вмонтировать его куда угодно, например в воздуховод. Но я всё-таки решил сделать корпус, мне кажется не все захотят модифицировать салон своей машины:



Первым делом я попытался найти готовую коробочку, но в нужных размерах и близко ничего не было. Напечатанный на 3D принтере корпус из ABS мне не понравился. Я решил попробовать нарезать лазером корпус из чёрного оргстекла, получилось красиво и производство штучных экземпляров недорогое, порядка 500р за корпус:



Корпус легко разборный, поэтому при желании можно извлечь плату с дисплеем и установить её в воздуховод.

В комплекте с бортовым компьютером идёт кабель подключения в OBD2 разъём. На Ali заказал компактный OBD2 штекер, но он оказался не очень удобным. Отверстие для кабеля у штекера с боку, из-за этого его неудобно вытаскивать из разъёма, но я модифицировал корпус штекера надфилем, чтобы кабель выходил сзади и получилось то что нужно:



К прибору кабель подключается XH2.54 разъёмом. Сначала я припаивал пины к проводам, но после нескольких дней тестирования они благополучно отвалились. Тогда я открыл для себя кримпер с губками SN-2549 (SN28B + SN01BM). Использование этого инструмента принесло множество положительных эмоций, как легко и красиво им можно делать разъёмы! Теперь не понимаю, как я жил без него раньше, это супер удобная и супер необходимая вещь в хозяйстве электронщика:


Как говорит Джорж из «Свинка Пеппа»: Динозаврррррррррр!

▍ Заключение


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

Прилагаю видео с демонстрацией работы VAG диагностического бортового компьютера:


Источник: https://habr.com/ru/company/ruvds/blog/589653/


Интересные статьи

Интересные статьи

Сегодня мы хотим поделиться опытом решения задачи детекции дефектов на снимках промышленных объектов методами современного компьютерного зрения. Наш рассказ будет состоять из нескольк...
В своей предыдущей статье я рассказывал о том, как собирал компьютер для экспериментов с 16-битным защищённым режимом Intel. Там же я анонсировал следующую статью, в кото...
Продолжаю делиться историей разработки аппаратной платформы GM-Box G1. В предыдущей статье я рассказал о первых шагах на пути создания продукта - прототипировании для проверки продук...
Компания Dell создаст самый мощный промышленный суперкомпьютер в истории. Новая установка под названием HPC5 будет обладать вычислительной мощностью в 52 Пфлопс. Суперкомпьютер HPC4 в дата-ц...
Эта публикация написана после неоднократных обращений как клиентов, так и (к горести моей) партнеров. Темы обращений были разные, но причиной в итоге оказывался один и тот же сценарий, реализу...