《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計應(yīng)用 > DSP ARM雙核系統(tǒng)的通信接口設(shè)計
DSP ARM雙核系統(tǒng)的通信接口設(shè)計
單片機與嵌入式系統(tǒng)應(yīng)用
摘要: 本文介紹了使用ARM和DSP雙CPU構(gòu)成的雙核嵌入式系統(tǒng)的硬件平臺,以及源代碼開放的Linux作為嵌入式系統(tǒng)中操作系統(tǒng)的方法,給出了系統(tǒng)設(shè)計的總體框圖,詳細(xì)介紹了ARM和DSP通信接口的設(shè)計。這一設(shè)計方法可以適用于大多數(shù)現(xiàn)代嵌入式系統(tǒng)的設(shè)計,有一定的實用價值。
關(guān)鍵詞: DSP 雙核 通信接口 ARM Linux TMS320C5416
Abstract:
Key words :

   嵌入式系統(tǒng)的核心是嵌入式微處理器和嵌入式操作系統(tǒng)。早期的嵌入式系統(tǒng)硬件核心是各種類型的8位和16位單片機;而近年來32位處理器以其高性能、低價格,得到了廣泛的應(yīng)用。近年來,又出現(xiàn)了另一類數(shù)據(jù)密集處理型芯片DSP" title="DSP">DSP。DSP由于其特殊的結(jié)構(gòu)、專門的硬件乘法器和特殊的指令,使其能快速地實現(xiàn)各種數(shù)字信號處理及滿足各種高實時性要求。隨著現(xiàn)代嵌入式系統(tǒng)的復(fù)雜度越來越高,操作系統(tǒng)已成為嵌入式系統(tǒng)不可缺少的部分。免費的嵌入式操作系統(tǒng),如 Linux" title="Linux">Linux等,隨著自身不斷的改善,得到了飛速的發(fā)展。Linux是一個免費的、強大的、可信賴的、具有可伸縮性與擴充性的操作系統(tǒng)。Linux實現(xiàn)了許多現(xiàn)代化操作系統(tǒng)的理論,并且支持完整的硬件驅(qū)動程序、網(wǎng)絡(luò)通信協(xié)議與多處理器的架構(gòu),其源碼的公開更有利于操作系統(tǒng)嵌入式應(yīng)用。

  基于上述分析,筆者開發(fā)了基于ARM" title="ARM">ARM和DSP芯片的雙核" title="雙核">雙核嵌入式系統(tǒng)。系統(tǒng)充分利用了ARM和DSP的各自特點,既可以使用ARM和DSP芯片進(jìn)行協(xié)同開發(fā),也可以利用ARM或DSP進(jìn)行獨立開發(fā)。操作系統(tǒng)選用了Linux,以利于充分發(fā)揮系統(tǒng)的效能。

1 系統(tǒng)的總體設(shè)計

  由于ARM芯片的控制性能較強,在嵌入式系統(tǒng)中ARM主要用于控制和少量的數(shù)據(jù)處理。這樣,一方面要求CPU要低功耗和有足夠的時鐘頻率來運行操作系統(tǒng),以滿足便攜式的要求;另一方面也要求其有足夠種類的接口,以利于性能的擴展。基于以上考慮,在開發(fā)平臺中選用HY7202作為CPU。

  DSP作為數(shù)據(jù)運算部分,可以充分發(fā)揮其對數(shù)字信號處理的獨特優(yōu)勢。TI公司的C54xx系列16位定點DSP以其高性價比普遍應(yīng)用于各類通信、便攜式應(yīng)用當(dāng)中。考慮到對數(shù)字視頻和數(shù)字圖像等大數(shù)據(jù)吞吐量應(yīng)用場合的處理要求,選用TI公司的TMS320C5416" title="TMS320C5416">TMS320C5416芯片。其時鐘頻率最高可達(dá)到 206 MHz,系統(tǒng)總體框圖如圖1所示。

      系統(tǒng)軟件平臺結(jié)構(gòu)如圖2所示,軟件平臺分ARM部分和DSP部分,以及ARM和DSP的接口軟件設(shè)計部分。ARM部分以Hynix公司PATCH的ARM Linux Version 2.4.18為操作系統(tǒng),并在此基礎(chǔ)之上移植Linux標(biāo)準(zhǔn)庫GLIBC、LIBJPG、LIBPNG、IMLIB、LIBWWW、LIBFLASH及漢字庫。圖形界面以Microwindows 0.9及其控件庫FLNX提供嵌入式圖形界面平臺。系統(tǒng)平臺具有強大的網(wǎng)絡(luò)通信功能,通過平臺WEBSERVER、FTP、TELNET、INETD等網(wǎng)絡(luò)工具和應(yīng)用程序能方便地開發(fā)基于Internet的網(wǎng)絡(luò)終端、遠(yuǎn)程控制、遠(yuǎn)程數(shù)據(jù)采集、遠(yuǎn)程數(shù)據(jù)處理產(chǎn)品。在應(yīng)用程序?qū)由?系統(tǒng)平臺集成窗口管理程序, 全中文化網(wǎng)絡(luò)瀏覽器(支持HTML、XML),Flash播放器(支持Flash4、Flash5、Flash6),文本編輯器,游戲等用于PDA開發(fā), 機頂盒上網(wǎng)解決方案,以及可用于嵌入式數(shù)據(jù)采集、處理的虛擬示波器等。

      DSP部分通過提供完整的HPI驅(qū)動程序(DSP部分)及通信協(xié)議,通過增加相應(yīng)數(shù)據(jù)處理程控制算法程序,利用HPI并行接口與主機ARM通信進(jìn)行數(shù)據(jù)交換,可用于各種實時處理,控制領(lǐng)域。

  此外,DSP和ARM可以各自作為獨立的系統(tǒng)使用,它們均有完整的子系統(tǒng)軟件。子系統(tǒng)之間聯(lián)系的核心是DSP器件本身帶有的HPI接口。

 

