当误设了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 引脚衔接的%&&&&&% ? 有必要断开一切的外部复位源 |