mega8的熔絲位設(shè)置以下內(nèi)容根據(jù)mega8的英文手冊翻譯,希望對大家有所幫助。如發(fā)現(xiàn)錯誤,懇請大家指正。
?
mega8熔絲位:
1:未編程(不選中)
0:編程(選中)
********************************
熔絲位說明缺省設(shè)置
********************************
RSTDISBL:復(fù)位或I/O功能選擇11:復(fù)位功能;0:I/O功能(PC6)
WDTON:看門狗開關(guān)11:看門狗打開(通過WDTCR允許);0:看門狗禁止
SPIEN:SPI下載允許01:SPI下載禁止;0:SPI下載允許(注:當(dāng)使用SPI編程時,該項不可用)
EEAVE:燒錄時EEPROM數(shù)據(jù)保留11:不保留;0:保留
BODEN:BOD功能控制11:BOD功能禁止;0:BOD功能允許
BODLEVEL:BOD電平選擇11:2.7V電平;0:4.0V電平
BOOTRST:復(fù)位入口選擇11:程序從0x0000地址開始執(zhí)行;0:程序從引導(dǎo)區(qū)確定的入口地址開始執(zhí)行
********************************
BOOTSZ1/0:引導(dǎo)區(qū)程序大小及入口00
00:1024Word/0xc00;
01:512Word/0xe00;
10:256Word/0xf00;
11:128Word/0xf80
********************************
BLB02/01:程序區(qū)指令位選擇11
11:SPM和LPM指令都允許執(zhí)行
10:SPM指令禁止寫程序區(qū)
01:引導(dǎo)區(qū)LPM指令禁止讀取程序區(qū)內(nèi)容;如果中斷向量定義在引導(dǎo)區(qū),則禁止該中斷在程序區(qū)執(zhí)行。
00:SPM指令禁止寫程序區(qū);引導(dǎo)區(qū)LPM指令禁止讀取程序區(qū)內(nèi)容;如果中斷向量定義在引導(dǎo)區(qū),則禁止該中斷在程序區(qū)執(zhí)行。
********************************
BLB12/11:引導(dǎo)區(qū)指令位選擇11
11:SPM和LPM指令都允許執(zhí)行
10:SPM指令禁止寫引導(dǎo)區(qū)
01:程序區(qū)LPM指令禁止讀取引導(dǎo)區(qū)內(nèi)容;如果中斷向量定義在程序區(qū),則禁止該中斷在引導(dǎo)區(qū)執(zhí)行。
00:SPM指令禁止寫引導(dǎo)區(qū);程序區(qū)LPM指令禁止讀取引導(dǎo)區(qū)內(nèi)容;如果中斷向量定義在程序區(qū),則禁止該中斷在引導(dǎo)區(qū)執(zhí)行。
********************************
LB2/1:程序區(qū)加密位選擇11
11:未加密
10:程序和EEPROM編程功能禁止,熔絲位鎖定
00:程序和EEPROM編程及校驗功能禁止,熔絲位鎖定
(注:先編程其他熔絲位,再編程加密位)
********************************
CKSEL3/0:時鐘源選擇0001
CKOPT:晶振選擇1
SUT1/0:復(fù)位啟動時間選擇10
********************************
CKSEL3/0=0000:外部時鐘,CKOPT=0:允許芯片內(nèi)部XTAL1管腳對GND接一個36PF電容;CKOPT=1:禁止該電容
----------------
CKSEL3/0=0001-0100:已經(jīng)校準(zhǔn)的內(nèi)部RC振蕩,CKOPT總為1
0001:1.0M
0010:2.0M
0011:4.0M
0100:8.0M
----------------
CKSEL3/0=0101-1000:外部RC振蕩,CKOPT=0:允許芯片內(nèi)部XTAL1管腳對GND接一個36PF電容;CKOPT=1:禁止該電容
0101:《0.9M0110:0.9-3.0M0111:3.0-8.0M1000:8.0-12.0M----------------CKSEL3/0=1001:外部低頻晶振,CKOPT=0:允許芯片內(nèi)部XTAL1/XTAL2管腳對GND各接一個36PF電容;CKOPT=1:禁止該電容----------------CKSEL3/0=1010-1111:外部晶振,陶瓷振蕩子,CKOPT=0:高幅度振蕩輸出;CKOPT=1:低幅度振蕩輸出101X:0.4-0.9M110X:0.9-3.0M111X:3.0-8.0M********************************SUT1/0:復(fù)位啟動時間選擇當(dāng)選擇不同晶振時,SUT有所不同。mega128增加了以下幾個選項:********************************熔絲位說明缺省設(shè)置********************************M103C:mega103兼容模式01:mega128模式;0:mega103模式JTAGEN:JTAG允許01:JTAG禁止;0:JTAG允許OCDEN:OCD功能允許11:OCD功能禁止;0:OCD功能允許其他基本相同,引導(dǎo)區(qū)程序大小及入口有所差別。~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~關(guān)于avr的熔絲的使用和設(shè)置 作者:馬潮老師 看到這么多的人對AVR的熔絲位不會使用和誤操作,給出參考。5.1.1正確配置AVR熔絲位對AVR熔絲位的配置是比較細(xì)致的工作,用戶往往忽視其重要性,或感到不易掌握。下面給出對AVR熔絲位的配置操作時的一些要點和需要注意的相關(guān)事項。有關(guān)ATmega128熔絲位的具體定義和功能請查看本書相關(guān)章節(jié),在附錄中將給出一個完整的匯總表。
? ? ? ?(1)在AVR的器件手冊中,對熔絲位使用已編程(Programmed)和未編程(Unprogrammed)定義熔絲位的狀態(tài),“Unprogrammed”表示熔絲狀態(tài)為“1”(禁止);“Programmed”表示熔絲狀態(tài)為“0”(允許)。因此,配置熔絲位的過程實際上是“配置熔絲位成為未編程狀態(tài)“1”或成為已編程狀態(tài)“0””。
? ? ? ?(2)在使用通過選擇打鉤“√”方式確定熔絲位狀態(tài)值的編程工具軟件時,請首先仔細(xì)閱讀軟件的使用說明,弄清楚“√”表示設(shè)置熔絲位狀態(tài)為“0”還是為“1”。
? ? ? ?(3)使用CVAVR中的編程下載程序時應(yīng)特別注意,由于CVAVR編程下載界面初始打開時,大部分熔絲位的初始狀態(tài)定義為“1”,因此不要使用其編程菜單選項中的“all”選項。此時的“all”選項會以熔絲位的初始狀態(tài)定義來配置芯片的熔絲位,而實際上其往往并不是用戶所需要的配置結(jié)果。如果要使用“all”選項,應(yīng)先使用“read-》fusebits”讀取芯片中熔絲位實際狀態(tài)后,再使用“all”選項。
(4)新的AVR芯片在使用前,應(yīng)首先查看它熔絲位的配置情況,再根據(jù)實際需要,進行熔絲位的配置,并將各個熔絲位的狀態(tài)記錄備案。
(5)AVR芯片加密以后僅僅是不能讀取芯片內(nèi)部Flash和E2PROM中的數(shù)據(jù),熔絲位的狀態(tài)仍然可以讀取但不能修改配置。芯片擦除命令是將Flash和E2PROM中的數(shù)據(jù)清除,并同時將兩位鎖定位狀態(tài)配置成“11”,處于無鎖定狀態(tài)。但芯片擦除命令并不改變其它熔絲位的狀態(tài)。
(6)正確的操作程序是:在芯片無鎖定狀態(tài)下,下載運行代碼和數(shù)據(jù),配置相關(guān)的熔絲位,最后配置芯片的鎖定位。芯片被鎖定后,如果發(fā)現(xiàn)熔絲位配置不對,必須使用芯片擦除命令,清除芯片中的數(shù)據(jù),并解除鎖定。然后重新下載運行代碼和數(shù)據(jù),修改配置相關(guān)的熔絲位,最后再次配置芯片的鎖定位。
(7)使用ISP串行方式下載編程時,應(yīng)配置SPIEN熔絲位為“0”。芯片出廠時SPIEN位的狀態(tài)默認(rèn)為“0”,表示允許ISP串行方式下載數(shù)據(jù)。只有該位處于編程狀態(tài)“0”,才可以通過AVR的SPI口進行ISP下載,如果該位被配置為未編程“1”后,ISP串行方式下載數(shù)據(jù)立即被禁止,此時只能通過并行方式或JTAG編程方式才能將SPIEN的狀態(tài)重新設(shè)置為“0”,開放ISP。通常情況下,應(yīng)保持SPIEN的狀態(tài)為“0”,允許ISP編程不會影響其引腳的I/O功能,只要在硬件電路設(shè)計時,注意ISP接口與其并接的器件進行必要的隔離,如使用串接電阻或斷路跳線等。
(8)當(dāng)你的系統(tǒng)中,不使用JTAG接口下載編程或?qū)崟r在線仿真調(diào)試,且JTAG接口的引腳需要作為I/O口使用時,必須設(shè)置熔絲位JTAGEN的狀態(tài)為“1”。芯片出廠時JTAGEN的狀態(tài)默認(rèn)為“0”,表示允許JTAG接口,JTAG的外部引腳不能作為I/O口使用。當(dāng)JTAGEN的狀態(tài)設(shè)置為“1”后,JTAG接口立即被禁止,此時只能通過并行方式或ISP編程方式才能將JTAG重新設(shè)置為“0”,開放JTAG。
(9)一般情況下不要設(shè)置熔絲位把RESET引腳定義成I/O使用(如設(shè)置ATmega8熔絲位RSTDISBL的狀態(tài)為“0”),這樣會造成ISP的下載編程無法進行,因為在進入ISP方式編程時前,需要將RESET引腳拉低,使芯片先進入復(fù)位狀態(tài)。
(10)使用內(nèi)部有RC振蕩器的AVR芯片時,要特別注意熔絲位CKSEL的配置。一般情況下,芯片出廠時CKSEL位的狀態(tài)默認(rèn)為使用內(nèi)部1MHz的RC振蕩器作為系統(tǒng)的時鐘源。如果你使用了外部振蕩器作為系統(tǒng)的時鐘源時,不要忘記首先正確配置CKSEL熔絲位,否則你整個系統(tǒng)的定時都會出現(xiàn)問題。而當(dāng)在你的設(shè)計中沒有使用外部振蕩器(或某鐘特定的振蕩源)作為系統(tǒng)的時鐘源時,千萬不要誤操作或錯誤的把CKSEL熔絲位配置成使用外部振蕩器(或其它不同類型的振蕩源)。一旦這種情況產(chǎn)生,使用ISP編程方式則無法對芯片操作了(因為ISP方式需要芯片的系統(tǒng)時鐘工作并產(chǎn)生定時控制信號),芯片看上去“壞了”。此時只有使用取下芯片使用并行編程方式,或使用JTAG方式(如果JTAG為允許時且目標(biāo)板上留有JTAG接口)來解救了。另一種解救的方式是:嘗試在芯片的晶體引腳上臨時人為的疊加上不同類型的振蕩時鐘信號,一旦ISP可以對芯片操作,立即將CKSEL配置成使用內(nèi)部1MHz的RC振蕩器作為系統(tǒng)的時鐘源,然后再根據(jù)實際情況重新正確配置CKSEL。
(11)使用支持IAP的AVR芯片時,如果你不使用BOOTLOADER功能,注意不要把熔絲位BOOTRST設(shè)置為“0”狀態(tài),它會使芯片在上電時不是從Flash的0x0000處開始執(zhí)行程序。芯片出廠時BOOTRST位的狀態(tài)默認(rèn)為“1”。關(guān)于BOOTRST的配置以及BOOTLOADER程序的設(shè)計與IAP的應(yīng)用請參考本章相關(guān)內(nèi)容。
5.1.2ATmega128中重要熔絲位的配置
上一小節(jié)介紹了配置AVR熔絲位的要點和注意事項,本小節(jié)把在一般情況下使用ATmega128時,幾個重要的熔絲位配置情況進行說明。
(1)熔絲位M103C。M103C的配置將設(shè)定ATmega128是以ATmega103兼容方式工作運行還是以ATmega128本身的方式工作運行。ATmega128在出廠時M103C默認(rèn)狀態(tài)為“0”,即默認(rèn)以ATmega103兼容方式工作。當(dāng)用戶系統(tǒng)設(shè)計使芯片以ATmega128方式工作時,應(yīng)首先將M103C的狀態(tài)配置為“1”。
(2)CLKSEL0..3。CLKSEL0、CLKSEL1、CLKSEL2、CLKSEL3用于選擇系統(tǒng)的時鐘源。有五種不同類型的時鐘源可供選擇(每種類型還有細(xì)的劃分)。芯片出廠時的默認(rèn)情況為CLKSEL3..0和SUT1..0分別是“0001”和“10”。即使用內(nèi)部1MHzRC振蕩器,使用最長的啟動延時。這保證了無論外部振蕩電路是否工作,都可以進行最初的ISP下載。對于CLKSEL3..0熔絲位的改寫需要十分慎重,因為一旦改寫錯誤,會造成芯片無法啟動,見上一小節(jié)第10點說明。
(3)JTAGEN。如果不使用JTAG接口,應(yīng)將JTAGEN的狀態(tài)設(shè)置為“1”,即禁止JTAG,JTAG引腳用于I/O口。
(4)SPIEN。SPI方式下載數(shù)據(jù)和程序允許,默認(rèn)狀態(tài)為允許“0”。一般保留其狀態(tài)。
(5)WDTON??撮T狗的定時器始終開啟。WDTON默認(rèn)為“1”,即禁止看門狗的定時器始終開啟。如果該位設(shè)置為“0”后,看門狗的定時器就會始終打開,不能被內(nèi)部程序控制了,這是為了防止當(dāng)程序跑飛時,未知代碼通過寫寄存器將看門狗定時器關(guān)斷而設(shè)計的(盡管關(guān)斷看門狗定時器需要特殊的方式,但它保證了更高的可靠行)。
(6)EESAVE。執(zhí)行擦除命令時是否保留E2PROM中的內(nèi)容,默認(rèn)狀態(tài)為“1”,表示E2PROM中的內(nèi)容同F(xiàn)lash中的內(nèi)容一同擦除。如果該位設(shè)置為“0”,對程序進行下載前的擦除命令只會對FLASH代碼區(qū)有效,而對E2PROM區(qū)無效。這對于希望在系統(tǒng)更新程序時,需要保留E2PROM中數(shù)據(jù)的情況下是十分有用的。
(7)BOOTRST。決定芯片上電起動時,第一條執(zhí)行指令的地址。默認(rèn)狀態(tài)為“1”,表示起動時從0x0000開始執(zhí)行。如果BOOTRST設(shè)置為“0”,則起動時從BOOTLOADER區(qū)的起始地址處開始執(zhí)行程序。BOOTLOADER區(qū)的大小由BOOTSZ1和BOOTSZ0決定,因此其首地址也隨之變化。
(8)BOOTSZ1和BOOTSZ0:這兩位確定了BOOTLOADER區(qū)的大小以及其起始的首地址。默認(rèn)的狀態(tài)為“00”,表示BOOTLOADER區(qū)為4096字,起始首地址為0xF000。
(9)推薦用戶使用ISP方式配置熔絲位。配置工具選用BASCOM-AVR(網(wǎng)上下載試用版,它對ISP下載無限制),和STK200/STK300兼容的下載電纜。
注:不同AVR的熔絲也不同,使用前必須仔細(xì)查看芯片手冊
評論
查看更多