《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > Linux下ARM/DSP雙核系統通信接口設計
Linux下ARM/DSP雙核系統通信接口設計
摘要: 本文介紹了使用ARM和DSP雙CPU構成的雙核嵌入式系統的硬件平臺,以及源代碼開放的Linux作為嵌入式系統中操作系統的方法,給出了系統設計的總體框圖,詳細介紹了ARM和DSP通信接口的設計。這一設計方法可以適用于大多數現代嵌入式系統的設計,有一定的實用價值。
Abstract:
Key words :

 引 言

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

  基于上述分析,筆者開發了基于ARM和DSP芯片的雙核嵌入式系統。系統充分利用了ARM和DSP的各自特點,既可以使用ARM和DSP芯片進行協同開發,也可以利用ARM或DSP進行獨立開發。操作系統選用了Linux,以利于充分發揮系統的效能。

  1 系統的總體設計

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

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

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

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

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

  2 ARM和DSP的通信接口設計

  (1) DSP的HPI口介紹

  HPI是TMS320C54X等芯片提供的一種并行端口,專門用于DSP和外部主機并行通信。HPI接口有標準HPI

  接口和增強型HPI接口。對于C5416和C5420DSP器件,它們的主機接口為增強型主機接口。標準HPI接口是一個8位總線接口,通過2個8位字節組合在一起形成1個16位字節。增強型HPI接口分8位和16位兩種。8位增強型主機接口和標準HPI接口操作時序一樣,主要區別在于標準型只能訪問2 KB專用RAM,而增強型可以訪問DSP的整個RAM區。16位增強型HPI接口采用16位總線,只要一個主機操作就能完成訪問操作。[next]

  (2) HPI硬件連線

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

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

  3 ARM和DSP的通信接口驅動程序設計

  Linux是Unix操作系統的一種變種。在Linux下編寫驅動程序的原理和思想完全類似于其他的Unix系統,但它和DOS或Window環境下的驅動程序有很大的區別。Linux驅動程序可以編譯進內核,也可以模塊形式動態地加入和卸載。Linux的這種特點可根據目標系統裁減內核,更適合于嵌入式系統。

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

  在Linux中所有設備分為字符設備、塊設備和網絡設備三種,所有設備都看成普通文件,因此可以通過用操縱普通文件相同的系統調用來打開、關閉、讀取和寫入設備。系統中每個設備都用一種設備特殊文件來表示。

  在Linux中,設備驅動程序是一組相關函數的集合。它包含設備服務子程序和中斷處理程序,每個設備服務子程序只處理一種設備或者緊密相關的設備。其目的就是從與設備無關的軟件中接受抽象的命令并執行。當執行一條請求時,具體操作是根據控制器驅動程序提供的接口,并利用中斷機制去調用中斷服務子程序配合設備來完成這個請求。設備程序利用結構file_operations與文件系統聯系起來。在Linux下驅動程序裝載如圖4所示。[next]

  (2) HPI驅動程序

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

#defineHPI_BASE0X0C000000//HPI基地址
#define HPD_READ_LOWHPI_BASE+0X0012
//讀數據寄存器第一字節

