0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于Blackfin處理器和DM9000AE實(shí)現(xiàn)嵌入式軟件系統(tǒng)的設(shè)計

電子設(shè)計 ? 來源:電子設(shè)計應(yīng)用 ? 作者:孫延均,茍先太,龍 ? 2020-09-03 17:11 ? 次閱讀

引言

嵌入式系統(tǒng)應(yīng)用越來越復(fù)雜和多樣化的今天,嵌入式軟件系統(tǒng)也變得越來越復(fù)雜,并且在復(fù)雜的應(yīng)用系統(tǒng)中通常都需要嵌入式操作系統(tǒng)的支持,這樣嵌入式操作系統(tǒng)鏡像文件的尺寸往往就會變得比較大??梢赃x擇通過網(wǎng)絡(luò)將嵌入式操作系統(tǒng)加載到SDRAM中運(yùn)行來解決這一問題。另外,通過網(wǎng)絡(luò)進(jìn)行操作時,只要將需要升級的軟件系統(tǒng)在主機(jī)端更新,然后嵌入式系統(tǒng)就可以通過網(wǎng)絡(luò)來加載更新后的軟件系統(tǒng)了。

硬件電路設(shè)計

本方案所選用的基本芯片包括Blackfin處理器ADSP-BF533、以太網(wǎng)控制器DM9000AE等,功能框圖如圖1所示。

基于Blackfin處理器和DM9000AE實(shí)現(xiàn)嵌入式軟件系統(tǒng)的設(shè)計

圖1 系統(tǒng)功能框圖

DM9000AE驅(qū)動

本文中所述系統(tǒng)的網(wǎng)絡(luò)模塊基于DM9000AE,可以與多種不同的處理器方便地進(jìn)行連接。

DM9000AE 的數(shù)據(jù)讀寫通過兩個對外可直接訪問的寄存器來進(jìn)行,其中INDEX port寄存器的地址=主控芯片片選基地址+0x0,DATA port寄存器的地址=主控芯片片選基地址+0x4。本系統(tǒng)將BF533的異步片選信號/ASM2連接至DM9000AE的片選引腳,因此本系統(tǒng)中 INDEX port=0x20000000,DATA port=0x20000004。

數(shù)據(jù)傳輸

數(shù)據(jù)傳輸經(jīng)過以下幾個步驟:

1. 檢查主控芯片與DM9000AE之間使用的數(shù)據(jù)總線寬度。

(u8)io_mode= DM9000_ior (0xFE)》》7; /*寄存器ISR第7位IOMODE表示I/O數(shù)據(jù)寬度*/

2. 將數(shù)據(jù)幀寫入到DM9000AE的傳輸FIFO SRAM中。

/*DM9000_IO=0x20000000, DM9000_DATA=0x20000004*/

DM9000_outb(0xF8, DM9000_IO); /*在設(shè)置了寄存器MWCMD后,就可以將要傳輸?shù)臄?shù)據(jù)寫入SRAM中,并且寫指針設(shè)置為自動增加*/

if(io_mode==1) /*8位模式*/

for (i = 0; i 《 TX_length; i++) /* TX_length表示待傳輸?shù)臄?shù)據(jù)幀長度*/

DM9000_outb(TX_data, DM9000_DATA); /*待傳輸?shù)臄?shù)據(jù)幀保存在數(shù)組TX_data 中*/

else if(io_mode==0) /*16位模式*/

{Length_tmp= (TX_length+1)/2;

for (i = 0; i 《 Length_tmp; i++)

DM9000_outw((u16 *) TX_data, DM9000_DATA);}

3. 在寄存器TXPLH(0xFD)和TXPLL(0xFC)中設(shè)置傳輸?shù)臄?shù)據(jù)幀的長度。

DM9000_iow(0xFC, TX_length & 0xff); /*將數(shù)據(jù)長度的低字節(jié)寫入寄存器TXPLL */

DM9000_iow(0xFD, (TX_length 》》 8) & 0xff); /*將數(shù)據(jù)長度的高字節(jié)寫入寄存器TXPLH */

4. 開始傳輸數(shù)據(jù)幀。

DM9000_iow(0x02, 1); /*將寄存器TCR的位0置1,向DM9000AE發(fā)出一個傳輸請求*/

5. 檢查傳輸是否完成。

while (DM9000_ior(0x02) & 0x01) { /*檢查寄存器TCR的位0是否為0,如果為0就表示傳輸完成*/

if (get_timer(0) 》=timeout) { /*檢查傳輸是否超時*/

printf(“transmission timeout\n”);

break;

}

}

