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

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

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

DSP/BIOS通信方式DSP應(yīng)用系統(tǒng)輸入輸出中的應(yīng)用分析

電子設(shè)計(jì) ? 來(lái)源:?jiǎn)纹瑱C(jī)與嵌入式系統(tǒng)應(yīng)用 ? 作者:丁宜棟,駱萬(wàn)文, ? 2021-06-17 16:41 ? 次閱讀

作者:丁宜棟,駱萬(wàn)文,叢劍飛,王海城

對(duì)于數(shù)字信號(hào)處理應(yīng)用來(lái)說(shuō),數(shù)據(jù)的通信很關(guān)鍵。在TI公司DSP/BIOS環(huán)境下有3種通信方式,即基于管道(PIP,pipe)的通信、基于流(SIO,stream I/O)通道的通信以及基于主機(jī)(HST,host)通道的通信。每一種通信方式都是通過(guò)調(diào)度其相應(yīng)的內(nèi)核對(duì)象來(lái)完成的。DSP/BIOS提供了管理每一種通信方式的模塊及相應(yīng)地API調(diào)用,通過(guò)這些模塊及調(diào)用,可以完成DSP環(huán)境下的輸入/輸出 (I/O)。本文在對(duì)各種通信方式進(jìn)行簡(jiǎn)要介紹的基礎(chǔ)上,對(duì)各種通信方式進(jìn)行比較,并給出利用PIP對(duì)象進(jìn)行數(shù)據(jù)通信的1個(gè)例子。

1 通信方式簡(jiǎn)介

(1)主機(jī)通信

主機(jī)通信方式下,由HST對(duì)象完成主機(jī)與目標(biāo)機(jī)之間的通信。HST對(duì)象靜態(tài)配置為輸入/輸出,每一個(gè)HST對(duì)象內(nèi)部是用數(shù)據(jù)管道對(duì)象來(lái)實(shí)現(xiàn)的。

開發(fā)DSP應(yīng)用時(shí),可以應(yīng)用HST對(duì)象來(lái)模仿數(shù)據(jù)流和測(cè)試程序算法對(duì)數(shù)據(jù)的處理。在程序開發(fā)的早期,特別是在測(cè)試信號(hào)處理算法時(shí),程序使用輸入通道對(duì)象訪問(wèn)來(lái)自主機(jī)文件中的數(shù)據(jù),以及使用輸出通道對(duì)象把算法處理過(guò)的結(jié)果反饋回主機(jī)一側(cè),以供查驗(yàn)或比較。在程序開發(fā)的后期,當(dāng)算法開發(fā)完畢時(shí),可以把HST對(duì)象改回到PIP對(duì)象,通過(guò)利用PIP對(duì)象完成外設(shè)真實(shí)數(shù)據(jù)與目標(biāo)應(yīng)用程序之間的通信。

(2)管道通信

管道(PIP)對(duì)象用于管理塊I/O(也稱為基于流的I/O或者異步I/O)。每一個(gè)PIP對(duì)象維護(hù)著一個(gè)分為固定數(shù)量和固定大小的緩沖區(qū)(稱為幀)。所有的I/O操作在每一刻只處理1幀。盡管每一幀長(zhǎng)度是固定的,但是應(yīng)用程序可以在每一幀中放置可變數(shù)量的數(shù)據(jù)(但不能超過(guò)最大值)。管道有兩端,一端為寫線程,一端為讀線程。寫線程一端用于向管道中添加數(shù)據(jù),讀線程一端用于從管道中讀取數(shù)據(jù)。管道能夠用于在程序內(nèi)的任意2個(gè)線程之間傳遞數(shù)據(jù)。經(jīng)常地,管道的一端由ISR控制,另一端由軟件中斷函數(shù)控制。數(shù)據(jù)通知函數(shù)(也稱為回調(diào)函數(shù))用于同步數(shù)據(jù)的傳輸,包括通知讀函數(shù)和通知寫函數(shù)。當(dāng)讀或?qū)?幀數(shù)據(jù)時(shí),這些函數(shù)被觸發(fā),以通知程序有空閑幀或者有數(shù)據(jù)可以利用。

(3)流通信