2 ARM和DSP的通信接口" title="通信接口">通信接口設(shè)計

(1) DSP的HPI口介紹

  HPI是TMS320C54X等芯片提供的一種并行端口,專門用于DSP和外部主機并行通信。HPI接口有標(biāo)準(zhǔn)HPI接口和增強型HPI接口。對于C5416和C5420DSP器件,它們的主機接口為增強型主機接口。標(biāo)準(zhǔn)HPI接口是一個8位總線接口,通過2個8位字節(jié)組合在一起形成1個16 字。增強型HPI接口分8位和16位兩種。8位增強型主機接口和標(biāo)準(zhǔn)HPI接口操作時序一樣,主要區(qū)別在于標(biāo)準(zhǔn)型只能訪問2 KB專用RAM,而增強型可以訪問DSP的整個RAM區(qū)。16位增強型HPI接口采用16位總線,只要一個主機操作就能完成訪問操作。

(2) HPI硬件連線

  HMS30C7202與TMS320C5416接口電路如圖3所示。系統(tǒng)將HPI接口所有控制寄存器、地址寄存器、數(shù)據(jù)寄存器統(tǒng)一編址,映射到HMS30C7202物理地址0X0C000000開始的I/O內(nèi)存空間。

    利用地址線RA[3:0]產(chǎn)生HPI訪問所需的控制信號。A0與A1決定訪問寄存器類型。A2決定訪問的是第一個字節(jié)還是第二個字節(jié):A2=0 時,表示寫入的數(shù)據(jù)為第一個字節(jié);A2=1時,表示寫入的數(shù)據(jù)為第二個字節(jié)。在HPI-8中所有地址線和控制線是在HDS1和HDS2的下降沿采樣,而不是由HR/W決定,因此HR/W通過地址線A3表示當(dāng)前操作是讀還是寫,而數(shù)據(jù)鎖存信號由nRCS3和nRW0相與后共同產(chǎn)生。KSCAN[2]設(shè)置為 HMS30C7202的PORTA中斷輸入腳,DSP通過中斷方式與Linux底層HPI驅(qū)動程序通信。

3 ARM和DSP的通信接口驅(qū)動程序設(shè)計

  Linux是Unix操作系統(tǒng)的一種變種。在Linux下編寫驅(qū)動程序的原理和思想完全類似于其他的Unix系統(tǒng),但它和DOS或Window 環(huán)境下的驅(qū)動程序有很大的區(qū)別。Linux驅(qū)動程序可以編譯進(jìn)內(nèi)核,也可以模塊形式動態(tài)地加入和卸載。Linux的這種特點可根據(jù)目標(biāo)系統(tǒng)裁減內(nèi)核,更適合于嵌入式系統(tǒng)。

(1) Linux驅(qū)動程序基本原理

  在Linux中所有設(shè)備分為字符設(shè)備、塊設(shè)備和網(wǎng)絡(luò)設(shè)備三種,所有設(shè)備都看成普通文件,因此可以通過用操縱普通文件相同的系統(tǒng)調(diào)用來打開、關(guān)閉、讀取和寫入設(shè)備。系統(tǒng)中每個設(shè)備都用一種設(shè)備特殊文件來表示。

  在Linux中,設(shè)備驅(qū)動程序是一組相關(guān)函數(shù)的集合。它包含設(shè)備服務(wù)子程序和中斷處理程序,每個設(shè)備服務(wù)子程序只處理一種設(shè)備或者緊密相關(guān)的設(shè)備。其目的就是從與設(shè)備無關(guān)的軟件中接受抽象的命令并執(zhí)行。當(dāng)執(zhí)行一條請求時,具體操作是根據(jù)控制器驅(qū)動程序提供的接口,并利用中斷機制去調(diào)用中斷服務(wù)子程序配合設(shè)備來完成這個請求。設(shè)備程序利用結(jié)構(gòu)file_operations與文件系統(tǒng)聯(lián)系起來。在Linux下驅(qū)動程序裝載如圖4所示。