數(shù)據(jù)接收

類似地,數(shù)據(jù)接收也要經(jīng)過如下幾個步驟:

1. 檢查DM9000AE的接收FIFO SRAM中是否接收到數(shù)據(jù)。

DM9000_ior(0xF0);

RX_ready= DM9000_inb (DM9000_DATA);

/*讀取數(shù)據(jù)到達(dá)標(biāo)志 */

if (RX_ready == 0)

return 0; /*如果沒有數(shù)據(jù)到達(dá),就返回調(diào)用此函數(shù)的原函數(shù)*/

if (RX_ready 》 1)

reset(); /*當(dāng)RX_ready 大于1時就說明DM9000AE處于異常狀態(tài),需要復(fù)位*/

當(dāng)RX_ready等于1時說明有數(shù)據(jù)到達(dá),進(jìn)入第二步

2. 被接收數(shù)據(jù)幀的狀態(tài)和長度檢查。

(u8)io_mode= DM9000_ior (0xFE)》》7;

DM9000_outb(0xF2, DM9000_IO);

if(io_mode==1){

RX_status = DM9000_inb (DM9000_DATA)+( DM9000_inb (DM9000_DATA)《《8);

RX_length = DM9000_inb (DM9000_DATA)+( DM9000_inb (DM9000_DATA)《《8);}

else if(io_mode==0){

RX_status = DM9000_inw (DM9000_DATA);

RX_length = DM9000_inw(DM9000_DATA);}

3. 接收數(shù)據(jù)幀。

if(io_mode==1)

for (i = 0; i 《 RX_length; i++)

RX_data=DM9000_inb(DM9000_DATA);

else if(io_mode==0)

{Length_tmp= (RX_length +1)/2;

for (i = 0; i 《 Length_tmp; i++)

(u16 *) RX_data=DM9000_inw(DM9000_DATA);}

4. 對接收的數(shù)據(jù)幀進(jìn)行錯誤檢驗(yàn)。

if((RX_status & 0xbf00) || (RX_length 《 0x40)|| (RX_length 》 1536)) {

if (RX_status & 0x100) {

printf(“rx fifo error\n”);} /*FIFO溢出錯誤*/

if (RX_status & 0x200) {

printf(“rx crc error\n”);} /*CRC校驗(yàn)和錯誤*/

if (RX_status & 0x8000) {

printf(“rx length error\n”);} /*接收的幀小于64字節(jié)*/

if (RX_length 》 1536) {

printf(“rx length too big\n”); /*接收的幀大于1536字節(jié)*/

dm9000_reset();}

}

網(wǎng)絡(luò)啟動的實(shí)現(xiàn)

本系統(tǒng)是在基于BF533+ DM9000AE的嵌入式硬件平臺上,通過U-Boot在自啟動時使用TFTP從網(wǎng)絡(luò)加載μclinux。

U-Boot源代碼移植

DM9000AE 的驅(qū)動位于U-Boot的driver目錄下,如果要使用此驅(qū)動,可以在include/configs目錄下相應(yīng)系統(tǒng)的頭文件中加入宏定義語句。自定義系統(tǒng)可以根據(jù)基于相同體系結(jié)構(gòu)的參考系統(tǒng)頭文件來創(chuàng)建自己的頭文件,比如,本系統(tǒng)以ezkit533系統(tǒng)為模板創(chuàng)建頭文件 mybf533.h,并且加入以下宏定義語句:

#define CONFIG_DRIVER_DM9000???1?/*使用DM9000AE驅(qū)動*/

#define CONFIG_DM9000_DEBUG???1?/*使用debug模式*/

#define CONFIG_DM9000_BASE??0x20000000?/*基地址*/

#define DM9000_IO?????0x20000000?/*IO地址*/

#define DM9000_DATA?????x20000004?/*數(shù)據(jù)地址*/

為了簡化U-Boot系統(tǒng)的設(shè)置,還可以把網(wǎng)絡(luò)參數(shù)通過宏進(jìn)行定義。

TFTP相關(guān)設(shè)置

為了實(shí)現(xiàn)嵌入式系統(tǒng)在上電后自動通過TFTP從主機(jī)下載并運(yùn)行μClinux操作系統(tǒng),需要設(shè)置U-Boot的自啟動命令。下面的命令是設(shè)置環(huán)境變量 tftp_boot,它包含的操作是通過tftp命令將文件名為uImage的文件從主機(jī)下載至目標(biāo)系統(tǒng)的0x1000000地址處。下載完畢之后,從 0x1000000處對嵌入式操作系統(tǒng)解壓縮并運(yùn)行:

