《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 嵌入式技術(shù) > 設(shè)計(jì)應(yīng)用 > 基于OMAP3530的船用導(dǎo)航雷達(dá)終端軟件開發(fā)設(shè)計(jì)
基于OMAP3530的船用導(dǎo)航雷達(dá)終端軟件開發(fā)設(shè)計(jì)
來(lái)源:電子技術(shù)應(yīng)用2013年第11期
唐維智,鄭 浩,李志剛
中國(guó)電子科技集團(tuán)公司第二十八研究所,江蘇 南京210007
摘要: OMAP3530是基于ARM+DSP的雙核應(yīng)用處理器,廣泛應(yīng)用于低成本、小型化產(chǎn)品中。提出了基于OMAP3530雙核架構(gòu)的導(dǎo)航雷達(dá)顯示終端的軟件設(shè)計(jì)方案,詳細(xì)介紹了在Codec Engine架構(gòu)下ARM與DSP通信的實(shí)現(xiàn)方法。
中圖分類號(hào): TN957
文獻(xiàn)標(biāo)識(shí)碼: B
文章編號(hào): 0258-7998(2013)11-0017-03
Software design of a marine navigation radar system based on OMAP3530
Tang Weizhi,Zheng Hao,Li Zhigang
The 28th Research Institute of China Electronics Technology Group Corporation,Nanjing 210007,China
Abstract: OMAP3530 EVM, which is an application processor with ARM+DSP dual-core, is applied to the products with cheap cost and miniaturization. This paper presents the soft design scheme of the marine navigation radar display terminal based on OMAP3530 dual-core structure, and introduces how to implement the communication of dual-core with Codec Engine in detail.
Key words : OMAP3530;marine navigation radar;Codec Engine;DVSDK

    OMAP3530是TI公司提出的基于ARM和DSP的雙核應(yīng)用處理器[1],在單個(gè)芯片上集成了ARM Cortex-A8內(nèi)核、TMS320C64X+DSP內(nèi)核、圖像引擎、視頻加速器以及豐富的多媒體外設(shè)。用ARM作為應(yīng)用處理器進(jìn)行多樣化的應(yīng)用開發(fā),實(shí)現(xiàn)用戶界面接口,能夠保證實(shí)時(shí)性和編碼效率,降低開發(fā)成本;利用DSP進(jìn)行算法加速,既能夠保持算法的靈活性,又能提供強(qiáng)大的處理能力。

    船用導(dǎo)航雷達(dá)作為重要的無(wú)線電輔助導(dǎo)航設(shè)備,在船舶近海定位、引導(dǎo)船舶進(jìn)出港口、惡劣天氣航行及避碰導(dǎo)航等領(lǐng)域發(fā)揮重大作用。國(guó)內(nèi)導(dǎo)航雷達(dá)顯控終端大多采用基于PC的PCI雷達(dá)圖像卡或基于X86的計(jì)算機(jī)模塊。隨著現(xiàn)代電子技術(shù)的飛速發(fā)展,越來(lái)越多的嵌入式處理器被應(yīng)用于雷達(dá)設(shè)備中。本文介紹的導(dǎo)航雷達(dá)終端以O(shè)MAP3530嵌入式處理器為硬件平臺(tái),采用了Codec Engine框架下的軟件設(shè)計(jì)方案。該終端具有體積小、實(shí)時(shí)性高、穩(wěn)定性好、成本低、功耗小的優(yōu)點(diǎn)。
1 軟件架構(gòu)設(shè)計(jì)
    如圖1所示,根據(jù)處理器的工作分配,終端從縱向劃分為ARM子系統(tǒng)與DSP子系統(tǒng)。ARM子系統(tǒng)采用Linux操作系統(tǒng),DSP子系統(tǒng)采用DSP/BIOS操作系統(tǒng)。ARM核是精簡(jiǎn)指令集處理器,運(yùn)算能力相對(duì)較弱,主要負(fù)責(zé)終端整體控制功能。而DSP核是超長(zhǎng)指令集的處理器,適合處理大批量的數(shù)據(jù)傳輸和數(shù)據(jù)處理工作。

