歡迎您光臨本站 登入註冊首頁

配置AVR熔絲位的建議

admin @ 2014-03-14 , reply:0

概述

對AVR熔絲位的配置是比較細緻的工作,用戶往往忽視其重要性,或感到不易掌握。下面給出對AVR熔絲位的配置操作時的一些要點和需要注意的相關事項。有關ATmega128熔絲位的具體定義和功能請查看本書相關……

對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的應用請參考本章相關內容。

二、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:保留

[admin via 研發互助社區 ] 配置AVR熔絲位的建議已經有3943次圍觀

http://cocdig.com/docs/show-post-800.html