流是一個(gè)通道,通過(guò)它,數(shù)據(jù)在應(yīng)用程序與 I/O設(shè)備之間傳輸。流通道可以是只讀的(用于輸入)或者只寫的(用于輸出)。它對(duì)所有I/O設(shè)備提供了一個(gè)簡(jiǎn)單通用接口,允許應(yīng)用程序完全不用考慮每個(gè)設(shè)備操作的細(xì)節(jié)。流I/O的一個(gè)重要方面是它的異步特性。當(dāng)應(yīng)用程序正在處理當(dāng)前緩沖區(qū)時(shí),一個(gè)新的輸入緩沖區(qū)正在被添充和以前的緩沖區(qū)正在被輸出。流交換的是指針而不是數(shù)據(jù),這就大大減少了開銷,使得程序更能滿足實(shí)時(shí)約束的要求。流模塊(SIO)通過(guò)驅(qū)動(dòng)程序來(lái)與不同類型的設(shè)備打交道。驅(qū)動(dòng)程序由DEV(Device)模塊管理。

設(shè)備驅(qū)動(dòng)程序是管理一類設(shè)備的軟件模塊。這些模塊遵從通用接口(由DEV提供),因此,流函數(shù)能夠發(fā)出普通請(qǐng)求。圖 1 給出了流與設(shè)備之間的交互示意圖。

(4)各種通信方式比較

DSP/BIOS支持兩種不同的數(shù)據(jù)傳輸模型,一種是管道模型,由PIP與HST模塊使用;另一種是流模型,由SIO與DEV模塊使用。2個(gè)模型都要求1個(gè)管道或者流具有1個(gè)讀線程和1個(gè)寫線程。2個(gè)模型都通過(guò)拷貝指針而不是數(shù)據(jù)來(lái)完成數(shù)據(jù)的拷貝。一般來(lái)說(shuō),管道模型支持低級(jí)通信,而流模型支持高級(jí)的、與設(shè)備無(wú)關(guān)的I/O。具體情況如表1所列。

2 基于管道通信的一個(gè)例子

在基于以上分析的基礎(chǔ)上,給出利用管道進(jìn)行通信的1個(gè)例子。該例是音頻處理的一個(gè)例子。數(shù)據(jù)從數(shù)據(jù)源輸入到編碼器以后經(jīng)量化通過(guò)串行口輸入到目標(biāo)機(jī),目標(biāo)機(jī)處理完畢后再經(jīng)串行口發(fā)送到編碼器,由編碼器經(jīng)揚(yáng)聲器輸出。圖2給出數(shù)據(jù)的流程圖。

(1)管道設(shè)計(jì)

該例中,設(shè)計(jì)了DSS_rxPipe和DSS_txPipe兩個(gè)管道,其中DSS_rxPipe用于數(shù)據(jù)的接收,DSS_txPipe用于數(shù)據(jù)的發(fā)送。

(2)線程設(shè)計(jì)

由于每個(gè)管道分別對(duì)應(yīng)1個(gè)讀寫線程,因此,發(fā)送管道與接收管道總共需要4個(gè)讀寫線程。本例中為了簡(jiǎn)化設(shè)計(jì),只設(shè)計(jì)了2個(gè)線程。其中,音頻處理函數(shù)(設(shè)計(jì)為軟件中斷SWI)既作為接收管道的讀線程又作為發(fā)送管道的寫線程;串行口接收中斷處理服務(wù)例程ISR既作為接收管道的寫線程又作為發(fā)送管道的讀線程。

每次中斷發(fā)生時(shí),串行口中斷服務(wù)例程(ISR)把數(shù)據(jù)接收寄存器(DRR)中的數(shù)據(jù)字(32位)拷貝到數(shù)據(jù)接收管道的一空閑幀中。當(dāng)1幀被填滿時(shí),ISR把該滿幀寫到數(shù)據(jù)接收管道中(通過(guò)調(diào)用PIP_put),供該管道的讀線程(即音頻處理函數(shù))讀取。音頻處理函數(shù)執(zhí)行時(shí),它讀取接收管道中的一滿幀,處理完畢后再把它寫到發(fā)送管道的一空閑幀中,供該管道的讀線程(即ISR)發(fā)送。每次ISR觸發(fā)時(shí),它從發(fā)送管道中讀取一滿幀(若有的話),并每次32位字地發(fā)向串行口發(fā)送寄存器(DXR)直到1幀中的所有數(shù)據(jù)發(fā)送完畢。然后,該空閑幀被回收到發(fā)送管道,供音頻處理函數(shù)(即該管道的寫線程使用)。需要注意的是,由于例子當(dāng)中發(fā)送速率與接收速率一樣,因此,中斷處理函數(shù)不但負(fù)責(zé)數(shù)據(jù)的接收也負(fù)責(zé)數(shù)據(jù)的發(fā)送,并且每次中斷執(zhí)行時(shí)只發(fā)送1個(gè)32位字。