(2) HPI驅(qū)動程序

  HPI接口可用I/O端口方式,也可以用I/O存取方式。系統(tǒng)平臺采用I/O存取方式,將HPI訪問控制寄存器、數(shù)據(jù)寄存器、地址寄存器,映射到內(nèi)存物理地址為0X0C000000開始的空間,通過訪問存儲器指令對HPI進(jìn)行操作。HPI具體物理地址定義如下:


#defineHPI_BASE0X0C000000//HPI基地址
#define HPD_READ_LOWHPI_BASE+0X0012
//讀數(shù)據(jù)寄存器第一字節(jié)
?
#define HPA_WRITE_HIGHHPI_BASE+0X000C
//寫地址寄存器第二字節(jié)

  在Linux下,類似Windows,程序不能直接訪問物理地址。設(shè)備驅(qū)動程序是內(nèi)核的一部分,它像內(nèi)核中其他代碼一樣運行在內(nèi)核模式,驅(qū)動程序如果出錯就會使系統(tǒng)受到嚴(yán)重破壞,因此需要將物理地址映射到內(nèi)核空間。在Linux下通過virtul_address=(u32)ioremap (HPI_BASE,HPI_LENGTH)實現(xiàn)。驅(qū)動程序主要結(jié)構(gòu)如下:


struct file_operations hpi_fops={
  owner:THIS_MODULE,
  read: hpi_read,
  write: hpi_write,
  poll : hpi_poll,
  open: hpi_open,
  release: hpi_release,
};

  HPI通信協(xié)議采用幀結(jié)構(gòu),由于增強型HPI接口允許訪問DSP內(nèi)部RAM所有空間,系統(tǒng)通信在DSP內(nèi)部分配2 K字(16位)作為幀緩沖區(qū),讀寫各1 K字,協(xié)議采用一位滑動窗口協(xié)議。幀格式如表1所列。

