www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 電源 > 數(shù)字電源
[導(dǎo)讀]本文首先介紹常見的Flash編程方法,然后詳細(xì)介紹本文方法的原理,以及DSP系統(tǒng)上電加載原理,最后給出整個(gè)實(shí)現(xiàn)過(guò)程并分析了Flash編程時(shí)需要注意的一些問(wèn)題?! lash編程方法  常見的Flash編程方式  Flash在正常使用

本文首先介紹常見的Flash編程方法,然后詳細(xì)介紹本文方法的原理,以及DSP系統(tǒng)上電加載原理,最后給出整個(gè)實(shí)現(xiàn)過(guò)程并分析了Flash編程時(shí)需要注意的一些問(wèn)題。

  Flash編程方法

  常見的Flash編程方式

  Flash在正常使用前必須寫入用戶程序,傳統(tǒng)上有3種編程方法:由供應(yīng)商出貨前把程序代碼寫入Flash、編程器編程和在系統(tǒng)編程。

  第1種方法不能滿足用戶更改代碼的需求,所以在開發(fā)階段不宜采用。當(dāng)使用編程器編程時(shí),要求Flash固定在PCB板前必須把用戶程序?qū)懭肫瑑?nèi)。因此,現(xiàn)在一般都優(yōu)先考慮在系統(tǒng)編程方法,首先應(yīng)確定所選的DSP是否直持在系統(tǒng)編程?,F(xiàn)行的在系統(tǒng)編程的方法一般是先把待加載程序(用戶程序)的.out文件(COFF格式)轉(zhuǎn)成HEX格式,然后去掉HEX格式文件的文件頭,再通過(guò)燒寫程序?qū)懙紽lash里去。也可以不進(jìn)行COFF格式到HEX格式的轉(zhuǎn)換這一步,把COFF文件作為源文件,去除文件頭信息后將其寫入Flash。

  編程原理

  本文的實(shí)現(xiàn)方法比較簡(jiǎn)單,首先把用戶程序映射到系統(tǒng)RAM,再把用戶程序作為數(shù)據(jù)直接從RAM搬入Flash中。

  首先在CCS上完成用戶程序,生成可執(zhí)行的.out文件,將該文件設(shè)為文件1進(jìn)行加載;然后加載燒寫程序的.out文件,將其設(shè)為文件2;最后運(yùn)行文件2,通過(guò)它把文件1燒入Flash。

  操作步驟非常簡(jiǎn)單,這里要說(shuō)明幾點(diǎn)。首先,2個(gè).out文件各自獨(dú)立,文件2加載后,文件1成為數(shù)據(jù),CCS在運(yùn)行時(shí),運(yùn)行的是最新加載的程序,也即文件2。其次,文件2與文件1映射到RAM中的物理空間各自獨(dú)立,也就是文件2不能映射到文件1已映射的地方,如果發(fā)生重疊,文件2的內(nèi)容就會(huì)覆蓋原先文件1映射到該地址空間的內(nèi)容,寫入Flash的內(nèi)容就會(huì)發(fā)生錯(cuò)誤。再次,用戶程序里包括了二次加載程序,以在自舉時(shí)把用戶程序從Flash還原到RAM中。

  總線周期

  命令1 2 3 4 5 6

  序列地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)

  軟件復(fù)位XXXF0

  芯片擦除XXXAAXXX55XXX80XXXAAXXX55XXX10

  扇區(qū)擦除XXXAAXXX55XXX80XXXAAXXX55SA30

  字節(jié)寫XXXAAXXX55XXXA0PAPD

  表1 Am29LV033C內(nèi)存指令表

  二次加載和Bootloader

  要保證用戶程序的正確運(yùn)行,僅把程序?qū)懭隖lash是不夠的,必須保證上電后,程序能夠從Flash中正確恢復(fù)到RAM。系統(tǒng)上電工作步驟如圖1所示。

  

 

  圖1 系統(tǒng)上電的工作步驟

  DSP首先自檢,得到程序的加載模式。在C6000中主要有2種模式,一種是主機(jī)加載模式,也即DSP從0x0000 0000開始執(zhí)行程序;另一種是ROM加載模式,該模式又有8位、16位、32位幾種,不同的DSP略有不同,這里選用8位ROM模式。工作時(shí),DSP先從地址0x9000 0000開始,把0x9000 0000~0x9000 0400這1K(在C62xx中是64K)的數(shù)據(jù)搬到0x0000 0000~0x0000 0400,然后再?gòu)?x0000 0000開始執(zhí)行程序。這一次加載由DSP自行完成,但是1K的程序作為用戶程序顯然不夠,因此,這1K的程序要做成加載器,也就是手工寫的Bootloader,利用它把用戶程序從Flash搬入RAM。加載器搬運(yùn)用戶程序又是一次加載,因此把這個(gè)過(guò)程統(tǒng)稱為二次加載。

  Bootloader要完成兩項(xiàng)功能,第一,把其它程序搬到指定的地址;第二,跳轉(zhuǎn)到用戶程序入口,這里要先修改ISP,再跳轉(zhuǎn)到復(fù)位中斷,因此在Bootloader的最后總是一條跳轉(zhuǎn)指令。由于Bootloader在Flash中的位置是0x9000 0000~0x9000 0400,而Bootloader又是放在用戶程序里的,因此,為了方便燒寫程序把Bootloader寫到該位置,這里在用戶程序的.cmd文件中把bootloader定位在程序段的起始位置。[!--empirenews.page--]編程方法實(shí)現(xiàn)

 

  系統(tǒng)配置和參數(shù)設(shè)置

  TMS320DM642是TI公司的一款視頻圖像DSP,工作時(shí)鐘最高可達(dá)到600MHz。程序存儲(chǔ)器最大可調(diào)至272M×8位,其EMIF接口分4個(gè)空間,即CE0~CE3。Flash映射到CE1空間,其地址為0x90000000~0x90400000,上電時(shí)采用8位ROM加載方式。

  Am29LV033C是AMD公司生產(chǎn)的Flash存儲(chǔ)器,其主要特點(diǎn)有:3.3 V單電源供電,可使內(nèi)部產(chǎn)生高電壓進(jìn)行編程和擦除操作;只需向其命令寄存器寫入標(biāo)準(zhǔn)的微處理器指令,具體編程、擦除操作由內(nèi)部嵌入的算法實(shí)現(xiàn),并且可以通過(guò)查詢特定的引腳或數(shù)據(jù)線監(jiān)控操作是否完成;可以對(duì)任一扇區(qū)進(jìn)行讀、寫或擦除操作,而不影響其它部分的數(shù)據(jù)。

  由于4MB的Flash ROM有22根地址線,而DM642只有20根地址線,因此加入FPGA,對(duì)Flash進(jìn)行分頁(yè),這里共分8頁(yè),每頁(yè)512KB,每頁(yè)內(nèi)含8塊,每塊64KB。

  Am29LV033C有多條內(nèi)存指令,可以實(shí)現(xiàn)芯片ID的讀取、軟件復(fù)位、整片擦除、塊擦除等。在這里主要介紹燒寫時(shí)用到的指令,其擦寫命令如表1所示。表中的XXX表示任意地址,SA為塊地址,即地址線的第16位到21位,PA為燒寫地址,PD為燒寫數(shù)據(jù)。

  待燒寫程序(用戶程序)為USER.out,大小為2M;燒寫程序?yàn)镕BCT.out,大小為4K,地址分配如表2所示。

  編程過(guò)程

  第一步,對(duì)整個(gè)Flash進(jìn)行一遍擦除。因?yàn)镕lash在編程時(shí)只能把“1”置為“0”,而不能把“0”置為“1”。

  第二步,判斷擦除結(jié)束。通過(guò)DQ6、DQ7均可完成判斷,當(dāng)DQ6位不再跳變時(shí)說(shuō)明擦除結(jié)束。這里通過(guò)讀取最后一位數(shù)據(jù)是否為“0xFF”來(lái)完成判斷。

  第三步,進(jìn)行軟件復(fù)位。軟件復(fù)位使Flash處于就緒狀態(tài),當(dāng)Flash在進(jìn)行擦除、編程時(shí)軟件復(fù)位信號(hào)無(wú)效。

  第四步,取得編程地址。如果地址超過(guò)最大地址則編程結(jié)束。

  開始地址長(zhǎng)度寫入Flash的開始地址

  USER.out0x800000002M0x9001 0000

  bootloader0x0000 00001K0x9000 0000

  FBCT.out,0x300000004K--

  表2 程序的地址分配

  注意事項(xiàng)

  對(duì)于不同的DSP,不同的Flash,在實(shí)現(xiàn)時(shí)可能不一樣,這里有幾個(gè)問(wèn)題必須注意:

  (1) 文件1和文件2的.cmd文件要分配好各自的地址,地址空間不能重疊。

  (2) 不是每個(gè)DSP都可以實(shí)現(xiàn)在系統(tǒng)編程,如TMS320C6204就不行,而C621x,C64x等就可以。原因在于Flash在編程時(shí)速度較慢,一般為ms級(jí),所以需要WE#信號(hào)的有效時(shí)間較長(zhǎng)。但是,一般的WE#有效時(shí)間都只有幾十ns,這么短的時(shí)間不足以讓DSP把內(nèi)容寫進(jìn)Flash。C64x等之所以能實(shí)現(xiàn)在系統(tǒng)編程,是因?yàn)樵诰幊虝r(shí)DSP自動(dòng)延長(zhǎng)了編程的有效時(shí)間。

  (3) 如果用戶程序中不含加載器程序,那么用戶程序的目的地址就不能從Flash的前1K地址開始。

  (4) 不同型號(hào)Flash的編程時(shí)序和指令可能會(huì)有所不同,編程之前要弄清該Flash的編程時(shí)序和指令。如果Flash要求有偏移地址,就需要加上基地址。

  (5) 對(duì)于程序的未初始化段不必?zé)隖lash,可以參考.map文件,里面對(duì)于各段有詳細(xì)說(shuō)明。

  

 

  圖2 程序流程

  結(jié)語(yǔ)

  利用上面的方法,本文在TMS320DM642平臺(tái)中通過(guò)JTAG仿真頭,成功地實(shí)現(xiàn)了在系統(tǒng)編程,為程序的調(diào)試提供了一種非常方便的手段,也為用戶程序的升級(jí)提供了一種簡(jiǎn)單易行的方法,同時(shí)這個(gè)方法也在C6211環(huán)境下成功實(shí)現(xiàn),其它DSP同樣可參考本方法。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

