当前位置: 首页 > news >正文

单片机烧录

在设计芯片的时候,关于烧录的环节是一个不得不考虑的问题。
我们首先排除掉,由外部直接硬件操控FLASH
的方案,这个方案有很多缺点。
1、每个IC使用的FLASH型号是各不相同的,每种型号的FLASH的烧录命令和流程都有差别,这会导致烧录器需要把所有的FLASH控制方式都内置,但是万一下次换了一个最新型号的FLASH呢?因此这种方式通用性非常低。
2、有些IC未必使用FLASH,有可能会采用OTP
(一次性编程),OTP一般是由芯片自己的内部寄存器来控制,直接写FLASH的烧录器在这根本就没办法用了
那现在换一个思路,让芯片自己控制自己的内部存储器,我用通信的方式把固件发给芯片,由它自己来完成这个过程呢?
很好,现在我们面临的问题变成了如何将这段烧录程序导入到芯片中运行这个问题了。
假如,芯片设计
的时候就是一个空片。那如何将程序下载进芯片中运行呢?
别怕,你用过JTAG吗?JTAG在调试的时候,是不是可以随便修改RAM,随便设置PC指针?
而且几乎所有的芯片硬件都是支持JTAG功能的吧?那这个问题就有解了。
我可以用JTAG将一段程序写入到RAM中,设置PC指针到程序的起始地址。这个程序是专门用来烧录FLASH和OTP的程序,我可以这样做:
1、将这个程序导入到RAM中
2、将固件的一部分内容导入到RAM的某个固定地址
3、设置PC到这个程序的起始地址,同时在程序结束的位置设置一个断点。
4、启动这个烧录程序,等待断点触发,往复2、3、4即可。
这个就是Keil
中的烧录算法的实现原理。而算法文件就是这个IC对应的烧录程序。
那现在,完全搞定烧录的问题吗? 不、还只完成了一半。这种方式还有好几个缺点:
1、烧录器硬件成本比较高
2、JTAG烧录器的控制复杂度和开发难度很高
3、对于安全程度非常高的芯片,JTAG很不安全
因此,我们能不能默认就将这段程序在芯片出厂的时候烧录或者固化到芯片上呢?同时采用成本更低和通用性更高的串口通信

所以,这段程序怎么放,有很多方案:
1、直接芯片投片的时候,由数字设计人员将固件硬编码
到晶圆上,芯片生产出来的时候,都会携带这个程序。这个的缺点就是,这段固件不可更改,固化前会经过大量的测试。
2、对于有OTP的芯片的话,会在芯片出厂测试时将这个程序烧录到OTP中,烧录方式用的就是JTAG
芯片的烧录方案,基本上就是这些了,对于那些你接触到的各种千奇百怪的烧录工具,其实也就是厂商自己定的通信协议
的不同导致的。

http://www.lryc.cn/news/427378.html

相关文章:

  • mysql实现分布式锁
  • MySQL快速使用
  • LeetCode41.缺失的第一个正数
  • ee trade:黄金投资与股票投资的区别
  • AI视频创作原理
  • idea vue项目删除node_modules时报文件损坏且无法读取,导致删除失败
  • Linux下编译安装-单机模式
  • RSSI定位算法
  • 布局管理(Layouts)-Qt-思维导图-学习笔记
  • 《区块链赋能游戏业:破解虚拟资产交易与确权难题》
  • 机器学习第十一章-特征选择与稀疏学习
  • C#中客户端直接引用服务端Proto文件
  • SiLM5932SHO系列SiLM5932SHOCG-DG 12A/12A强劲驱动电流能力 支持主动短路保护功能(ASC)单通道隔离门极驱动器
  • 本地项目上传github
  • 使用zip包来安装mysql
  • 嵌入式面经篇十——驱动开发
  • MySQL(四)——常用函数
  • C++ //练习 17.38 扩展上一题中你的程序,将读入的每个单词打印到它所在的行。
  • NC 丑数
  • Spring Boot 整合 Spring AI 实现项目接入ChatGPT(OpenAl的调用)
  • react中 useContext 和useReducer的使用
  • Android:动态更新app启动图标和应用名
  • 深入探讨 ElementUI 动态渲染 el-table
  • 数据炼金术:用Python爬虫精炼信息
  • C++第三十八弹---一万六千字使用红黑树封装set和map
  • ★ C++基础篇 ★ vector 类
  • 原生js用Export2Excel导出excel单级表头和多级表头数据方式实现
  • 急需翻译PDF文件怎么办?pdf翻译在线快速帮你解决
  • 线程安全的集合类和并发数据结构
  • Linux环境下运行介绍