(1)在AVR的器材手册中,对熔丝位运用已编程(Programmed)和未编程(Unprogrammed)界说熔丝位的状况,“Unprogrammed”表明熔丝状况为“1”(制止);“Programmed”表明熔丝状况为“0”(答应)。因而,装备熔丝位的进程实践上是“装备熔丝位成为未编程状况“1”或成为已编程状况“0””。
(2)在运用经过挑选打钩“√”方法确认熔丝位状况值的编程东西软件时,请首要细心阅读软件的运用阐明,弄清楚“√”表明设置熔丝位状况为“0”仍是为“1”。
(3)运用CVAVR中的编程下载程序时应特别留意,由于CVAVR编程下载界面初始翻开时,大部分熔丝位的初始状况界说为“1”,因而不要运用其编程菜单选项中的“all”选项。此刻的“all”选项会以熔丝位的初始状况界说来装备芯片的熔丝位,而实践上其往往并不是用户所需求的装备成果。假如要运用“all”选项,应先运用“read->fusebits”读取芯片中熔丝位实践状况后,再运用“all”选项。
(4)新的AVR芯片在运用前,应首要检查它熔丝位的装备状况,再依据实践需求,进行熔丝位的装备,并将各个熔丝位的状况记载存案。
(5)AVR芯片加密今后仅仅是不能读取芯片内部Flash和E2PROM中的数据,熔丝位的状况依然能够读取但不能修正装备。芯片擦除指令是将Flash和E2PROM中的数据铲除,并一起将两位确认位状况装备成“11”,处于无确认状况。但芯片擦除指令并不改动其它熔丝位的状况。
(6)正确的操作程序是:在芯片无确认状况下,下载运转代码和数据,装备相关的熔丝位,最终装备芯片的确认位。芯片被确认后,假如发现熔丝位装备不对,有必要运用芯片擦除指令,铲除芯片中的数据,并免除确认。然后从头下载运转代码和数据,修正装备相关的熔丝位,最终再次装备芯片的确认位。
(7)运用ISP串行方法下载编程时,应装备SPIEN熔丝位为“0”。芯片出厂时SPIEN位的状况默以为“0”,表明答应ISP串行方法下载数据。只要该位处于编程状况“0”,才干够经过AVR的SPI口进行ISP下载,假如该位被装备为未编程“1”后,ISP串行方法下载数据当即被制止,此刻只能经过并行方法或JTAG编程方法才干将SPIEN的状况从头设置为“0”,敞开ISP。通常状况下,应坚持SPIEN的状况为“0”,答应ISP编程不会影响其引脚的I/O功用,只要在硬件电路规划时,留意ISP接口与其并接的器材进行必要的阻隔,如运用串接电阻或断路跳线等。
(8)当你的体系中,不运用JTAG接口下载编程或实时在线仿真调试,且JTAG接口的引脚需求作为I/O口运用时,有必要设置熔丝位JTAGEN的状况为“1”。芯片出厂时JTAGEN的状况默以为“0”,表明答应JTAG接口,JTAG的外部引脚不能作为I/O口运用。当JTAGEN的状况设置为“1”后,JTAG接口当即被制止,此刻只能经过并行方法或ISP编程方法才干将JTAG从头设置为“0”,敞开JTAG。
(9)一般状况下不要设置熔丝位把RESET引脚界说成I/O运用(如设置ATmega8熔丝位RSTDISBL的状况为“0”),这样会形成ISP的下载编程无法进行,由于在进入ISP方法编程时前,需求将RESET引脚拉低,使芯片先进入复位状况。
(10)运用内部有RC振动器的AVR芯片时,要特别留意熔丝位CKSEL的装备。一般状况下,芯片出厂时CKSEL位的状况默以为运用内部1MHz的RC振动器作为体系的时钟源。假如你运用了外部振动器作为体系的时钟源时,不要忘掉首要正确装备CKSEL熔丝位,不然你整个体系的守时都会出现问题。而当在你的规划中没有运用外部振动器(或某钟特定的振动源)作为体系的时钟源时,千万不要误操作或过错的把CKSEL熔丝位装备成运用外部振动器(或其它不同类型的振动源)。一旦这种状况发生,运用ISP编程方法则无法对芯片操作了(由于ISP方法需求芯片的体系时钟作业并发生守时操控信号),芯片看上去“坏了”。此刻只要运用取下芯片运用并行编程方法,或运用JTAG方法(假如JTAG为答应时且方针板上留有JTAG接口)来挽救了。另一种挽救的方法是:测验在芯片的晶体引脚上暂时人为的叠加上不同类型的振动时钟信号,一旦ISP能够对芯片操作,当行将CKSEL装备成运用内部1MHz的RC振动器作为体系的时钟源,然后再依据实践状况从头正确装备CKSEL。
(11)运用支撑IAP的AVR芯片时,假如你不运用BOOTLOADER功用,留意不要把熔丝位BOOTRST设置为“0”状况,它会使芯片在上电时不是从Flash的0x0000处开端履行程序。芯片出厂时BOOTRST位的状况默以为“1”。关于BOOTRST的装备以及BOOTLOADER程序的规划与IAP的运用请参阅本章相关内容。
ATmega128中重要熔丝位的装备
上一末节介绍了装备AVR熔丝位的关键和留意事项,本末节把在一般状况下运用ATmega128时,几个重要的熔丝位装备状况进行阐明。
(1)熔丝位M103C。M103C的装备将设定ATmega128是以ATmega103兼容方法作业运转仍是以ATmega128自身的方法作业运转。ATmega128在出厂时M103C默许状况为“0”,即默许以ATmega103兼容方法作业。当用户体系规划使芯片以ATmega128方法作业时,应首要将M103C的状况装备为“1”。
(2)CLKSEL0..3。CLKSEL0、CLKSEL1、CLKSEL2、CLKSEL3用于挑选体系的时钟源。有五种不同类型的时钟源可供挑选(每种类型还有细的区分)。芯片出厂时的默许状况为CLKSEL3..0和SUT1..0分别是“0001”和“10”。即运用内部1MHzRC振动器,运用最长的发动延时。这确保了不管外部振动电路是否作业,都能够进行开端的ISP下载。关于CLKSEL3..0熔丝位的改写需求非常稳重,由于一旦改写过错,会形成芯片无法发动,见上一末节第10点阐明。
(3)JTAGEN。假如不运用JTAG接口,应将JTAGEN的状况设置为“1”,即制止JTAG,JTAG引脚用于I/O口。
(4)SPIEN。SPI方法下载数据和程序答应,默许状况为答应“0”。一般保存其状况。
(5)WDTON。看门狗的守时器一直敞开。WDTON默以为“1”,即制止看门狗的守时器一直敞开。假如该位设置为“0”后,看门狗的守时器就会一直翻开,不能被内部程序操控了,这是为了避免当程序跑飞时,不知道代码经过写寄存器将看门狗守时器关断而规划的(虽然关断看门狗守时器需求特别的方法,但它确保了更高的可靠行)。
(6)EESAVE。履行擦除指令时是否保存E2PROM中的内容,默许状况为“1”,表明E2PROM中的内容同Flash中的内容一起擦除。假如该位设置为“0”,对程序进行下载前的擦除指令只会对FLASH代码区有用,而对E2PROM区无效。这关于期望在体系更新程序时,需求保存E2PROM中数据的状况下是非常有用的。
(7)BOOTRST。决议芯片上电起动时,第一条履行指令的地址。默许状况为“1”,表明起动时从0x0000开端履行。假如BOOTRST设置为“0”,则起动时从BOOTLOADER区的开端地址处开端履行程序。BOOTLOADER区的巨细由BOOTSZ1和BOOTSZ0决议,因而其首地址也随之改变。
(8)BOOTSZ1和BOOTSZ0:这两位确认了BOOTLOADER区的巨细以及其开端的首地址。默许的状况为“00”,表明BOOTLOADER区为4096字,开端首地址为0xF000。
(9)引荐用户运用ISP方法装备熔丝位。装备东西选用BASCOM-AVR(网上下载试用版,它对ISP下载无限制),和STK200/STK300兼容的下载电缆(见第四章内容)。
注:不同AVR的熔丝也不同,运用前有必要细心检查芯片手册。
要注重手册学习,不仅是把握怎样运用,也是从根本上知道和把握原理和结构。关于硬件工程师来将,数据手册是真实的“经文”,其它都是“修练经历”。不熟读“经文”,你无法修_炼成“仙”的。这也是《M128》、《M8》的意图之一!
mega8熔丝位:1:未编程(不选中)0:编程(选中)
***************************************
熔丝位 阐明 缺省设置
***************************************
RSTDISBL: 复位或I/O功用挑选 1 1:复位功用;0:I/O功用(PC6)
WDTON: 看门狗开关 1 1:看门狗翻开(经过WDTCR答应);0:看门狗制止
SPIEN: SPI下载答应 0 1:SPI下载制止;0:SPI下载答应(注:当运用SPI编程时,该项不可用)
EEAVE: 烧录时EEPROM数据保存 1 1:不保存;0:保存
BODEN: BOD功用操控 1 1:BOD功用制止;0:BOD功用答应
BODLEVEL: BOD电平挑选 1 1:2.7V电平;0:4.0V电平
BOOTRST: 复位进口挑选 1 1:程序从0x0000地址开端履行;0:程序从引导区确认的进口地址开端履行
***************************************
BOOTSZ1/0: 引导程序巨细及进口 00
00:1024Word/0xc00;
01:512Word/0xe00;
10:256Word/0xf00;
11:128Word/0xf80
***************************************
BLB02/01: 程序区指令位挑选 11
11:SPM和LPM指令都答应履行
10:SPM指令制止写程序区
01:引导区LPM指令制止读取程序区内容;假如中止向量界说在引导区,则制止该中止在程序区履行。
00:SPM指令制止写程序区;引导区LPM指令制止读取程序区内容;假如中止向量界说在引导区,则制止该中止在程序区履行。
***************************************
BLB12/11: 引导区指令位挑选 11
11:SPM和LPM指令都答应履行
10:SPM指令制止写引导区
01:程序区LPM指令制止读取引导区内容;假如中止向量界说在程序区,则制止该中止在引导区履行。
00:SPM指令制止写引导区;程序区LPM指令制止读取引导区内容;假如中止向量界说在程序区,则制止该中止在引导区履行。
***************************************
LB2/1: 程序区加密位挑选 11
11:未加密
10:程序和EEPROM编程功用制止,熔丝位确认
00:程序和EEPROM编程及校验功用制止,熔丝位确认
(注:先编程其他熔丝位,再编程加密位)
***************************************
CKSEL3/0: 时钟源挑选 0001
CKOPT: 晶振挑选 1
SUT1/0: 复位发动时刻挑选 10
***************************************
CKSEL3/0=0000:外部时钟,CKOPT=0:答应芯片内部XTAL1管脚对GND接一个36PF电容;CKOPT=1:制止该电容
—————-
CKSEL3/0=0001-0100:现已校准的内部RC振动,CKOPT总为1
0001:1.0M
0010:2.0M
0011:4.0M
0100:8.0M
—————-
CKSEL3/0=0101-1000:外部RC振动,CKOPT=0:答应芯片内部XTAL1管脚对GND接一个36PF电容;CKOPT=1:制止该电容
0101:<0.9M
0110:0.9-3.0M
0111:3.0-8.0M
1000:8.0-12.0M
—————-
CKSEL3/0=1001:外部低频晶振,CKOPT=0:答应芯片内部XTAL1/XTAL2管脚对GND各接一个36PF电容;CKOPT=1:制止该电容
—————-
CKSEL3/0=1010-1111:外部晶振,陶瓷振动子,CKOPT=0:高起伏振动输出;CKOPT=1:低起伏振动输出
101X:0.4-0.9M
110X:0.9-3.0M
111X:3.0-8.0M
***************************************
SUT1/0: 复位发动时刻挑选
当挑选不同晶振时,SUT有所不同。
三、时钟挑选一览表
时钟源 发动延时 熔丝
外部时钟 6 CK + 0 ms CKSEL=0000 SUT=00
外部时钟 6 CK + 4.1 ms CKSEL=0000 SUT=01
外部时钟 6 CK + 65 ms CKSEL=0000 SUT=10
内部RC振动1MHZ 6 CK + 0 ms CKSEL=0001 SUT=00
内部RC振动1MHZ 6 CK + 4.1 ms CKSEL=0001 SUT=01
内部RC振动1MHZ 6 CK + 65 ms CKSEL=0001 SUT=10
内部RC振动2MHZ 6 CK + 0 ms CKSEL=0010 SUT=00
内部RC振动2MHZ 6 CK + 4.1 ms CKSEL=0010 SUT=01
内部RC振动2MHZ 6 CK + 65 ms CKSEL=0010 SUT=10
内部RC振动4MHZ 6 CK + 0 ms CKSEL=0011 SUT=00
内部RC振动4MHZ 6 CK + 4.1 ms CKSEL=0011 SUT=01
内部RC振动4MHZ 6 CK + 65 ms CKSEL=0011 SUT=10
内部RC振动8MHZ 6 CK + 0 ms CKSEL=0100 SUT=00
内部RC振动8MHZ 6 CK + 4.1 ms CKSEL=0100 SUT=01
内部RC振动8MHZ 6 CK + 65 ms CKSEL=0100 SUT=10
外部RC振动≤0.9MHZ 18 CK + 0 ms CKSEL=0101 SUT=00
外部RC振动≤0.9MHZ 18 CK + 4.1 ms CKSEL=0101 SUT=01
外部RC振动≤0.9MHZ 18 CK + 65 ms CKSEL=0101 SUT=10
外部RC振动≤0.9MHZ 6 CK + 4.1 ms CKSEL=0101 SUT=11
外部RC振动0.9-3.0MHZ 18 CK + 0 ms CKSEL=0110 SUT=00
外部RC振动0.9-3.0MHZ 18 CK + 4.1 ms CKSEL=0110 SUT=01
外部RC振动0.9-3.0MHZ 18 CK + 65 ms CKSEL=0110 SUT=10
外部RC振动0.9-3.0MHZ 6 CK + 4.1 ms CKSEL=0110 SUT=11
外部RC振动3.0-8.0MHZ 18 CK + 0 ms CKSEL=0111 SUT=00
外部RC振动3.0-8.0MHZ 18 CK + 4.1 ms CKSEL=0111 SUT=01
外部RC振动3.0-8.0MHZ 18 CK + 65 ms CKSEL=0111 SUT=10
外部RC振动3.0-8.0MHZ 6 CK + 4.1 ms CKSEL=0111 SUT=11
外部RC振动8.0-12.0MHZ 18 CK + 0 ms CKSEL=1000 SUT=00
外部RC振动8.0-12.0MHZ 18 CK + 4.1 ms CKSEL=1000 SUT=01
外部RC振动8.0-12.0MHZ 18 CK + 65 ms CKSEL=1000 SUT=10
外部RC振动8.0-12.0MHZ 6 CK + 4.1 ms CKSEL=1000 SUT=11
低频晶振(32.768KHZ) 1K CK + 4.1 ms CKSEL=1001 SUT=00
低频晶振(32.768KHZ) 1K CK + 65 ms CKSEL=1001 SUT=01
低频晶振(32.768KHZ) 32K CK + 65 ms CKSEL=1001 SUT=10
低频石英/陶瓷振动器(0.4-0.9M) 258 CK + 4.1 ms CKSEL=1010 SUT=00
低石英/陶瓷振动器(0.4-0.9M) 258 CK + 65 ms CKSEL=1010 SUT=01
低石英/陶瓷振动器(0.4-0.9M) 1K CK + 0 ms CKSEL=1010 SUT=10
低石英/陶瓷振动器(0.4-0.9M) 1K CK + 4.1 ms CKSEL=1010 SUT=11
低石英/陶瓷振动器(0.4-0.9M) 1K CK + 65 ms CKSEL=1011 SUT=00
低石英/陶瓷振动器(0.4-0.9M) 16K CK + 0 ms CKSEL=1011 SUT=01
低石英/陶瓷振动器(0.4-0.9M) 16K CK + 4.1ms CKSEL=1011 SUT=10
低石英/陶瓷振动器(0.4-0.9M) 16K CK + 65ms CKSEL=1011 SUT=11
中石英/陶瓷振动器(0.9-3.0M) 258 CK + 4.1 ms CKSEL=1100 SUT=00
中石英/陶瓷振动器(0.9-3.0M) 258 CK + 65 ms CKSEL=1100 SUT=01
中石英/陶瓷振动器(0.9-3.0M) 1K CK + 0 ms CKSEL=1100 SUT=10
中石英/陶瓷振动器(0.9-3.0M) 1K CK + 4.1 ms CKSEL=1100 SUT=11
中石英/陶瓷振动器(0.9-3.0M) 1K CK + 65 ms CKSEL=1101 SUT=00
中石英/陶瓷振动器(0.9-3.0M) 16K CK + 0 ms CKSEL=1101 SUT=01
中石英/陶瓷振动器(0.9-3.0M) 16K CK + 4.1ms CKSEL=1101 SUT=10
中石英/陶瓷振动器(0.9-3.0M) 16K CK + 65ms CKSEL=1101 SUT=11
高石英/陶瓷振动器(3.0-8.0M) 258 CK + 4.1 ms CKSEL=1110 SUT=00
高石英/陶瓷振动器(3.0-8.0M) 258 CK + 65 ms CKSEL=1110 SUT=01
高石英/陶瓷振动器(3.0-8.0M) 1K CK + 0 ms CKSEL=1110 SUT=10
高石英/陶瓷振动器(3.0-8.0M) 1K CK + 4.1 ms CKSEL=1110 SUT=11
高石英/陶瓷振动器(3.0-8.0M) 1K CK + 65 ms CKSEL=1111 SUT=00
高石英/陶瓷振动器(3.0-8.0M) 16K CK + 0 ms CKSEL=1111 SUT=01
高石英/陶瓷振动器(3.0-8.0M) 16K CK + 4.1ms CKSEL=1111 SUT=10
高石英/陶瓷振动器(3.0-8.0M) 16K CK + 65ms CKSEL=1111 SUT=11
注:1、出厂默许设置
留意:CKOPT=1(未编程)时,最大作业频率为8MHZ
内部RC振动1MHZ 6 CK + 4.1 ms CKSEL=0001 SUT=01
还有进入不了编程形式,提示衔接不正常的,能够这样修正,我亲身试过,好极了。也是转帖的
当改动了AVR的熔丝位装备,从头加电后,想再用ISP下载,提示:“进入编程形式失利”等,极有可能是搞错了熔丝位,导致芯片不知道运用何种主频而无法正常作业(仅限于内部RC振动的状况)。
经过外加有源晶振的方法,让其康复。
运用51系列单片机的ALE引脚作为外部时钟源,将51系列的ALE引脚与M16的XTAL1引脚相衔接。我亲手试了一下,作用是马到成功,很快的康复了过错设置的熔丝位。
论坛转帖:
在给ATMEGA8单片机编程时分运用AVR-frighter 软件,成果编程运用了内部晶振,运转速度很慢。请问怎样设置才干运用外部晶振。我外部用的24M晶振。还要怎样设置才干用外部?
问题解决,没正确装备熔丝,外部晶体不起振,频率计测不到。照下图装备,搞定。M8 和M16相同。