色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于Blackfin處理器和DM9000AE實現嵌入式軟件系統的設計

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

引言

嵌入式系統應用越來越復雜和多樣化的今天,嵌入式軟件系統也變得越來越復雜,并且在復雜的應用系統中通常都需要嵌入式操作系統的支持,這樣嵌入式操作系統鏡像文件的尺寸往往就會變得比較大。可以選擇通過網絡將嵌入式操作系統加載到SDRAM中運行來解決這一問題。另外,通過網絡進行操作時,只要將需要升級的軟件系統在主機端更新,然后嵌入式系統就可以通過網絡來加載更新后的軟件系統了。

硬件電路設計

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

基于Blackfin處理器和DM9000AE實現嵌入式軟件系統的設計

圖1 系統功能框圖

DM9000AE驅動

本文中所述系統的網絡模塊基于DM9000AE,可以與多種不同的處理器方便地進行連接。

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

數據傳輸

數據傳輸經過以下幾個步驟:

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

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

2. 將數據幀寫入到DM9000AE的傳輸FIFO SRAM中。

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

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

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

for (i = 0; i 《 TX_length; i++) /* TX_length表示待傳輸的數據幀長度*/

DM9000_outb(TX_data, DM9000_DATA); /*待傳輸的數據幀保存在數組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)中設置傳輸的數據幀的長度。

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

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

4. 開始傳輸數據幀。

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

5. 檢查傳輸是否完成。

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

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

printf(“transmission timeout\n”);

break;

}

}

數據接收

類似地,數據接收也要經過如下幾個步驟:

1. 檢查DM9000AE的接收FIFO SRAM中是否接收到數據。

DM9000_ior(0xF0);

RX_ready= DM9000_inb (DM9000_DATA);

/*讀取數據到達標志 */

if (RX_ready == 0)

return 0; /*如果沒有數據到達,就返回調用此函數的原函數*/

if (RX_ready 》 1)

reset(); /*當RX_ready 大于1時就說明DM9000AE處于異常狀態,需要復位*/

當RX_ready等于1時說明有數據到達,進入第二步

2. 被接收數據幀的狀態和長度檢查。

