您的位置 首页 设计

AVR单片机熔丝位设置技巧

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

对AVR熔丝位的装备是比较详尽的作业,用户往往忽视其重要性,或感到不易把握。下面给出对AVR熔丝位的装备操作时的一些关键和需求留意的相关事项。有关ATmega128熔丝位的详细界说和功用请检查本书相关章节,在附录中将给出一个完好的汇总表。
(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的使用请参阅本章相关内容。
现场调试进程中对熔丝位起到的效果。
问题一:体系的发动时刻,若不装备熔丝位,体系默以为内部时钟,所以体系的发动时刻比较长。将熔丝位装备为外部晶振,这样正常,追述原因可参加上面的第10条。
问题二:串口运转不正常,若不装备熔丝位,其默许是1M的晶振,故所设置的波特率的核算将不正确。呈现乱码或串口不同的现象。

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

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

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

微信扫一扫关注我们

返回顶部