汽车电子学习笔记---基于UDS的Bootloader

汽车电子学习笔记—基于UDS的Bootloader

Bootloader 又称引导加载程序,是系统上电之后运行的第一段代码,其主要用于软件更新。在每次上电/复位后,ECU首先执行Bootloader代码,Bootloader会执行一些基本的初始化,然后再检查刷新请求标志位是否为有效,如果刷新请求标志位有效,则停留在bootloader模式中进行软件升级操作。如果当前没有刷新请求,即刷新请求标志位为无效,则检查应用软件的状态。如果应用软件是有效的,则执行APP应用程序代码,如果应用软件无效,则继续执行Bootloader代码,停留在Bootloader模式中。
汽车电子学习笔记---基于UDS的Bootloader_第1张图片

Bootloader与App关系:
1)Bootloader和App分别是两个完整的MCU软件工程,各自都由自己的启动代码、main()函数、链接文件、外设驱动程序和中断向量表。
2)bootloader和App NvM的地址空间分配必须分开独立,不能重叠。
3)bootloader必须使用MCU默认的中断向量表,因为每次复位后MCU都是从其默认中断向量表的复位向量取地址执行的;应用程序的中断向量必须进行偏移。
汽车电子学习笔记---基于UDS的Bootloader_第2张图片

Bootloader 需支持功能点:
1、通信
与上位机下载端建立可靠的总线通信以获取要更新应用程序:CAN驱动,CAN Driver模块实现CAN报文的收发。
2、Flash Driver
用于操作Flash的擦除、写入和读取功能。主要包括Flash硬件初始化,Flash block块的读写操作及擦除功能。基于软件运行安全性考虑,Flash diver一般不会存在放在flash中,避免正常程序在发生错误时可能的非法修改。在需要执行应用程序或应用数据需要时,首先将Flash diver下载至ram中,然后执行相应的更新。
3、协议
1)传输协议:ISO 15765-2,
传输层主要是提供数据的组包和拆包功能服务,能够实现报文的分段传输及数据传输过程中的错误检测和超时处理。
2)UDS协议:ISO 14229-1,协议中定义的Bootloader程序刷写流程,包括:诊断会话切换、安全状态切换、标识符读写、程序刷写和ECU复位等。
汽车电子学习笔记---基于UDS的Bootloader_第3张图片

4、Watch Dog
监控Bootloader超时或者死机,对ECU复位。
5、NvM驱动
包括对NvM的读写操作支持。

Bootloader升级过程:
ISO 14229-1 规范中定义编程升级阶段分为两个阶段:
1)Programming phase #1 — download of application software and/or application data
2)Programming phase #2 — Server configuration (optional)
而Programming phase #1又细分为两个阶段:Optional Pre-Programming step — Setup of vehicle network for programming(预编程阶段)和 Server Programming step — Download of application software and application data(主编程阶段)

预编程阶段:
汽车电子学习笔记---基于UDS的Bootloader_第4张图片

1、进入extendedDiagnosticSession扩展会话模式:$10 03
2、一般接着会执行31服务,对刷写条件进行检查,例如低压电是否在正常范围内,档位是否为P档,车速是否为零等;(此部可选)
3、关闭DTC:$85 02,为了防止刷写过程中其他ECU节点误触发DTC,通过85服务关闭所有DTC。
4、禁止非诊断报文的发送和接收:$28 03 03,为了提高刷写速度,降低刷写程序时总线负载率,通过28服务关闭无关报文,比如应用报文和网络管理报文;
5、设置波特率:$87 01,为了减少刷写的时间,可以通过87服务提高CAN总线的波特率。

主编程阶段:
汽车电子学习笔记---基于UDS的Bootloader_第5张图片

1、进入编程会话模式:$10 02
2、安全访问检查:$27 XX,进行安全解锁,确保只有合法的诊断仪能对ECU进行下载操作。
3、写入数据:$2E XX,将指纹信息和软件刷新日期写入到ECU中。
4、擦除Memory:$31 01,启动31例程控制服务,执行擦除ECU内存。
5、下载数据:请求下载($34)、传输数据($36)、请求退出传输($37),应用软件或者数据的每一个连续的数据块下载都遵循请求下载->传输数据->请求退出的顺序,单个应用软件或数据块可能需要多个数据传输($36)请求报文来完成传输。
6、检查一致性和数据完整性:$31,执行31服务检查逻辑块的完整性和一致性。
7、若有更多块需要下载,重新执行31(擦除内存)再执行34-36-37-31(校验)服务。
8、复位:$11 01,通过ECU复位服务请求将使ECU结束重编程过程,返回到正常的操作模式。

后编程阶段-Programming phase #2
1、10服务切换到03扩展会话。
2、执行28服务和85服务,使能非诊断报文和DTC。这是对整车网络进行操作的,一般都是以功能寻址的方式来发送。注意先执行28,后执行85,避免DTC误报。
3、清除诊断信息:$14 FF FF FF。
4、10服务切换到01默认会话模式或者11 01 执行服务。
汽车电子学习笔记---基于UDS的Bootloader_第6张图片
汽车电子学习笔记---基于UDS的Bootloader_第7张图片

你可能感兴趣的:(汽车产品研发,单片机,mcu,单片机)