您的位置 首页 电子

AVR芯片的ISP全攻略 及 avr解锁

当误设了AVR的熔丝位是的ISP无法下程序了,那就需要对它进行解锁。我赞成的方法是用有源晶振或是用单片机模拟有源晶振(此方法适用于ATMEGA…

当误设了AVR的熔丝位是的ISP无法下程序了,那就需求对它进行解锁。

我拥护的办法是用有源晶振或是用单片机模仿有源晶振(此办法适用于ATMEGA16或32)
把有源晶振的输出脚接16的第一个时钟引脚,或,例如:用at89S52的ALE端接X1脚,将熔丝位设置为出厂设置在写入,就OK!

AVR芯片ISP全攻略
并行编程,最早的编程办法,功用最强壮,但需求衔接较多的引脚,一般需求12V~24V的高压,以示差异,下面称为 高压并行编程。
ISP(In System Programmability)在体系编程,简称为 串行下载
IAP(In Application Programing)在运用编程,BootLoader也是相似的意思
1 ISP尽管利用了SPI接口(破例:M64/M128为UASRT0接口,Tiny13等没有SPI接口)的引脚,但只在复位时起作用,并且下载完成后合格的下载器会主动断开端口的衔接,对正常作业时没有影响的( 在产品运用中,下载器一定是不会一向粘在上面的)。
2 尽管高压并行下载能修正任何熔丝位,但关于贴片封装来说是很不实际的,所以ISP接口是最常用的下载方式了
3 尽管IAP是一种新的晋级办法,但IAP程序自身也是要先用高压并行下载或ISP来烧进芯片里边才行
4 Tiny13等少管脚AVR芯片因为管脚实在太少了,有ISP,但没有[高压并行编程]而特制了[高压串行编程]
所以,产品上一般都留有ISP接口插座,或更省方位的—-留6个焊盘就行了
ISP的作业条件
1 芯片没有物理损坏
2 芯片的SPIEN熔丝位=0 使能ISP功用
3 芯片的RSTDISBL熔丝位=1 RESET引脚有用 (假设芯片有这个熔丝位)
4 线路正常———接错线? 短路?
5 下载器正常——-特别要考虑 连线的接触不良问题
6 电源
运转时钟 ISP时钟(有必要低于运转时钟的1/4)
4096Hz <1024Hz //很反常的用法,外接32.768KHz晶体+CKDIV8 ,不过AVRISP仍是供给了603Hz这个速度了
//另一简易解决办法是 下载时在32.768KHz晶体并联一个1MHz晶体,双龙的下载线就配有一个8MHz的石英晶体
32768Hz <8192Hz
128KHz < 32KHz //内部RC128KHz
1.0MHz <250KHz //默许值(包含8MHz+CKDIV8),所以AVRISP的ISP速度多为230KHz
8.0MHz <2000KHz
16.0MHz <4000KHz
运转时钟不等于震动器的频率,因为部分AVR芯片有体系时钟预分频器,能够对震动器进行1~256分频
CKDIV8熔丝位决议CLKPS位的初始值。
若CKDIV8未编程,CLKPS位复位为“0000”;若CKDIV8 已编程,CLKPS 位复位为“0011”,给出启动时分频因子为8
AVRISP可供给的ISP时钟 921.6KHz,230.4KHz, 57.6KHz,28.8KHz,4.0KHz, 603Hz
STK500可供给的ISP时钟 1.845MHz,460.8KHz,115.2KHz,57.6KHz,4.0KHz,1206Hz
时钟设定 ISP计划
内部RC 挑选适宜的ISP速度
外部RC 接上适宜的电阻和电容,挑选适宜的ISP速度。——弥补: 外部时钟源接到XTAL1
外部RC 根本就没有什么含义,频率精度/安稳度不高,本钱也没有下降,所以新的AVR芯片现已没有这个选项了。
各位网友要注意的是过错设定后弥补办法
外部晶体 接上适宜的晶体,挑选适宜的ISP速度。 ——弥补: 外部时钟源接到XTAL1
外部时钟 接上适宜的时钟源,挑选适宜的ISP速度。 ——弥补: 外部时钟源接到XTAL1
外部时钟源可所以 外部(4MHz)有源晶体输出,其他MCU的XTAL2脚,各种方波振荡电路(NE555)输出等
大部分AVR芯片的ISP端口是SCK,MOSI,MISO,RESET
而M64/M128的ISP端口是 SCK, PDI, PDO,RESET
并且M64/M128出厂默许兼容M103—-熔丝位M103C=0,许多新特性不能运用,程序也或许不能正常运转
—-因为C编译器一般默许主动把SP指向SRAM的结尾,M103=0x0FFFH, M64/M128=0x10FFH,必定犯错!
AVR的一切熔丝位均是:
1 未编程,多为不起作用的意思。
0 编程,多为起作用的意思。
根据可编程工艺的都是这样:
PROM/EEPROM/FLASH都是出厂时和擦除后变为全1(0xFF)的,要编程才干变成0。
反过来就是了,跟CE/OE/INT都是[低电平有用]相同,都是很常见。
在ISP形式下永久不能拜访(修正)SPIEN位,这是AVR芯片的硬件维护
有独立RESET脚的M16/M32/M64/M128等,在ISP形式下根本就就不会令ISP无效,无论如何修正熔丝位,都能康复正常。
M8/M48/M88/M168/Tiny系列有RSTDISBL熔丝位能够令导致RESET失效而令ISP无法作业外,其他状况都能康复正常。
一般来说,只需满意ISP的作业条件,再把XTAL1接到一个4MHz有源晶体的输出,基本是万试万灵的。
不要忘掉,并行高压编程的时钟信号也是从XTAL1导入方波信号的。
假如有源晶振的办法不可(除了ISPEN=0,RSTDISBL=0状况外),恐怕高压编程也未必能见效。
JTAG的影响(M16,M32,M128等):
JTAG能拜访 SPIEN 和 JTAGEN,要是不小心一起改成SPIEN=1,JTAGEN=1,将会导致MCU锁死,需求高压并行编程才干康复。
DebugWIRE的影响M48,M88,M168,T2313等,数据手册里边的材料不是很具体)
因为DebugWIRE运用RESET脚来通讯,所以跟ISP有所抵触
能够经过ISP或并行高压编程来使能DebugWIRE功用[即DWEN=0],使能DebugWIRE功用后,ISP功用失效。
能够经过DebugWIRE来封闭DebugWIRE功用[即DWEN=1],封闭DebugWIRE功用后,假如RSTDISBL=1,SPIEN=0,ISP功用有用。
比较特别的是 DebugWIRE调试中,断点的运用会下降Flash 数据回忆时刻 DebugWIRE调试用的器材不能发给终究客户。
JTAG MKII一起具有JTAG/DeubgWIRE/ISP三种功用,能够轻松完成DebugWIRE/ISP的切换。
(软件需求晋级到1.09版今后 即对应AVRstudio 4.12今后版别)
最新版别 JTAG MK2运用说明中文pdf(20051125)
规划运用debugWIRE 的体系时,有必要进行下面的查看:
? dW/(RESET) 的上拉电阻不得小于10kΩ。debugWIRE 并不需求上拉电阻
? 将 RESET 引脚与 VCC 直接衔接将无法作业
? 运用debugWIRE 时有必要断开与RESET 引脚衔接的%&&&&&%
? 有必要断开一切的外部复位源

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qiche/dianzi/273142.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部