Matlab和C語(yǔ)言的區(qū)別是:1、用途不同;2、語(yǔ)法不同;3、運(yùn)行速度不同;4、可移植性不同;5、代碼管理不同。Matlab是一種數(shù)值計(jì)算和科學(xué)計(jì)算工具

關(guān)鍵字: matlab語(yǔ)言 C語(yǔ)言 系統(tǒng)編程

寫作目的: 學(xué)習(xí) Linux 文件模型相關(guān)的知識(shí)。 正文目錄: 1.?Linux?的兩大抽象 2.?文件類型 3.?文件描述符 4. 通用文件模型:簡(jiǎn)介 ????4.1?演示?demo ????4.2?相關(guān)要點(diǎn):?與?V...

關(guān)鍵字: 模型 系統(tǒng)編程

人們很容易高估某個(gè)決定性時(shí)刻的重要性,也很容易低估每天進(jìn)行微小改進(jìn)的價(jià)值。以前我也以為大規(guī)模的成功需要大規(guī)模的行動(dòng),現(xiàn)在我不這么認(rèn)為了。長(zhǎng)期來(lái)看,由于復(fù)利效果,一點(diǎn)小小的改進(jìn)就能產(chǎn)生驚人的變化。 還有一點(diǎn)值得注意的情況,...