結(jié)語

  本文介紹了使用ARM和DSP雙CPU構(gòu)成的雙核嵌入式系統(tǒng)的硬件平臺,以及源代碼開放的Linux作為嵌入式系統(tǒng)中操作系統(tǒng)的方法,給出了系統(tǒng)設(shè)計的總體框圖,詳細(xì)介紹了ARM和DSP通信接口的設(shè)計。這一設(shè)計方法可以適用于大多數(shù)現(xiàn)代嵌入式系統(tǒng)的設(shè)計,有一定的實用價值。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲一区二区三区高清不卡| 欧美h视频在线| 国产精品成人免费| 亚洲国产精品欧美一二99| 欧美视频在线一区| 久久激情网站| 欧美视频在线观看 亚洲欧| 久久国产精品第一页| 国产精品国产三级国产a| 亚洲精品国精品久久99热| 国产欧美69| 亚洲在线免费观看| 狠狠色综合播放一区二区| 久久精品久久99精品久久| 欧美一区二区视频免费观看| 国产视频在线观看一区| 久久免费的精品国产v∧| 久久精品午夜| 亚洲国产你懂的| 欧美精品一区二区在线观看| 一本色道久久88精品综合| 亚洲高清在线观看一区| 毛片av中文字幕一区二区| 欧美一区网站| 亚洲国产精品尤物yw在线观看| 欧美二区乱c少妇| 亚洲视频一区在线观看| 日韩亚洲欧美成人一区| 国产精品亚洲美女av网站| 久久综合亚州| 一区二区电影免费在线观看| 一区二区三区 在线观看视| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲在线观看免费| 欧美亚洲日本国产| 国产精品五区| 久久久久久久久久码影片| 欧美影院一区| 最新成人在线| 国产精品久久久久久久7电影| 欧美一区二区在线观看| 亚洲大胆av| 亚洲美女精品成人在线视频| 国产精品高潮粉嫩av| 欧美在线影院在线视频| 亚洲韩国精品一区| 一区二区三区日韩欧美精品| 国产精品自拍小视频| 蜜桃av噜噜一区| 亚洲欧美日韩国产中文| 欧美亚洲网站| 日韩一级成人av| 国内精品久久久久久久影视蜜臀 | 国产欧美日韩精品专区| 久久免费视频在线| 亚洲婷婷在线| 亚洲精品国产日韩| 欧美在线视频免费| 亚洲一二三区在线观看| 91久久国产综合久久蜜月精品| 国产欧美日韩免费看aⅴ视频| 欧美大胆人体视频| 久久久久久精| 亚洲欧美一区二区在线观看| 亚洲精品国产精品乱码不99按摩| 亚洲欧美精品在线观看| 亚洲免费福利视频| 亚洲日本电影| 亚洲国产mv| 在线观看一区欧美| 国产亚洲成av人在线观看导航 | 午夜一区二区三视频在线观看| 亚洲毛片在线| 日韩视频免费| 亚洲区一区二| 亚洲欧洲综合另类| 亚洲国产成人精品久久久国产成人一区| 亚洲综合色在线| 亚洲一区免费在线观看| 亚洲天堂免费在线观看视频| 日韩亚洲精品电影| 一区二区国产日产| 一区二区三区蜜桃网| 一本久道久久综合狠狠爱| 亚洲六月丁香色婷婷综合久久| 日韩视频永久免费观看| 日韩系列在线| 亚洲午夜国产一区99re久久| 亚洲在线国产日韩欧美| 欧美一级淫片aaaaaaa视频| 欧美伊人久久久久久午夜久久久久 | aa级大片欧美三级| 亚洲综合色噜噜狠狠| 久久国产乱子精品免费女| 老牛影视一区二区三区| 欧美韩国在线| 国产精品久久久久久久久久三级| 国产欧美日韩在线观看| 国产一区二区日韩精品| 亚洲激情视频网站| 亚洲免费视频在线观看| 亚洲高清视频一区二区| 亚洲视频在线观看免费| 久久精品99久久香蕉国产色戒| 女女同性精品视频| 国产精品久久久久91| 国外视频精品毛片| 99精品视频免费在线观看| 久久国产一区二区| 亚洲一区免费网站| 久久精品免费电影| 欧美午夜激情在线| 伊伊综合在线| 亚洲视频欧美在线| 亚洲欧洲另类国产综合| 欧美一区二区三区免费视频| 欧美黄色一级视频| 国语自产精品视频在线看抢先版结局 | 久久av红桃一区二区小说| 这里只有精品视频在线| 美女性感视频久久久| 国产免费成人av| 日韩手机在线导航| 亚洲人成精品久久久久| 久久久91精品国产一区二区三区| 欧美日韩一区二区欧美激情| 在线看一区二区| 久久精品国产精品亚洲综合| 亚洲欧美影院| 国产精品久久久久影院色老大| 最新日韩中文字幕| 亚洲日本中文字幕| 久久躁狠狠躁夜夜爽| 国产一级久久| 欧美一激情一区二区三区| 香蕉成人伊视频在线观看 | 91久久久久| 蜜乳av另类精品一区二区| 在线视频观看日韩| 亚洲国产欧美日韩精品| 欧美大片在线看| 亚洲乱亚洲高清| 亚洲午夜精品久久久久久浪潮| 欧美国产日韩精品| 亚洲美女av在线播放| 亚洲一区二区精品| 国产精品日本精品| 性欧美暴力猛交69hd| 久久免费视频这里只有精品| 亚洲第一页中文字幕| 一本不卡影院| 国产精品美女999| 久久国产精彩视频| 欧美精品成人91久久久久久久| 日韩一二三区视频| 久久九九免费| 亚洲精品国精品久久99热一| 亚洲影视在线播放| 好看的日韩视频| 一本色道精品久久一区二区三区| 国产精品久久999| 亚洲电影免费观看高清完整版| 欧美国产精品久久| 亚洲欧美日韩一区在线| 欧美风情在线| 欧美一级免费视频| 欧美日韩亚洲视频| 亚洲国产精品久久| 国产精品福利在线观看| 亚洲国产综合91精品麻豆| 国产精品一区视频| 一区二区三区.www| 伊人久久亚洲热| 久久精品99| 亚洲在线网站| 欧美色精品天天在线观看视频 | 一本久道久久久| 韩日欧美一区二区三区| 午夜精品成人在线视频| 亚洲黄色影片| 欧美大片免费观看| 亚洲欧美中文字幕| 国产精品美女久久久久久2018| 日韩亚洲视频在线| 亚洲国产mv| 美日韩精品免费观看视频| 久久福利毛片| 国语自产精品视频在线看| 香蕉精品999视频一区二区| 宅男精品视频| 欧美日韩一区精品| 亚洲视频高清| 99精品热6080yy久久| 欧美日韩黄视频| 一区二区激情小说| 99热在这里有精品免费| 欧美日韩国产电影| 亚洲一区二区欧美| 亚洲一级黄色av| 国产偷国产偷亚洲高清97cao|