set tftp_boot ‘tftp 0x1000000 uImage;bootm 0×1000000’

接下來將tftp_boot設(shè)置為自啟動命令:

set bootcmd run tftp_boot

還可以通過設(shè)置bootdelay環(huán)境變量來改變U-Boot運(yùn)行自啟動命令之前的等待時間。

最后要使用U-Boot的save命令來將剛才設(shè)置的環(huán)境變量保存到Flash中。

為了讓目標(biāo)系統(tǒng)能夠正確地從主機(jī)中下載操作系統(tǒng),要對主機(jī)的TFTP服務(wù)器進(jìn)行設(shè)置,主機(jī)的IP地址必須與U-Boot中設(shè)置的服務(wù)器IP地址相同,其次是主機(jī)中文件的名字必須與U-Boot的環(huán)境變量tftp_boot中設(shè)置的文件名相同。

通過以上的設(shè)置,現(xiàn)在目標(biāo)系統(tǒng)上電之后,在設(shè)定的時間之內(nèi)沒有任何按鍵的情況下,就會通過網(wǎng)絡(luò)從主機(jī)的TFTP服務(wù)器下載并運(yùn)行μClinux操作系統(tǒng)。

經(jīng)驗(yàn)和建議

前面我們定義了一個宏CONFIG_DM9000_DEBUG,定義它是為了在系統(tǒng)調(diào)試的過程中輸出程序運(yùn)行的相關(guān)信息,便于跟蹤系統(tǒng)運(yùn)行和查找錯誤。在系統(tǒng)的調(diào)試階段打開相應(yīng)的調(diào)試開關(guān)是很有必要的,但是當(dāng)系統(tǒng)完成調(diào)試準(zhǔn)備投入正常運(yùn)行的時候,為了提高整個系統(tǒng)的運(yùn)行效率,必須關(guān)掉相應(yīng)的調(diào)試開關(guān)。要去掉網(wǎng)絡(luò)調(diào)試信息的輸出,只需要把CONFIG_DM9000_DEBUG宏的定義語句注釋掉就可以,對修改過的U-Boot重新編譯并運(yùn)行,文件的下載速度比之前有了成倍的提高。

結(jié)語

本文所討論的內(nèi)容不失一般性,可以本文為指導(dǎo),在其它應(yīng)用系統(tǒng)中實(shí)現(xiàn)嵌入式操作系統(tǒng)或者其它任何軟件系統(tǒng)的網(wǎng)絡(luò)加載。

責(zé)任編輯:gt

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19286

    瀏覽量

    229873
  • 控制器
    +關(guān)注

    關(guān)注

    112

    文章

    16367

    瀏覽量

    178122
  • 嵌入式
    +關(guān)注

    關(guān)注

    5082

    文章

    19126

    瀏覽量

    305303