(3)需注意的問(wèn)題

PIP_alloc和PIP_put由PIP對(duì)象的寫線程調(diào)用,PIP_get和PIP_free由PIP對(duì)象的讀線程調(diào)用,這種調(diào)用順序是非常重要的。若打亂這種調(diào)用順序,將會(huì)產(chǎn)生不可預(yù)測(cè)的后果。因此,每一次對(duì)PIP_alloc的調(diào)用都要跟著對(duì)PIP_put的調(diào)用才能繼續(xù)調(diào)用PIP_alloc;對(duì)于PIP_get,情況也是如此。

另外,為了避免PIP調(diào)用過(guò)程中產(chǎn)生遞歸,作為通知讀/寫函數(shù)的一部分,應(yīng)該避免調(diào)用PIP API函數(shù)。如果為了效率起見必須要這樣做,那么對(duì)諸如此類的調(diào)用應(yīng)該加以保護(hù),以阻止同一管道對(duì)象的重入以及錯(cuò)誤的PIP API調(diào)用順序。例如,在發(fā)送管道的通知讀函數(shù)以及接收管道的通知寫函數(shù)的開始部分,我們添加了如下語(yǔ)句,以避免遞歸調(diào)用:

static

Int nested = 0;

if (nested){/*防止由于調(diào)用PIP_get函數(shù)而產(chǎn)生的遞歸調(diào)用*/

return;

}

nested =1;

3 總 結(jié)

在DSP/BIOS提供的3種通信方式中,由于PIP對(duì)象的效率很高,因此使得它在基于DSP應(yīng)用系統(tǒng)的輸入輸出中得到了廣泛的應(yīng)用。但是,我們?cè)诶闷渌峁┑谋憷耐瑫r(shí),一定要妥善處理好通知讀/寫函數(shù)的編寫工作,以免發(fā)生遞歸調(diào)用,產(chǎn)生災(zāi)難性的后果。