(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. 接收數據幀。

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. 對接收的數據幀進行錯誤檢驗。

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校驗和錯誤*/

if (RX_status & 0x8000) {

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

if (RX_length 》 1536) {

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

dm9000_reset();}

}

網絡啟動的實現

本系統是在基于BF533+ DM9000AE的嵌入式硬件平臺上,通過U-Boot在自啟動時使用TFTP從網絡加載μclinux

U-Boot源代碼移植

DM9000AE 的驅動位于U-Boot的driver目錄下,如果要使用此驅動,可以在include/configs目錄下相應系統的頭文件中加入宏定義語句。自定義系統可以根據基于相同體系結構的參考系統頭文件來創建自己的頭文件,比如,本系統以ezkit533系統為模板創建頭文件 mybf533.h,并且加入以下宏定義語句:

#define CONFIG_DRIVER_DM9000???1?/*使用DM9000AE驅動*/

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

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

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

#define DM9000_DATA?????x20000004?/*數據地址*/

為了簡化U-Boot系統的設置,還可以把網絡參數通過宏進行定義。

TFTP相關設置

為了實現嵌入式系統在上電后自動通過TFTP從主機下載并運行μClinux操作系統,需要設置U-Boot的自啟動命令。下面的命令是設置環境變量 tftp_boot,它包含的操作是通過tftp命令將文件名為uImage的文件從主機下載至目標系統的0x1000000地址處。下載完畢之后,從 0x1000000處對嵌入式操作系統解壓縮并運行:

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

接下來將tftp_boot設置為自啟動命令:

set bootcmd run tftp_boot

還可以通過設置bootdelay環境變量來改變U-Boot運行自啟動命令之前的等待時間。

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

為了讓目標系統能夠正確地從主機中下載操作系統,要對主機的TFTP服務器進行設置,主機的IP地址必須與U-Boot中設置的服務器IP地址相同,其次是主機中文件的名字必須與U-Boot的環境變量tftp_boot中設置的文件名相同。

通過以上的設置,現在目標系統上電之后,在設定的時間之內沒有任何按鍵的情況下,就會通過網絡從主機的TFTP服務器下載并運行μClinux操作系統。

經驗和建議

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

結語

本文所討論的內容不失一般性,可以本文為指導,在其它應用系統中實現嵌入式操作系統或者其它任何軟件系統的網絡加載。

責任編輯:gt

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    19265

    瀏覽量

    229679
  • 控制器
    +關注

    關注

    112

    文章

    16339

    瀏覽量

    177856
  • 嵌入式
    +關注

    關注

    5082

    文章

    19111

    瀏覽量

    304856
收藏 人收藏

    評論

    相關推薦

    8051_DM9000AE參考接口電路

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

    DM9000A,DM9000C網絡接口電路圖

    DM9000A是現在用得比較多的一款10M/100M以太網控制,大概廠商推出DM9000A的目標市場就是面向嵌入8位/16位MCU應用產品。整個控制設計充公考慮了8位/16位MCU接
    發表于 04-07 15:29

    如何去實現S3C2440嵌入式系統的以太網接口設計?

    DM9000AE工作原理是什么?如何去實現S3C2440嵌入式系統的以太網接口設計?
    發表于 05-24 07:28

    基于S3C2440和DM9000AE的以太網接口的設計

    通信距離限制等優點,已經被國內外很多監控、控制領域的研究人員廣泛關注,并在實際應用中展露出顯著的優勢。本文提出了一種基于DM9000AE網絡接口芯片和32位三星ARM9處理器S3C2440嵌入式
    發表于 11-05 06:30

    DM9000AE pdf,DM9000AE datashee

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

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

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

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

    ADI公司嵌入式體系結構的特點包括簡單但功能強大的編程模型,并得到高質量開發工具的支持。 Blackfin處理器 高性能、低功耗處理 Blackfi
    發表于 02-24 22:31 ?44次下載

    基于Blackfin處理器嵌入式數碼相框設計

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

    DM9000AE工作原理 以太網接口電路設計

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

    快速開發基于Blackfin處理器的視頻應用

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

    利用匯聚處理器Blackfin和uClinux系統實現嵌入式數碼相框的設計

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

    如何構建基于處理器嵌入式安全系統?

    嵌入式安全系統概述;嵌入式系統安全技術;安全應用處理器介紹 ;基于安全處理器
    的頭像 發表于 01-25 07:06 ?2558次閱讀
    如何構建基于<b class='flag-5'>處理器</b>的<b class='flag-5'>嵌入式</b>安全<b class='flag-5'>系統</b>?

    Blackfin雙核嵌入式處理器

    Blackfin雙核嵌入式處理器
    發表于 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嵌入式處理器
    發表于 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嵌入式模塊
    發表于 05-17 17:27 ?4次下載
    用于ADI <b class='flag-5'>Blackfin</b><b class='flag-5'>處理器</b>的LabVIEW<b class='flag-5'>嵌入式</b>模塊
    主站蜘蛛池模板: 肉肉高潮液体高干文H| 久久亚洲免费视频| 国产亚洲人成网站在线观看播放 | 国产精品麻豆a啊在线观看| 国产精品国产三级国AV在线观看| 国产精一品亚洲二区在线播放| 国色精品VA在线观看免费视频| 久久99热这里只频精品6| 男人J进女人P| 乳液全集电影在线观看| 亚洲国产在线精品国自产拍五月 | 国产精品A久久777777| 精品国产福利在线视频| 麻豆出品国产AV在线观看| 人妻 中文无码 中出| 亚洲成AV人电影在线观看| 在线观看亚洲免费人成网址 | 精品国产乱码久久久久久下载| 久久热精品18国产| 色琪琪无码成人AV视频| 亚洲涩福利高清在线| 99久久久A片无码国产精| 岛国在线无码免费观| 花蝴蝶免费版高清版| 嫩草影院地址一二三| 午夜国产福利| 5566av资源| 国产精品96久久久久久AV网址 | 亚洲人交性视频| BL全肉多攻NP高H| 国产亚洲制服免视频| 秘密教学93话恩爱久等了免费| 射死你天天日| 中文视频在线| 国产精品一区二区AV97| 蜜桃最新网址| 小女生RAPPER入口| BL低喘贯穿顶弄老师H| 精品一区二区三区色花堂 | 母乳女神春日もな| 亚洲成人综合在线|