1.1 軟件框架
    如圖1所示,終端軟件分為顯控處理軟件、錄取跟蹤軟件、GPMC總線驅(qū)動(dòng)程序、Codec Engine。其中,顯控處理軟件在ARM核[2]上運(yùn)行,它基于QT界面框架[3],使用自定義繪圖和QT控件提供可視化的導(dǎo)航界面,負(fù)責(zé)終端整體控制功能;錄取跟蹤軟件在DSP核上運(yùn)行,負(fù)責(zé)處理運(yùn)算需求高的各種濾波、關(guān)聯(lián)算法,使導(dǎo)航雷達(dá)同時(shí)對(duì)多批目標(biāo)進(jìn)行實(shí)時(shí)錄取、ARPA跟蹤[4],并自動(dòng)計(jì)算出目標(biāo)的動(dòng)態(tài)信息,以發(fā)揮避碰導(dǎo)航的作用;GPMC總線驅(qū)動(dòng)程序?yàn)镕PGA與OMAP提供通信通道;FrameBuf顯示驅(qū)動(dòng)為QT與OMAP顯示模塊提供圖形數(shù)據(jù)寫入通道;Codec Engine為顯控處理軟件(ARM側(cè))與錄取跟蹤軟件(DSP側(cè))提供交互通道。
1.2 各軟件間數(shù)據(jù)通信流
    如圖1所示,各軟件間數(shù)據(jù)通信流包括雷達(dá)控制信息、雷達(dá)狀態(tài)信息、波門信息、航跡信息、界面圖形信息。顯控處理軟件通過(guò)GPMC總線驅(qū)動(dòng)經(jīng)FPGA讀取雷達(dá)狀態(tài)信息,寫入雷達(dá)操控信息;同時(shí)讀取波門和扇區(qū)信息,通過(guò)Codec Engine送至錄取跟蹤軟件。錄取跟蹤軟件通過(guò)Codec Engine將航跡信息送至顯控處理軟件。顯控處理軟件通過(guò)FrameBuf顯示驅(qū)動(dòng)將界面繪圖送入OMAP顯示緩沖。
2 在Codec Engine框架下的軟件開發(fā)
    雙核系統(tǒng)雖然擁有強(qiáng)大的處理能力,但由于ARM和DSP分別對(duì)應(yīng)不同的指令集和編譯器,要使雙核系統(tǒng)配合工作,分擔(dān)不同的任務(wù),雙核之間的協(xié)調(diào)通信是一個(gè)關(guān)鍵的因素。TI的數(shù)字視頻軟件開發(fā)包(DVSDK)提供了Codec Engine來(lái)實(shí)現(xiàn)ARM與DSP的協(xié)同工作[5]。Codec Engine引入了遠(yuǎn)程過(guò)程調(diào)用(RPC)的概念[6],它是指在另外一個(gè)處理器上遠(yuǎn)程執(zhí)行的一個(gè)命令或者過(guò)程。在該終端中,錄取跟蹤軟件為Server端,顯控處理軟件為Client端,Client端應(yīng)用程序調(diào)用Codec Engine向Server端發(fā)送一個(gè)命令,Server端執(zhí)行命令并通過(guò)相應(yīng)的通信方式將結(jié)果返回給客戶端,進(jìn)而實(shí)現(xiàn)雙核的無(wú)縫連接與協(xié)調(diào)工作。
    在使用Codec Engine時(shí),一般會(huì)做以下操作:搭建開發(fā)環(huán)境、創(chuàng)立算法(Codec)、服務(wù)的集成(Server)以及Engine的集成和應(yīng)用(App)。
2.1 軟件開發(fā)環(huán)境搭建
    要構(gòu)建定制的Codec Engine配置,需要在TI公司提供的數(shù)字視頻開發(fā)套件DVSDK中修改相關(guān)軟件包的環(huán)境變量,搭建軟件開發(fā)環(huán)境。該套件中集成了多種軟件模塊,其核心是Codec Engine。要根據(jù)實(shí)際安裝情況分別修改以下文件的環(huán)境變量。
    (1)在DSPLINK軟件包中的Rules.mk、c64xxp_5.xx_linux.mk、omap3530_2.6.mk文件中分別修改內(nèi)核源碼路徑、ARM編譯器路徑、XDC工具路徑、DSP系統(tǒng)路徑等,完成后編譯生成dsplinkk.ko(ARM與DSP連接模塊)。;
    (2)在CMEM軟件包中的Rules.make文件中分別修改內(nèi)核源碼路徑、ARM編譯器路徑,完成后編譯生成cmemk.ko(內(nèi)存管理模塊)。
    (3)在電源管理軟件包中的Makefile文件中修改內(nèi)核源碼路徑、ARM編譯器路徑、DSPLINK安裝路徑,完成后編譯生成lpm_omap3530.ko(電源管理模塊)。