責(zé)任編輯:gt

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

    關(guān)注

    551

    文章

    7823

    瀏覽量

    346815
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5250

    瀏覽量

    119192
  • 主機(jī)
    +關(guān)注

    關(guān)注

    0

    文章

    958

    瀏覽量

    34854
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    DSP BIOS 出錯(cuò)原因

    使用分析:RTXD可以在DSP/BIOS中使用,也可以脫離DSP/BIOS使用;目前CCS Simulator不支持RTDX,故RTDX必須
    發(fā)表于 06-12 15:11

    基于DSPBIOS的多信號(hào)并行處理軟件架構(gòu)設(shè)計(jì)

    模塊,負(fù)責(zé)各個(gè)調(diào)度模塊之間信息的交換傳遞,保證調(diào)度模塊之間的同步和互斥。通信模塊,允許應(yīng)用程序在目標(biāo)系統(tǒng)和主機(jī)之間交流數(shù)據(jù)。配置模塊,負(fù)責(zé)芯片底層硬件的配置。另外DSPBIOS還帶有
    發(fā)表于 09-03 17:18

    基于6747的網(wǎng)絡(luò)通信問(wèn)題,不使用DSP/BIOS系統(tǒng)

    您好我最近在使用6747進(jìn)行網(wǎng)絡(luò)通信的調(diào)試工作。要求不能使用DSP/BIOS系統(tǒng)實(shí)現(xiàn)UDP協(xié)議,我想請(qǐng)教一下幾個(gè)問(wèn)題:1,在不使用DSP/
    發(fā)表于 08-02 08:53

    實(shí)時(shí)操作系統(tǒng) DSP/BIOS

    ,主要負(fù)責(zé)DSP與外設(shè)的交互,從外設(shè)讀寫數(shù)據(jù)。由于硬件中斷直接與硬件打交道,對(duì)應(yīng)的中斷服務(wù)程序ISR應(yīng)盡可能短小精焊。HWI不引起任務(wù)調(diào)度,它在處理完數(shù)據(jù)的輸入輸出后調(diào)用SWI_post()來(lái)調(diào)度相應(yīng)
    發(fā)表于 04-24 07:00

    DSP/BIOS和EMAC通信怎么用?

    1)看了挺多關(guān)于DSP/BIOS介紹的文檔,知道是什么,由什么組成,有什么功能,但是,到底怎么用?我在CCS環(huán)境下創(chuàng)建的工程跟DSP/BIOS如何扯上關(guān)系?具體怎么去操作?另外經(jīng)常說(shuō)要
    發(fā)表于 04-17 09:58

    DSP集成開發(fā)環(huán)境--CCS及DSP/BIOS的原理與應(yīng)用

    DSP集成開發(fā)環(huán)境--CCS及DSP/BIOS的原理與應(yīng)用:CCS是TI開發(fā)的一個(gè)完整的DSP集成開發(fā)環(huán)境,也是目前使用得最為廣泛的DSP
    發(fā)表于 10-30 10:54 ?264次下載
    <b class='flag-5'>DSP</b>集成開發(fā)環(huán)境--CCS及<b class='flag-5'>DSP</b>/<b class='flag-5'>BIOS</b>的原理與應(yīng)用

    DSP BIOS實(shí)時(shí)內(nèi)核在視頻目標(biāo)跟蹤系統(tǒng)的應(yīng)用

    介紹一種TMS320 DSP的實(shí)時(shí)內(nèi)核——DSPBIOS,并闡述其啟動(dòng)過(guò)程和基于DSPBIOS內(nèi)核開發(fā)實(shí)時(shí)目標(biāo)跟蹤
    發(fā)表于 12-04 11:35 ?6次下載

    基于DSPDSP/BIOS的實(shí)時(shí)雷達(dá)信號(hào)采集與處理系統(tǒng)

    基于DSPDSP/BIOS的實(shí)時(shí)雷達(dá)信號(hào)采集與處理系統(tǒng):介紹了一種在實(shí)時(shí)操作系統(tǒng)DSP
    發(fā)表于 01-16 16:59 ?25次下載

    如何創(chuàng)建一個(gè)DSP/BIOS程序

    如何創(chuàng)建一個(gè)DSP/BIOS程序?qū)嶒?yàn)?zāi)康?#1048698; 掌握DSP/BIOS的的開發(fā)步驟􀁺 認(rèn)識(shí)DSP/
    發(fā)表于 04-07 10:56 ?71次下載

    DSP/BIOS環(huán)境下的數(shù)據(jù)通信

    DSP/BIOS環(huán)境下的數(shù)據(jù)通信原理 摘要:討論和比較DSP/BIOS環(huán)境下的各種通信
    發(fā)表于 03-04 17:29 ?902次閱讀
    <b class='flag-5'>DSP</b>/<b class='flag-5'>BIOS</b>環(huán)境下的數(shù)據(jù)<b class='flag-5'>通信</b>

    基于DSP_BIOS的PLC執(zhí)行系統(tǒng)開發(fā)

    分析了目前軟PLC在實(shí)時(shí)性方面存在的不足;提出采用基于DSP/BIOS實(shí)時(shí)內(nèi)核的嵌入式處理器的軟PLC執(zhí)行系統(tǒng)架構(gòu)。首先,通過(guò)分析軟PLC執(zhí)
    發(fā)表于 04-15 19:28 ?15次下載
    基于<b class='flag-5'>DSP_BIOS</b>的PLC執(zhí)行<b class='flag-5'>系統(tǒng)</b>開發(fā)

    DSP_BIOS在以太網(wǎng)通信節(jié)點(diǎn)中的應(yīng)用

    DSP_BIOS在以太網(wǎng)通信節(jié)點(diǎn)中的應(yīng)用
    發(fā)表于 10-20 11:03 ?2次下載
    <b class='flag-5'>DSP_BIOS</b>在以太網(wǎng)<b class='flag-5'>通信</b>節(jié)點(diǎn)中的應(yīng)用

    DSP_BIOS講座

    DSP_BIOS講座
    發(fā)表于 10-20 11:26 ?3次下載
    <b class='flag-5'>DSP_BIOS</b>講座

    實(shí)時(shí)操作系統(tǒng)DSP_BIOSDSP開發(fā)的應(yīng)用

    實(shí)時(shí)操作系統(tǒng)DSP_BIOSDSP開發(fā)的應(yīng)用
    發(fā)表于 10-20 16:18 ?8次下載
    實(shí)時(shí)操作<b class='flag-5'>系統(tǒng)</b><b class='flag-5'>DSP_BIOS</b>在<b class='flag-5'>DSP</b>開發(fā)<b class='flag-5'>中</b>的應(yīng)用

    寄存器的輸入輸出方式

    寄存器的輸入輸出方式是數(shù)字電路設(shè)計(jì)至關(guān)重要的部分,它決定了數(shù)據(jù)如何在寄存器中進(jìn)出以及處理的效率。下面將詳細(xì)探討寄存器的幾種主要輸入輸出方式,包括并行輸入輸出、串行
    的頭像 發(fā)表于 09-05 14:09 ?177次閱讀