class="markdown_views prism-atom-one-light">
需要实现远程升级单片机,正好在网上找到了官方提供的Bootloader程序及其对应的文档,赶快弄下来学习研究,这是对其文档的翻译。
翻译的资料是公开的,在这里下载
https://www.nxp.com/products/microcontrollers-and-processors/additional-processors-and-mcus/8-16-bit-mcus/16-bit-s12-and-s12x-mcus/ultra-reliable-s12xe-high-performance-automotive-and-industrial-microcontrollers:S12XE?tab=Documentation_Tab ,我想应该不会有什么版权问题,如涉及版权问题,请联系我删除文章。另感谢NXP提供的学习资料。
实测在MC9S12XEP100上可以使用,但是对我来说需要修改了一个小地方:
可能是由于这个程序的版本太老,PARTID没有考虑到我手头上这个XEP100的PARTID(0xCC95),这个PARTID甚至在芯片手册中都没有提到,不过问题也不大,测试后发现只要和0xCC94一样的处理方法即可了。想知道自己设备的PARTID是多少可以直接去看地址在1A-1B的这两个字节的值是多少。
修改方式为:
首先在PARTID.h中添加一个宏
……
#define MASK_0M48H 0xCC90 //1024k flash
#define MASK_1M48H 0xCC91
#define MASK_2M48H 0xCC92
#define MASK_3M48H 0xCC93
#define MASK_4M48H_5M48H 0xCC94
#define MASK_5M48H 0xCC95 // 添加的
……
然后在main.c 中的EraseFlash和ProgramFlash两个函数中的switch语句中分别添加一行case。
……
//S12XE 1024 k flash
case MASK_0M48H: //Falling to next case
case MASK_1M48H: //Falling to next case
case MASK_2M48H: //Falling to next case
case MASK_3M48H: //Falling to next case
case MASK_4M48H_5M48H:
case MASK_5M48H: // 添加的
if (!((ProgSRec.LoadAddr >= 0x700000 UL) && (ProgSRec.LoadAddr <= 0x7FEFDF UL)))
return (SRecRangeError);
break;
……
然后就能按照指南正常运行了。
180nm微控制器 S12(X)的串行Bootloader
by: Lukas Zadrapa and Ladislav Makovic
Technical Information Center
Roznov
Czech Republic
译者注:译者博客(
http://blog.csdn.net/lin_strong ),转载请保留这条。此为官方文档AN4258,仅供学习交流使用,请勿用于商业用途。
介绍
这篇应用笔记介绍了为 基于180nm技术的 S12和S12X微控制器家族 编写的一个bootloader程序的运行和使用。
使用这bootloader可以很方便地实现生产中编程或者“在线系统(in-system)”编程,特别是应用于那些 无法使用HCS12背景调试接口(BDM)的场合。用户必须在生产准备阶段或在编程供应商那把bootloader预先烧写进S12(X)。Bootloader会留存在MCU中以供未来使用。
这个bootloader实现支持通过SCI串口将用户软件下载进MCU flash内存中。
这篇文档中描述的bootloader只是一个示例,由其产生的任何后果我们概不负责,并且我们不提供技术支持。
硬件兼容性
有两个版本的bootloader:
第一个是为S12系列(S12P、S12HY、S12HA和S12G)写的。
第二个是为S12X系列(S12XS、S12XE和S12XF)写的。
除非特别标注,这篇应用笔记中的内容适用于所有两个版本。
这个bootloader没有为最小的设备进行优化。因此,不支持MC9S12GN16。
当前不支持对D-Flash或说EEPROM的编程。
需求
为了成功运行这个bootloader,需要满足一些需求。
输入引脚
有许多种方式确定是要启动bootloader还是用户应用程序。比如可以选择通过判断输入引脚的状态、通过EEPROM内存中的某个变量的状态或者通过从通讯接口收到的命令。
这个bootloader使用第一种方式。在重置之后,bootloader会使能PP0引脚的上拉寄存器并且读取PP0引脚的状态以确定是否你想要运行bootloader。
可能这个引脚的外部电路是这样的:一个开关、跳线或者一个按钮与可选的上拉电阻器。
图 1.引脚连接
串行接口
所有的S12(X)微控制器都有集成串行通信接口。注意,需要RS232电平转换器以与PC通信。
默认的,串行通信会设为这个格式:
8数据位
1起始位
1停止位
0校验位
Xon/Xoff 流控制
默认的波特率是9600。可以在bootloader的菜单中修改其为38400、57600或115200 bps。
终端模拟程序
可以使用串口调试助手来与PC通信。这个串口调试器必须支持串行COM口通信、Xon/Xoff流控制以及必须支持发送文本文件。
振荡器
S12微控制器不需要外部晶振。bootloader会使用S12微控制器内部的一个1MHz的RC震荡电路。Bootloader设置总线频率为25MHz以支持高速率通信。
S12X微控制器需要晶振或者外部振荡器。在bootloader内配置PLL以达到40MHz的总线时钟频率。这是为了提高通信速率以加快代码下载速度。
功能描述
bootloader的运作方式很直白。这个部分仅描述了最重要的和最特殊的那些。
运作
bootloader会处理所有的重置向量。在重置后,会调用bootloader的startup例程。首先,bootloader会读取PP0引脚的状态。如果引脚值为逻辑0,bootloader就会开始工作。如果是逻辑1,就会调用用户应用程序的startup例程。如果用户应用的重置向量不可用(地址0xEFFE-0xEFFF上的字被擦除),那不管怎么样bootloader都会开始运行。用户可以重写这个代码以更改启动条件。
中断向量
在用户应用用到了中断的情况下,需要使用IVBR寄存器重定位中断向量表。bootloader被放在最高的一个地址块中,地址0xF000-0xFFFF。这个区域是受保护的,所以用户的应用程序不能把中断向量表放在默认的地址0xFF10-0xFFFF。这种方案的优点是bootloader不会受到电源故障的影响,这可能会在重写中断和重置向量时发生。
掩码组与part ID
每个硅掩码组都有一个特定的part ID,位于两个8位寄存器中,PARTIDH和PARTIDL中,地址在0x001A和0x001B。
当要把s-record编程到flash内存中去时,bootloader会检查是否地址位于物理flash内存上。当地址无效时,会返回一个错误。
在bootloader工程的PartID.h文件中可以找到当前支持的掩码组和part ID。
用户指南
这个部分描述了使用这个bootloader的每一步。
配置S12的bootloader
在CodeWarrior for S12(X)集成开发环境中打开Bootloader_S12工程。bootloader在v5.0和v5.1中测试过了。
如图2选择target。 图 2.S12 target选项
通过引脚PP0来决定是启动bootloader还是用户应用程序。如果PP0是低电平,就会启动bootloader,如果PP0是高电平,就会启动用户应用程序。如果这个默认配置不好用,用户可以在Start12.s中重写这个代码。
配置S12X的bootloader
在CodeWarrior for S12(X)集成开发环境中打开Bootloader_S12X工程。bootloader在v5.0和v5.1中测试过了。
打开文件Config.h并进行如下设置: 设置FLASH_PRESCALER(加载到FCLKDIV寄存器中的值)以让flash运行频率在800-1050kHz间,如参考手册所述。 设置PLL以使总线频率达到40MHz。可以利用这个应用笔记附带的PLL计算器。
如图3选择target。 图 3.S12X target选项
通过引脚PP0来决定是启动bootloader还是用户应用程序。如果PP0是低电平,就会启动bootloader,如果PP0是高电平,就会启动用户应用程序。如果这个默认配置不好用,用户可以在StartS12X.s中重写这个代码。
Bootloader指南
编译工程并通过BDM设备下载bootloader到MCU中去。
打开串口调试助手。设置波特率为9600,1个起始位,8数据位,1数据位,流控制Xon/Xoff。
用串行连接线连接PC和开发板。
让PP0为低电平,然后重启MCU。
bootloader就启动了,然后你会在串口调试助手中看到如下信息。见图4。 图 4.最初的界面
输入“a”以擦除flash内存。第一次不需要这一步,因为flash已经被BDM设备擦除了。
输入“b”以编程flash。
现在将用到的S-record作为文本文件发送—见图5。浏览被下载到MCU中的S-record。 为了测试目的,使用附加到这个应用笔记上的示例S-records。S-records必须使用特定的格式。请参考章节6,“怎么写用户应用程序”以及章节7,“怎么转换将被bootloader下载的S-Record”。 图 5.发送文本文件
确定对话框和S-record已经被下载到MCU中去了。一个星号(*)代表编程成功了一行。见图6。 图 6.下载用户应用
怎么写用户应用程序
你必须确保用户应用程序不会碰到bootloader的地址范围(0xF000-0xFFFF)。
1. 在CodeWarrior for S12(X)集成开发环境中创建一个新工程。
2. 打开.prm文件
3. 把segment ROM_C000从原来的0xC000-0xFEFF改成0xC000-0xEFDF。这是因为地址0xF000-0xFFFF会放着bootloader,而0xEFE0-0xEFFF会用作用户应用的重置向量。
如果使用了中断:
4. 把segment ROM_4000从原来的0x4000-0x7FFF改成0x4000-0x7F0F。0x7F10-0x7FFF会被用于重定位中断向量表。
5. 如附件示例应用那样创建一个中断向量表,并对应的设置IVBR寄存器。IVBR设置中断向量表的基地址,这种情况下必须被设置为0x7F。
怎么转换将被bootloader下载的S-Record
bootloader接受使用全局(线性)地址的s-records。所有的records必须被对齐为32字节,长度也必须是32字节。
1. 打开SRecCvt工具(SRecCvt-GUI.exe)
2. 选择使用的MC9S12设备(取决你用的是哪个),选择Memory为Flash,选择Operation为Convert File。
3. 选择输入文件格式为Banked,输出文件格式为Linear。
4. 设置S-Record Size为32.
5. 浏览输入文件(由CodeWarrior生成的S19文件)并选择输出文件。
6. 点击Convert按钮。
图 7.SRecCvt
怎么合并用户应用和bootloader
用户应用可以被独立地开发,或说,不带有bootloader。用户应用可以被加载进微控制器并可以由BDM设备来直接的调试。然而,出于生产目的,将用户应用与bootloader合并到一起是很有价值的,这样就可以在单个s-record文件中把所有东西都下载进微控制器了。
这是推荐的流程:
1. 打开按照第6章“怎么写用户应用程序”中所述那样创建的用户应用程序。
2. 把一个用户应用程序重置向量放到地址0xEFFE,这样bootloader就可以使用这个向量了。拷贝以下三行到main.c中:
extern void near _Startup(void) typedef void (*near tFunc)(void) const tFunc rst_vec @0xEFFE = _Startup
3. 移除原先的用户应用程序重置向量。
在Project.prm文件中注释掉这行:
//VECTOR 0 _Startup
4. 复制准备好了的bootloader .s19文件到 ..user_application_projectin下。比如,s-record文件可以被重命名为bootloader.s19
5. 链接这个文件到用户应用程序中。
在Project.prm的开头加上这个命令:
HEXFILE bootloader.s19
6. 添加如下命令到文件..user_application_projectcmdP&E_Multilink_CyclonePro_Preload.cmd中:
FLASH NOUNSECURE
这个命令能确保烧写器不会在MCU编程过程中自动地改变0xFF0F处的flash安全字节为一个不安全状态(0xFE),这样,这个phrase(0xFF08-0XFF0F)就可以被加载定义在bootloader中的值了。如果不使用这个命令,会导致在这个phrase发生ECC错误,芯片会被保护,并且flash会被完全保护。
7. 编译项目。最终的s-record就准备好被BDM设备下载入微控制器了。
测试
这个bootloaders在这些开发板上测试成功过:
DEMO9S12PFAME
DEMO9S12HY64
TWR-S12G128
DEMO9S12XSFAME
EVB9S12XEP100
Zip文件的内容
所有提到的工程和工具都在这篇应用笔记相关的zip文件中。
Bootloader_S12 — S12微控制器的bootloader工程。
Bootloader_S12X — S12X微控制器的bootloader工程。
Demo_applications — 示例怎么写用户应用程序的工程。
Coverted_srecords — 源于Demo_applications的已经被SRecCvt工具转换好的S-Records。这些S-Records可以由bootloader下载进MCU中。
Demo_applications_with_linked_bootloader — 包含bootloader的用户应用程序。
SRecCvt — 用于转换S-Record的工具。
S12XE_PLL_Calculator — 帮助设置PLL模块的工具。