2.2 算法的創(chuàng)立
    按照xDAIS-DM標(biāo)準(zhǔn),目標(biāo)跟蹤算法模塊需要提供標(biāo)準(zhǔn)中所定義的一些接口的實(shí)現(xiàn)函數(shù),并且需要對(duì)算法模塊中用到的一些結(jié)構(gòu)作出定義。擴(kuò)展xDM規(guī)范中已有的標(biāo)準(zhǔn)接口是產(chǎn)生自定義算法模塊的一種最常見的方式。本文的目標(biāo)跟蹤算法模塊利用VISA中的SCALE接口進(jìn)行xDM標(biāo)準(zhǔn)算法庫(kù)的開發(fā)。圖2是SCALE接口中各個(gè)package的關(guān)系。

    codecs:在該文件夾下定義相關(guān)算法的.c和.h文件。為了使編譯器能識(shí)別自定義的.c文件,需要修改package.bld配置文件,將自定義的.c文件名添加到SRCS數(shù)組中,這個(gè)SRCS數(shù)組中包括了package中的所有.c文件。最后修改相應(yīng)的服務(wù)配置文件生成算法并將其打包,經(jīng)編譯生成scale_ti.a64P的lib庫(kù)文件,這就是所需要的codec。
    extensions:包括GPP端的stub庫(kù)和DSP端的skeleton庫(kù)(通過(guò).c和.h文件配置stub和skeleton函數(shù)表),經(jīng)編譯生成scale.a64P的lib庫(kù)文件。
2.3 服務(wù)的集成
    servers:算法服務(wù)集成。修改配置文件,分配內(nèi)存生成一個(gè)DSP端的可執(zhí)行程序all.x64P文件,這就是所需要的DSP Server算法服務(wù)器,可被應(yīng)用程序直接調(diào)用。
    (1)修改all.tcf文件。對(duì)128 MB的外部RAM空間即DDR存儲(chǔ)區(qū)進(jìn)行分配,這塊空間是ARM和DSP可以共享的,ARM通過(guò)MMU(Memory Management Unit)看到的是內(nèi)存的虛擬地址,但DSP直接使用物理地址。內(nèi)存分配具體如表1所示。

 

 

    (2)修改all.cfg文件。主要對(duì)線程屬性進(jìn)行設(shè)置。線程屬性主要包括棧大小、內(nèi)存段的ID以及優(yōu)先級(jí)等。堆棧大小要大于所需要的容量,這樣比較安全。
2.4 Engine集成和應(yīng)用
    apps:apps中定義了Engine的配置,對(duì)于應(yīng)用程序是在本地(ARM)執(zhí)行還是在遠(yuǎn)端(DSP)執(zhí)行,通過(guò)配置腳本文件local.cfg和remote.cfg即可實(shí)現(xiàn),在腳本文件中指明Engine名稱和Server名稱。經(jīng)編譯生成app_remote.av5T可執(zhí)行程序。
    App通過(guò)調(diào)用各種VISA(Video,Image,Speech,Audio)APIs實(shí)現(xiàn)具體算法實(shí)例[7-8],VISA APIs通常分為四個(gè)部分:MOD_create(用于創(chuàng)建算法實(shí)例)、MOD_control(用于動(dòng)態(tài)地修改算法實(shí)例的屬性)、MOD_process(用于對(duì)算法傳遞輸入數(shù)據(jù)流做處理并返回一個(gè)輸出數(shù)據(jù)流)、MOD_delete(用于刪除編碼器實(shí)例,釋放創(chuàng)建編碼器實(shí)例時(shí)占用的系統(tǒng)資源)。以應(yīng)用程序調(diào)用MOD_process為例,GPP端和DSP端的交互過(guò)程大致如圖3所示。

    (1)應(yīng)用程序(GPP端)調(diào)用MOD_process()函數(shù);
    (2)Codec Engine將調(diào)用信息和調(diào)用所需參數(shù)傳遞給GPP端的stub;
    (3)stub將參數(shù)打包封裝成消息,并且將GPP端的虛擬地址映射到DSP端的物理地址;
    (4)Codec Engine將消息傳遞到DSP端的skeleton;
    (5)skeleton將參數(shù)解析出來(lái),并且調(diào)用xDAIS算法的process函數(shù);
    (6)skeleton再將參數(shù)打包返回,以消息隊(duì)列形式返回給應(yīng)用程序,然后stub再對(duì)參數(shù)進(jìn)行解析。
    最后將編譯生成的all.x64P算法服務(wù)器、app_remote.av5T可執(zhí)行程序、dsplinkk.ko、cmemk.ko、lpm_omap3530.ko驅(qū)動(dòng)以及驅(qū)動(dòng)加載/卸載配置腳本loadmodules.sh、unloadmodules.sh一同拷入目標(biāo)板的同一文件夾執(zhí)行,即可實(shí)現(xiàn)目標(biāo)跟蹤。
    現(xiàn)代雷達(dá)終端價(jià)格高、體積大、功耗大,本文基于OMAP3530實(shí)現(xiàn)的船用導(dǎo)航雷達(dá)終端的軟件設(shè)計(jì),充分發(fā)揮了OMAP3530芯片的雙核特性,滿足高速處理和穩(wěn)定性的需求,使船載雷達(dá)終端的體積大大減小,成本大幅降低,為在中小船只上普及裝備導(dǎo)航雷達(dá)終端提供了一種新的解決方案,值得在現(xiàn)代船舶導(dǎo)航雷達(dá)中進(jìn)一步研究推廣。
