Изначально блок управления обновляли на автомобиле с использованием системы ODIS. Это была одна из последних версий блока управления ABS с номером 80A907379AF
, однако для программирования использовали ODX-файл для блока ABS
80A907379AN
. Номера совпадали, но различие в буквах привело к ошибке. Использование прошивки, предназначенной для другого номера, недопустимо, так как ODX
-файлы содержат бинарные патчи, которые модифицируют части кода. Неправильное применение таких патчей может вызвать непредсказуемые последствия, что и произошло: блок управления перестал выходить на связь, и клиент обратился к нам за помощью.
Первое что мы сделали: произвели вскрытие крышки блока управления посредством нагревания компаунда на столе подогрева, сняли образ ПЗУ из EEPROM 95256, считали и сохранили FLASH
программой JLinkZReader через точки подключения к процессору TMS570LS31. В нашей лаборатории это стандартная процедура: она выполняется для того, чтобы избежать дополнительных ошибок при подключении к ЭБУ на столе.
Понимание того, как произошла ошибка, дало нам шанс восстановить оригинальную прошивку. Мы изучили, как выглядит ODX
-файл, написали код на Python для анализа различий между ODX
-файлом, используемым для патча, и оригинальной версией. Скрипт сравнивает оба файла, находит различия, затем определяет их во FLASH
, и заменяет изменённые участки кода на оригинальные. Несмотря на возникновение "шума" из-за наложения патча, нам удалось заменить большую часть флеш-памяти с помощью нашего скрипта odx.py, который получил дальнейшее применение в других проектах.
Благодаря проделанной работе нам удалось восстановить связь с блоком управления. Подключение проводилось через интерфейс VW Gateway к шине FlexRay. Это было вторичное подключение, первый раз мы подключались к блоку в начале ремонта, после снятия образов FLASH
и EEPROM
с «кирпича», несмотря на то, что результат был известен заранее.
Связь с ЭБУ
восстановить удалось, но блок функционировал некорректно, запросы на сохранённые ошибки (DTC) не поддерживались, некоторые ID не возвращались, что указывало на неполную работоспособность.
Мы попытались перепрограммировать блок с использованием оригинального ODX
-файла посредством VAG CAN PRO, но процесс остановился на этапе авторизации. Вывод напрашивался сам собой: это происходит из-за того, что мы очистили флеш, но EEPROM
не трогали, он остался обновлённым патчем.
Не имея оригинального EEPROM
, мы подобрали его из донорских блоков ABS
. Подходящий дамп мы нашли, но потратили на это немало времени. Изначально искали образ дампа, испробовали много вариантов, но все попытки закончились ничем. Донорский дамп мы взяли из блока с номером 4M6907379AC
, этот блок оказался в конце немаленького списка.
Находка нас не только обрадовала, но и немало удивила, надежды на это было немного. Тем не менее блок управления начал корректнее отзываться и отображать ошибки, что позволило провести перепрошивку. Заливка оригинального ODX
-файла завершилась с ошибкой подписи, но, в целом, прошла успешно.
Таким образом, функционирование блока управления было восстановлено, правда он стал своеобразным гибридом из двух разных устройств. ЭБУ заработал, но у него чужие кодировки и защита компонентов. Мало того, теперь в ЭБУ
ABS
с номером 80A907379AF
стал отображаться номер детали аппаратного обеспечения 4M6907379
…
Всё это говорило о том, что, такой блок управления машина не примет, донорский EEPROM
имеет свои настройки, свою компонентную защиту и т.д. Попытки изменить несоответствия напрямую прошли неудачно, например, при изменении ECU ID, возникали сбои: блок переставал видеть эту информацию и выводил пустое значение при диагностике. Стало понятно, что в системе предусмотрена проверка целостности — либо контрольная сумма, либо другая защита, но выявить эту закономерность не удалось.
После таких выводов и экспериментов было решено заняться оригинальным дампом, который изначально находился в блоке. Мы сняли его при первом знакомстве с ЭБУ
. Для этого необходимо было бы применить реверс-инжиниринг, на что пока не было времени.
Частичный реверс всё же понадобился, чтобы понять, как соотносятся идентификаторы блоков с их длинами, так как без него эту информацию невозможно получить. В рамках другого проекта мы создали скрипт на Python
для разбора EEPROM
и доработали его для данного случая, чтобы понять, какие блоки содержатся в дампе и к чему они относятся.
В структуре дампа вначале хранится список указателей на фрагменты различных блоков данных. В этих списках содержится тип блока данных и смещение (offset) внутри EEPROM
, где находятся данные этого блока. Мы нашли нужные нам фрагменты и сравнили их с аналогичными в дампе-доноре.
В итоге были отредактированы несколько блоков. Восстановлен номер, заменили 80A907379AN
на 80A907379AF
. Номер 931
, номер программного обеспечения, был заменён на 871
. Эти и другие блоки были скопированы в оригинальный дамп из дампа-донора, запрограммированного на нашем блоке управления. Мы также определили блок ошибок и очистили его.
С восстановленным ПЗУ
, блок управления запустился и стал корректно отвечать на диагностические запросы, за исключением кодировок, которые отображались как 00
.
Посоветовавшись с профессиональным диагностом, мы решили завершить ремонт блока. По его словам, все кодировки примутся, когда блок будет закодирован, для этого потребуется кодировать ЭБУ ABS непосредственно на автомобиле и вводить его в эксплуатацию. Более того, необходимо будет синхронизировать его с оригинальным автомобилем из-за защиты компонентов.
Комментарии (7)
vilgeforce
04.12.2024 07:07Упомянутый ODIS не умеет делать бэкапы перед патчингом?
ecurep Автор
04.12.2024 07:07При прошивке блоков управления, также как и при прошивке устройств, бекапы делать не принято. Другое дело, что в устройствах есть "recovery", в ЭБУ такое встречается только в ГУ.
slog2
04.12.2024 07:07ABS это безопасность в критических ситуациях. А вы там чего-то попатчили методом тыка, лишь бы ошибок не показывал. Как он будет работать не известно.
ecurep Автор
04.12.2024 07:07Почти любой ремонт автомобиля может привести к критическим ситуациям. Например, одному моему другу во время банального шиномонтажа не до конца завернули гайки на колёсах, в следствие чего у него в дороге почти открутилось колесо, хорошо, во-время заметил ).
Все мы помним отзывную компанию Toyota, причиной которой стала, казалось бы, безобидная деталь - коврик (https://www.gazeta.ru/auto/2009/09/30_a_3268142.shtml) под педалями.
Поэтому рассматривать замену подушек безопасности, прошивку блока SRS или ABS, чип-тюнинг, так популярный в России, как некоторое неконтроллируемое действие не стоит.
Теперь про "метод тыка". Если Вы читали статью, то никакого "метода тыка" в ней не было описано. Изменения, которые получил блок были вызваны "успешной" прошивкой штатными средствами производителя. Обратные действия делались на основании тех же данных производителя. Замена идентов производилась вручную, но целостность не была нарушена, что тоже доказательно объясняется. Где же здесь тык?
В качестве контраргумента мне хотелось бы взглянуть на то, как Вы, методом тыка почините подобную неисправность в блоках ABS или SRS. Будем благодарны за демонстрацию подобных скиллов )
NutsUnderline
04.12.2024 07:07а при проведении собеседования на должность авторемонтника теперь даются алгоритмические задачи или достаточно знание asm нескольких процов? (тег: сарказм присутствует, но я реально удивлен)
woodiron
Насколько часто возникает необходимость перепрограммирования ЭБУ? - на первый взгляд, это следствие вмешательства различных тюнингистов, чем реальная неисправность.
ecurep Автор
В нашей практике довольно часто. Обновление блоков применяется не только по назначению, но и когда пытаются исправить какие-то проблемы по автомобилю. Также обновление может не сработать по причине просадки аккумулятора, невыполнению условий, необходимых при выполнении обновления (например, отсутствие ошибок в ЭБУ).