關(guān)鍵字: 信號(hào) 系統(tǒng)編程

CC2640 R2是德州儀器推出的面向 Bluetooth Smart 應(yīng)用的低功耗無(wú)線 MCU。該芯片運(yùn)行TI的BLE協(xié)議棧,具有功耗低,外設(shè)種類豐富,射頻性能好等特點(diǎn)。利用它可以實(shí)現(xiàn)許多有趣的應(yīng)用,收到了用戶的廣泛歡...

關(guān)鍵字: 芯片 燒寫程序 BOOTLOADER KD

C語(yǔ)言是一門通用計(jì)算機(jī)編程語(yǔ)言,應(yīng)用廣泛。C語(yǔ)言的設(shè)計(jì)目標(biāo)是提供一種能以簡(jiǎn)易的方式編譯、處理低級(jí)存儲(chǔ)器、產(chǎn)生少量的機(jī)器碼以及不需要任何運(yùn)行環(huán)境支持便能運(yùn)行的編程語(yǔ)言。 盡管C語(yǔ)言提供了許多低級(jí)處理的功能,但仍然保持著良好...

關(guān)鍵字: C語(yǔ)言 嵌入式系統(tǒng) 系統(tǒng)編程 CE

在大學(xué)的時(shí)候很少關(guān)心單片機(jī)內(nèi)部存儲(chǔ)器的結(jié)構(gòu)及應(yīng)用,只是大概的知道RAM和ROM的區(qū)別,甚至只是知道程序下載到ROM中就能運(yùn)行了。其他的如何工作程序如何啟動(dòng)的就不了了知了。