參考文獻(xiàn)
[1] Texas Instruments.OMAP35x applications processor Texas Instruments OMAPTM family of products technical reference  manual[Z].2008.
[2] 李忠民,楊剛,顧亦然,等.ARM嵌入式VxWorks實(shí)踐教程[M].北京:北京航空航天大學(xué)出版社,2006.
[3] 袁鵬飛.24小時(shí)學(xué)通qt編程[M].北京:人民郵電出版社,2000.
[4] 王德生,彭勇.ARPA系統(tǒng)與艦船導(dǎo)航雷達(dá)顯示[J].中國(guó)雷達(dá),1998(02):40-42.
[5] 溫君安.基于Davinci處理器的語(yǔ)音算法設(shè)計(jì)和優(yōu)化實(shí)現(xiàn)[D].杭州:浙江大學(xué),2007.
[6] 劉永春.基于DSP和ARM的車牌識(shí)別系統(tǒng)設(shè)計(jì)[J].微型機(jī)與應(yīng)用,2012,31(22):80-82.
[7] 林上升.基于OMAP3530硬件平臺(tái)的ARM和DSP協(xié)同開發(fā)方法[J].電子技術(shù)應(yīng)用,2013,39(2):6-8.
[8] 孫連三.基于OMAP的手持設(shè)備嵌入式系統(tǒng)研究[J].計(jì)算機(jī)工程與設(shè)計(jì),2008(9):2242-2245.

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
午夜在线视频观看日韩17c| 亚洲国产精品一区二区www| 一区二区三区在线视频观看| 国产精品亚洲激情| 国产精品你懂的在线| 欧美性事在线| 国产精品国产三级国产普通话三级 | 亚洲欧洲一区二区三区| 亚洲国产精品精华液2区45| 揄拍成人国产精品视频| 在线看视频不卡| 亚洲国产精品成人一区二区| 亚洲福利专区| 亚洲精品日韩激情在线电影| 亚洲精品久久视频| 99re在线精品| 亚洲手机在线| 午夜在线精品偷拍| 久久精品视频在线播放| 亚洲区欧美区| 一本大道久久精品懂色aⅴ| 亚洲视频在线观看三级| 午夜久久tv| 久久精品中文字幕免费mv| 久久一日本道色综合久久| 免费久久99精品国产自| 欧美aⅴ99久久黑人专区| 欧美久久影院| 国产精品久久网站| 国产一区999| 亚洲电影毛片| 一本综合久久| 欧美一区2区三区4区公司二百| 欧美在线免费一级片| 亚洲欧洲一区二区三区| 在线视频精品| 欧美在线免费播放| 农村妇女精品| 国产精品九九久久久久久久| 国产日韩欧美一区二区三区在线观看| 国产一区二区三区在线免费观看| 18成人免费观看视频| 一区二区三区 在线观看视| 午夜一区二区三区在线观看| 亚洲欧洲在线一区| 亚洲综合99| 久久亚洲春色中文字幕| 欧美日本国产精品| 国产视频一区二区在线观看| 亚洲国产成人精品久久久国产成人一区 | 亚洲国产精品va在线看黑人| 一本色道久久综合狠狠躁篇怎么玩| 亚洲欧美综合国产精品一区| 亚洲激情视频| 亚洲欧美网站| 欧美www在线| 国产精品亚洲综合久久| 亚洲国产高清在线观看视频| 一区二区三区精密机械公司 | 一本在线高清不卡dvd | 一本大道久久a久久精品综合| 亚洲欧美不卡| 亚洲精品国产日韩| 欧美一区二区三区四区高清| 欧美激情视频给我| 国产日本欧美一区二区| 亚洲伦理在线免费看| 欧美在线关看| 亚洲已满18点击进入久久| 免费永久网站黄欧美| 国产精品午夜视频| 亚洲精品久久视频| 亚洲国产成人91精品| 午夜精品久久久| 欧美精品一区二区三区在线播放| 国产一区二区三区四区三区四 | 亚洲欧美日韩一区二区在线| 免费在线看成人av| 国产性做久久久久久| 亚洲最黄网站| 亚洲欧洲免费视频| 久久久久一区二区三区| 国产精品家教| 日韩亚洲欧美精品| 日韩香蕉视频| 久久综合色天天久久综合图片| 国产精品美女久久久浪潮软件 | 亚洲综合大片69999| 欧美激情一区二区三区高清视频| 国产亚洲精品一区二555| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲视频导航| 欧美成人午夜激情在线| 国产亚洲一区二区三区在线观看| 一本色道久久综合亚洲精品按摩| 91久久国产自产拍夜夜嗨 | 欧美不卡视频一区| 国语自产偷拍精品视频偷| 亚洲综合色视频| 亚洲女人小视频在线观看| 欧美日韩精品免费观看视频完整| 亚洲成人在线视频网站| 久久爱www.| 久久九九久精品国产免费直播| 国产精品理论片在线观看| 一区二区三区黄色| 亚洲视频一区在线观看| 欧美日韩午夜| 亚洲乱码精品一二三四区日韩在线| 亚洲精品一区在线观看香蕉| 麻豆av一区二区三区| 伊人春色精品| 亚洲欧洲另类国产综合| 蜜乳av另类精品一区二区| 激情综合在线| 亚洲精品国产精品乱码不99 | 久久精品视频99| 国产私拍一区| 香蕉成人啪国产精品视频综合网| 午夜精品999| 国产精品五区| 性高湖久久久久久久久| 久久国产色av| 国产亚洲va综合人人澡精品| 欧美亚洲午夜视频在线观看| 午夜精品一区二区三区电影天堂| 国产精品免费看片| 亚洲欧美乱综合| 久久精品亚洲一区二区三区浴池| 国产日韩欧美视频在线| 欧美在线观看一区| 蜜桃av一区二区三区| 亚洲黄色一区| 在线视频亚洲一区| 国产精品扒开腿爽爽爽视频| 亚洲淫性视频| 久久久无码精品亚洲日韩按摩| 国模大胆一区二区三区| 亚洲国内欧美| 欧美另类在线观看| 一区二区三区欧美成人| 欧美影院午夜播放| 在线观看日韩国产| 99视频一区二区| 国产精品高潮在线| 午夜精品久久久久久久99樱桃 | 欧美巨乳在线观看| 亚洲图片欧美一区| 久久久久一本一区二区青青蜜月| 一区二区三区在线免费视频| 日韩视频在线观看国产| 国产精品久久久久久久第一福利 | 亚洲综合色视频| 国内精品久久久| 亚洲美女诱惑| 国产精品视频一二| 亚洲高清自拍| 欧美色网一区二区| 午夜在线一区二区| 欧美成人视屏| 亚洲一区二区在线观看视频| 麻豆91精品91久久久的内涵| 99视频一区二区三区| 久久精品亚洲乱码伦伦中文| 亚洲经典一区| 久久精彩视频| 亚洲毛片一区| 久久久99久久精品女同性 | 亚洲深夜福利在线| 美女视频黄免费的久久| 一区二区国产日产| 久久久噜噜噜久久| 99精品免费网| 两个人的视频www国产精品| 在线亚洲伦理| 欧美成人精品在线观看| 亚洲在线视频| 欧美精品久久久久久久久久| 欧美一区二区三区视频在线观看| 欧美精品久久久久久久| 欧美一区亚洲一区| 欧美午夜精品电影| 亚洲国产精品999| 国产毛片一区| 亚洲视频第一页| 亚洲国产精品电影| 久久久久国产精品午夜一区| 一本大道久久a久久综合婷婷| 美女诱惑一区| 午夜精品久久久久久久久久久| 欧美日本国产一区| 亚洲国产毛片完整版| 国产精品入口麻豆原神| 99人久久精品视频最新地址| 黄色工厂这里只有精品| 亚欧美中日韩视频| 在线视频亚洲欧美| 欧美日韩国产欧| 亚洲激情视频在线| 国内精品久久久久久久97牛牛|