收藏 人收藏

    評論

    相關(guān)推薦

    8051_DM9000AE參考接口電路

    ;8051_DM9000AE參考接口電路</font>,單片機(jī),DM9000A,DM9000AE,DM9000AEP<br/>8051單片機(jī)<br/>
    發(fā)表于 05-07 14:18

    DM9000A,DM9000C網(wǎng)絡(luò)接口電路圖

    DM9000A是現(xiàn)在用得比較多的一款10M/100M以太網(wǎng)控制,大概廠商推出DM9000A的目標(biāo)市場就是面向嵌入8位/16位MCU應(yīng)用產(chǎn)品。整個控制設(shè)計充公考慮了8位/16位MCU接
    發(fā)表于 04-07 15:29

    如何去實(shí)現(xiàn)S3C2440嵌入式系統(tǒng)的以太網(wǎng)接口設(shè)計?

    DM9000AE工作原理是什么?如何去實(shí)現(xiàn)S3C2440嵌入式系統(tǒng)的以太網(wǎng)接口設(shè)計?
    發(fā)表于 05-24 07:28

    基于S3C2440和DM9000AE的以太網(wǎng)接口的設(shè)計

    通信距離限制等優(yōu)點(diǎn),已經(jīng)被國內(nèi)外很多監(jiān)控、控制領(lǐng)域的研究人員廣泛關(guān)注,并在實(shí)際應(yīng)用中展露出顯著的優(yōu)勢。本文提出了一種基于DM9000AE網(wǎng)絡(luò)接口芯片和32位三星ARM9處理器S3C2440嵌入式
    發(fā)表于 11-05 06:30

    DM9000AE pdf,DM9000AE datashee

    The DM9000A is a fully integrated and cost-effectivelow pin count single chip Fast Ethernet
    發(fā)表于 12-25 21:43 ?77次下載

    dm9000ae中文資料,dm9000ae的中文手冊

    LOCAL BUS芯片現(xiàn)推薦一款DM9000AE網(wǎng)卡芯片,其基本特性是48PIN,10/100MLOCAL-BUS interface,工作模式8/16bit, 有AUTO-Mdix(自動翻轉(zhuǎn))、TCP/Ip加速(check sum offload)減輕CPU負(fù)擔(dān),提高整機(jī)效能,20
    發(fā)表于 12-25 21:51 ?944次下載
    <b class='flag-5'>dm9000ae</b>中文資料,<b class='flag-5'>dm9000ae</b>的中文手冊

    嵌入式處理器和數(shù)字信號處理器(DSP)選型指南

    ADI公司嵌入式體系結(jié)構(gòu)的特點(diǎn)包括簡單但功能強(qiáng)大的編程模型,并得到高質(zhì)量開發(fā)工具的支持。 Blackfin處理器 高性能、低功耗處理 Blackfi
    發(fā)表于 02-24 22:31 ?44次下載

    基于Blackfin處理器嵌入式數(shù)碼相框設(shè)計

    介紹了匯聚處理器Blackfin的基本功能, 給出了以 Blackfin嵌入式系統(tǒng)硬件平臺
    發(fā)表于 06-08 16:53 ?49次下載
    基于<b class='flag-5'>Blackfin</b><b class='flag-5'>處理器</b>的<b class='flag-5'>嵌入式</b>數(shù)碼相框設(shè)計

    DM9000AE工作原理 以太網(wǎng)接口電路設(shè)計

    限制等優(yōu)點(diǎn),已經(jīng)被國內(nèi)外很多監(jiān)控、控制領(lǐng)域的研究人員廣泛關(guān)注,并在實(shí)際應(yīng)用中展露出顯著的優(yōu)勢。本文提出了一種基于DM9000AE網(wǎng)絡(luò)接口芯片和32位三星ARM9處理器S3C2440嵌入式系統(tǒng)
    發(fā)表于 04-01 11:58 ?1.3w次閱讀
    <b class='flag-5'>DM9000AE</b>工作原理 以太網(wǎng)接口電路設(shè)計

    快速開發(fā)基于Blackfin處理器的視頻應(yīng)用

    快速開發(fā)基于Blackfin處理器的視頻應(yīng)用: 如何利用享有全面技術(shù)支持的硬件和軟件模塊,快速開發(fā)能夠在Blackfin處理器上運(yùn)行的視頻應(yīng)
    的頭像 發(fā)表于 06-06 04:45 ?3481次閱讀

    利用匯聚處理器Blackfin和uClinux系統(tǒng)實(shí)現(xiàn)嵌入式數(shù)碼相框的設(shè)計

    本文介紹了匯聚處理器Blackfin的基本功能,給出了以Blackfin嵌入式系統(tǒng)硬件平臺,
    的頭像 發(fā)表于 08-22 08:04 ?1379次閱讀

    如何構(gòu)建基于處理器嵌入式安全系統(tǒng)?

    嵌入式安全系統(tǒng)概述;嵌入式系統(tǒng)安全技術(shù);安全應(yīng)用處理器介紹 ;基于安全處理器
    的頭像 發(fā)表于 01-25 07:06 ?2562次閱讀
    如何構(gòu)建基于<b class='flag-5'>處理器</b>的<b class='flag-5'>嵌入式</b>安全<b class='flag-5'>系統(tǒng)</b>?

    Blackfin雙核嵌入式處理器

    Blackfin雙核嵌入式處理器
    發(fā)表于 03-19 12:27 ?0次下載
    <b class='flag-5'>Blackfin</b>雙核<b class='flag-5'>嵌入式</b><b class='flag-5'>處理器</b>

    ADSP-BF592:Blackfin嵌入式處理器

    ADSP-BF592:Blackfin嵌入式處理器
    發(fā)表于 03-21 15:08 ?4次下載
    ADSP-BF592:<b class='flag-5'>Blackfin</b><b class='flag-5'>嵌入式</b><b class='flag-5'>處理器</b>

    用于ADI Blackfin處理器的LabVIEW嵌入式模塊

    用于ADI Blackfin處理器的LabVIEW嵌入式模塊
    發(fā)表于 05-17 17:27 ?4次下載
    用于ADI <b class='flag-5'>Blackfin</b><b class='flag-5'>處理器</b>的LabVIEW<b class='flag-5'>嵌入式</b>模塊