關(guān)鍵字: 存儲(chǔ)器 BOOTLOADER 嵌入式設(shè)計(jì) LOADER

0 引言Bootloader通常稱為系統(tǒng)引導(dǎo)加載程序,是系統(tǒng)加電或復(fù)位后執(zhí)行第一段代碼[ 1 ]。一般它只在系統(tǒng)啟動(dòng)時(shí)運(yùn)行非常短時(shí)間,但對(duì)于嵌入式系統(tǒng)來(lái)說(shuō),這是一個(gè)非常重要系統(tǒng)

關(guān)鍵字: BOOTLOADER NANDFLASH 內(nèi)核 CK

摘要: 近年來(lái),在系統(tǒng)編程(ISP)技術(shù)的不斷發(fā)展和成熟,使得硬件設(shè)計(jì)逐步軟件化,硬件結(jié)構(gòu)的通用性日益增強(qiáng),系統(tǒng)設(shè)計(jì)、生產(chǎn)、維護(hù)、升級(jí)等環(huán)節(jié)都發(fā)生著深刻的變革。本文以

關(guān)鍵字: 系統(tǒng)編程 W78E516 ISP 微控制器

摘要:針對(duì)目前基于單片機(jī)的產(chǎn)品和C8051F410單片機(jī)特色,提出了一種使用UART接口進(jìn)行程序升級(jí)的實(shí)現(xiàn)方法,并對(duì)實(shí)現(xiàn)此功能的關(guān)鍵技術(shù)點(diǎn)做了相應(yīng)分析,使程序更加實(shí)用、可靠,所有代碼使用C語(yǔ)言進(jìn)行實(shí)現(xiàn)。此方法具有一

關(guān)鍵字: BOOTLOADER 單片機(jī) C8051F410 ADDR

摘要:該系統(tǒng)是以TMS320DM642為核心,結(jié)合視頻編解碼芯片,并外擴(kuò)大容量的存儲(chǔ)器,實(shí)現(xiàn)4路視頻輸入與1路視頻輸出。本文主要介紹了基于TMS320DM642的視頻監(jiān)控系統(tǒng)的硬件設(shè)計(jì),主要包括視頻輸入/輸出模塊的設(shè)計(jì)...

關(guān)鍵字: 硬件設(shè)計(jì) 視頻監(jiān)控系統(tǒng) TMS320DM642 引腳
關(guān)閉