网站首页 > 技术教程 正文
嵌入式工程师在求职时,经常会被要求熟悉Bootloader,在嵌入式开发工作中,这是一个非常基本且重要的功能,所以一般公司都已经开发好了,初学者往往只会应用而不知其原理。今天我就和大家聊聊Bootloader原理,加深大家的印象。
操作模式
大多数Bootloader都包含两种不同的操作模式:
(1)启动加载模式
在这种模式下,Bootloader从目标机的某个固态存储设备上将操作系统加载到RAM中运行,整个过程并没有用户的介入。这种模式是Bootloader的正常工作模式,因此在嵌入式产品发布时,Bootloader必须工作在这种模式下。
(2)下载模式
在这种模式下,目标机上的Bootloader将通过串口、USB、以太网等通信手段从开发主机上下载芯片程序等到RAM中,实现在线升级功能。笔者的工作大多是以应用开发为主,经常使用的是下载模式;这个也是众多开发者经常接触到的模式。
大家常见的消费类电子产品,如手机,手环,机顶盒;工控类电子产品如变频器,UPS,太阳能光伏逆变器等等,都要经常更新软件,如客户需求,安规升级等等。由于这些产品都要在户外运行,都是防尘防水,IP65等级,这个时候再拆机壳去更新程序是非常不划算的,所以一般使用U盘,外部485本地升级或GPRS/WIFI等工具进行远程升级,可靠又方便,极大节省了人力成本,也减少了拆机壳带来的潜在风险。
在线升级
首先我们要将芯片的外部FLASH分两层,Application(应用层)和Bootloader(烧录层);Bootloader判断App是否完整且接受上位机发送的升级文件,对自己进行升级。
以STM32F103VCT6为例,芯片FLASH地址为:0x0800 0000 - 0x0804 0000,共256K;
分配Bootloader地址为:0x0800 0000 - 0x0800 2000,占用8K
分配Application地址为:0x0800 2000 - 0x0804 0000,占用248K
在Applicaiton程序的起始地址和结束地址写固定字符'SPZG'。
程序刚上电,从0x0800 0000开始执行,此时我们可以读取出Applicaiton的起始和结束地址的字符是否为'SPZG';如果是则使用Jump_To_Application = (pFunction) JumpAddress跳到application层;如果不是,则停留在Bootloader等待通讯再次升级它;
程序运行过程中,接收到升级芯片的指令,将Application结尾地址的'SPZG'擦除,然后使用软件重启芯片。__set_FAULTMASK(1);//关闭所有中断 NVIC_SystemReset();//复位函数;程序重启后就和刚上电的情况一样。
Bootloader程序
在Bootloader里边我们只需要干两件是,一是判断Applicaiton是否完整;二是接收上位机指令去升级Applicaiton;升级协议自己和上位机定义清楚就好,写Application前需要将FLASH擦除;注意:仅仅擦除Application地址,万万不可擦除Bootloader程序,否则升级中碰到断电的情况,就无法再次升级了;
对于空白芯片,使用J-LINK或XDS200将FLASH写入芯片中,之后就可以在线升级,在线升级只升级Application部分,所以书写Bootloader一定要注意,不能出错;Bootloader出问题就必须通过JLINK/XDS200更新了;由于Bootloader只是升级功能,多测试就可以找出潜在的风险,一般写好之后就不修改了,只是修改Application部分;这也是大多数新手不明白原理的原因。
以上就是笔者关于Bootloader的总结,经验尚浅,如有不对之处希望头友多多指教;对于Bootloader,你明白了吗,一起聊聊吧?
猜你喜欢
- 2024-10-23 基于S12 MagniV系列的LIN Bootloader设计
- 2024-10-23 怎么使用USBasp给arduino烧写bootloader?
- 2024-10-23 腾讯 ROG 游戏手机 6 / Pro 公开内核源码并支持解锁 bootloader
- 2024-10-23 浅谈基于uds的bootloader设计(简要概述u-boot的主要功能)
- 2024-10-23 Bootloader引导程序uboot(bootice 引导)
- 2024-10-23 基于CAN总线的Bootloader设计与实现
- 2024-10-23 Rust语言开发操作系统-第二章(最小化内核)
- 2024-10-23 基于RT-Thread完整版搭建的极简Bootloader
- 2024-10-23 海信阅读手机A9现可解锁bootloader并获取root权限
- 2024-10-23 三星警告Galaxy Z Fold 3解锁bootloader将失去相机功能
你 发表评论:
欢迎- 最近发表
-
- linux日志文件的管理、备份及日志服务器的搭建
- Linux下挂载windows的共享目录操作方法
- Linux系统中的备份文件命令(linux系统中的备份文件命令有哪些)
- 麒麟KYLINOS|通过不同方法设置用户访问文件及目录权限
- 「Linux笔记」系统目录结构(linux目录的结构及含义)
- linux中修改归属权chown命令和chgrp命令
- 工作日报 2021.10.27 Android-SEAndroid权限问题指南
- Windows和Linux环境下,修改Ollama的模型默认保存路径
- 如何强制用户在 Linux 上下次登录时更改密码?
- 如何删除Linux文件夹中除某些扩展名之外的所有文件?
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)