您的位置 首页 设计

AVR熔丝位装备

对AVR熔丝位的配置是比较细致的工作,用户往往忽视其重要性,或感到不易掌握。下面给出对AVR熔丝位的配置操作时的一些要点和需要注意的相

AVR熔丝位的装备是比较详尽的作业,用户往往忽视其重要性,或感到不易把握。下面给 出对AVR熔丝位的装备操作时的一些关键和需求留意的相关事项。

(1)在AVR的器材手册中,对熔丝位运用已编程 (Programmed)和未编程(Unprogrammed)界说熔丝位的状况,“Unprogrammed”表明熔丝状况为“1”(禁 止);“Programmed”表明熔丝状况为“0”(答应)。因而,装备熔丝位的进程实践上是“装备熔丝位成为未编程状况“1”或成为已编程状况 “0””。

(2)在运用经过挑选打钩“√”方法确认熔丝位状况值的编程东西软件时,请首要细心阅读软件的运用说明,弄清楚“√”表明设置 熔丝位状况为“0”仍是为“1”。

(3)运用CVAVR中的编程下载程序时应特别留意,由于CVAVR编程下载界面初始翻开时,大部分熔 丝位的初始状况界说为“1”,因而不要运用其编程菜单选项中的“all”选项。此刻的“all”选项会以熔丝位的初始状况界说来装备芯片的熔丝位,而实践 上其往往并不是用户所需求的装备成果。假如要运用“all”选项,应先运用“read->fuse bits”读取芯片中熔丝位实践状况后,再运用“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中重要熔丝位的装备

(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”。即运用内部1MHz RC振动器,运用最长的发动延时。这确保了不管外部振动电路是否作业,都能够进行开端的ISP下载。关于CLKSEL3..0熔丝位的改写需求非常稳重, 由于一旦改写过错,会形成芯片无法发动。

(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的熔丝也不同,运用前有必要细心检查芯片手册。

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

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

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

微信扫一扫关注我们

返回顶部