#define HPA_WRITE_HIGHHPI_BASE+0X000C
//寫地址寄存器第二字節

 

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

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

 

  HPI通信協議采用幀結構,由于增強型HPI接口允許訪問DSP內部RAM所有空間,系統通信在DSP內部分配2 KB(16位)作為幀緩沖區,讀寫各1 KB,協議采用一位滑動窗口協議。幀格式如表1所列。

  結語

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

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美在线视频日韩| 亚洲肉体裸体xxxx137| 欧美一二三视频| 亚洲私拍自拍| 国产精品资源在线观看| 久久久999成人| 亚洲国产欧美一区二区三区同亚洲| 亚洲电影免费在线| 欧美日韩一区二区视频在线| 午夜伦理片一区| 久久精品一区中文字幕| 亚洲精品日本| 国产偷自视频区视频一区二区| 麻豆成人综合网| 一区二区三区四区蜜桃| 亚洲午夜激情免费视频| 黄色亚洲在线| 欧美特黄a级高清免费大片a级| 久久成人av少妇免费| 欧美一区二区三区在线观看视频| 亚洲欧美福利一区二区| 亚洲第一页中文字幕| 99精品国产福利在线观看免费| 国产日韩在线亚洲字幕中文| 国产喷白浆一区二区三区| 欧美韩日高清| 久久本道综合色狠狠五月| 久久大逼视频| 中文久久乱码一区二区| 欧美一区二区播放| 亚洲欧洲精品一区二区精品久久久| 国产精品乱码妇女bbbb| 免费人成精品欧美精品| 亚洲一区免费视频| 久久精品一区中文字幕| 91久久精品一区二区别| 亚洲午夜日本在线观看| 亚洲一区二区黄| 欧美专区日韩专区| 亚洲天堂成人在线视频| 中文精品视频| 亚洲欧美激情四射在线日| 亚洲美女在线一区| 激情婷婷欧美| 国产日韩高清一区二区三区在线| 国产午夜精品一区理论片飘花| 国内精品国产成人| 国产精品久久久久久一区二区三区 | 欧美成人一区二区三区片免费| 亚洲欧美视频在线观看| 亚洲精品视频在线| 亚洲国产精品精华液2区45| 亚洲啪啪91| 亚洲在线免费| 久久一区二区精品| 久久精品成人| 欧美韩日一区| 国产人久久人人人人爽| 亚洲国产成人精品久久久国产成人一区 | 麻豆精品国产91久久久久久| 欧美日韩国产亚洲一区| 欧美88av| 国产精品久久久久9999| 欧美日精品一区视频| 国产日韩精品视频一区| 亚洲国产高清aⅴ视频| 亚洲婷婷国产精品电影人久久| 久久成人免费视频| 亚洲一区二区三区高清| 久久免费视频在线| 欧美日韩中文字幕综合视频| 国精产品99永久一区一区| 一本到12不卡视频在线dvd| 日韩小视频在线观看| 欧美一区二区成人| 亚洲无线一线二线三线区别av| 一区二区三区国产盗摄| 久久国产福利国产秒拍| 欧美日韩国产综合在线| 韩日成人av| 亚洲一区精彩视频| 99成人免费视频| 日韩视频精品| 久久精品国产欧美亚洲人人爽 | 欧美日韩免费高清一区色橹橹| 国产亚洲精品一区二555| 国产一区二区观看| 夜夜嗨av一区二区三区| 亚洲国产美国国产综合一区二区| 亚洲欧美日韩一区二区三区在线观看| 欧美aⅴ一区二区三区视频| 国产精品午夜在线| 国产欧美日韩综合一区在线播放| 亚洲欧洲综合另类| 亚洲国产另类久久精品| 久久精品一区二区三区四区| 国产精品高潮在线| 一本久久a久久免费精品不卡| 亚洲国产精品一区在线观看不卡 | 欧美日韩激情网| 亚洲国产精品久久久久婷婷884| 性欧美xxxx视频在线观看| 亚洲专区国产精品| 欧美色区777第一页| 亚洲精品小视频在线观看| 亚洲免费大片| 欧美韩国在线| 91久久香蕉国产日韩欧美9色| 亚洲国产视频直播| 久久综合狠狠综合久久综青草| 鲁大师成人一区二区三区 | 性做久久久久久久免费看| 亚洲免费小视频| 国产精品成人免费| 国产一区欧美| 小辣椒精品导航| 欧美在线视频a| 国产日韩一区二区三区| 欧美一区二区三区在线视频| 亚洲茄子视频| 欧美 日韩 国产一区二区在线视频 | 亚洲激情国产| 欧美成人免费网站| 亚洲国产婷婷综合在线精品| 日韩视频免费大全中文字幕| 亚洲精品偷拍| 欧美激情一二区| 国产欧美日韩亚洲精品| 亚洲综合视频网| 亚洲娇小video精品| 卡一卡二国产精品| 在线播放豆国产99亚洲| 夜夜嗨av一区二区三区中文字幕| 日韩午夜三级在线| 欧美乱妇高清无乱码| 国产乱人伦精品一区二区| 亚洲综合成人在线| 久久久精品国产99久久精品芒果| 国产一区在线视频| 亚洲国产视频直播| 欧美理论电影网| 一本久道久久综合婷婷鲸鱼| 亚洲欧美日韩直播| 国产视频一区欧美| 久久精品五月婷婷| 欧美成人在线免费视频| 亚洲欧洲偷拍精品| 亚洲午夜小视频| 国产精品视频一二| 久久精品视频在线观看| 欧美精品少妇一区二区三区| 一本色道久久99精品综合 | 久久激情视频免费观看| 樱桃成人精品视频在线播放| 日韩网站免费观看| 国产精品久久一区主播| 久久成人精品无人区| 久久理论片午夜琪琪电影网| 国产精品国产福利国产秒拍| 亚洲一区二区三区免费在线观看| 久久久国产精品一区二区三区| 亚洲成色www久久网站| 一区二区三区高清在线| 国产欧美日韩麻豆91| 亚洲激情欧美激情| 国产精品福利在线观看网址| 欧美在线视频免费观看| 欧美激情中文字幕一区二区| 亚洲永久免费| 欧美成人免费在线观看| 一区二区三区日韩| 99在线热播精品免费| 男女激情视频一区| 99亚洲一区二区| 欧美专区亚洲专区| 亚洲精品国精品久久99热| 篠田优中文在线播放第一区| 伊人天天综合| 午夜精品久久久久久99热| 激情av一区二区| 亚洲一区二区三| 激情伊人五月天久久综合| 亚洲一区二区在线看| 伊人成人开心激情综合网| 亚洲永久免费av| 在线观看一区欧美| 亚洲欧美在线播放| 亚洲国产精选| 欧美在线日韩精品| 一区二区三区高清视频在线观看| 久久综合色播五月| 亚洲一区制服诱惑| 欧美日韩国产另类不卡| 亚洲高清不卡av| 国产精品一区二区三区久久久| 日韩午夜av电影| 在线电影一区| 欧美在线网址| 亚洲图片欧美午夜| 欧美精品1区2区|