新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 嵌入式 FIFO 數據傳輸系統設計

        嵌入式 FIFO 數據傳輸系統設計

        作者: 時間:2011-06-28 來源:網絡 收藏
        系統硬件結構
        C6727B和其他DSP有一個較大的區別,就是C6727B不再提供專門的外部中斷引腳,而是采用GPIO引腳和dMAX配合使用,通過寄存器的設置將GPIO引腳配置成外部中斷引腳。本文為了實現的實時操作,一旦外設向寫入,即發出中斷信號到DSP的CPU,通知CPU讀取。為此,需要使用1個外部中斷引腳,將C6727B的音頻串口的AXR[8]配置成通用的GPIO引腳,并在dMAX中設置成中斷引腳。此時需要將音頻串口的CONFIGMACSP0寄存器設置為0x0001,如圖3所示。此時音頻串口不能再作為普通的音頻口使用,而是配置成IO接口。

        本文引用地址:http://www.104case.com/article/150549.htm

        圖3 中斷功能設置框圖


        從圖3中可以看出,配置好音頻串口后,一旦AXR[8]引腳有上升沿到,則McASP0激活dMAX的事件26,向CPU發送內部中斷13。McASP的與中斷相關的寄存器配置是實現以上方案的重點。使用PFUNC寄存器將其配置成通用IO引腳;PDIR寄存器控制IO引腳的方向;如果是輸出引腳則由POUT引腳輸出高低電平,如果是輸入引腳,則由PDIN寄存器讀出該引腳的狀態;此外,可以使用PDCLR和PSET寄存器清除或者設置輸出引腳的狀態。

        系統軟件
        系統軟件主要包括McASP的初始化、dMAX的初始化、的初始化、中斷使能等。系統主程序只需要等待中斷進行相應的處理,主要的傳輸工作都是dMAX按照軟件配置自動完成,不需要CPU參與。圖4是實現由外設寫FIFO,DSP讀取FIFO數據的流程。圖中虛線部分表示由dMAX獨立完成的工作,實線部分表示由CPU完成的工作。兩者之間通過內部中斷方式實現狀態的交流。

        圖4 系統軟件流程


        為了提高FIFO的讀寫速率,一般采用突發方式進行讀寫。突發方式的讀時序如圖5所示。寫時序和讀時序類似。突發方式一次最多只能讀寫8個數據,也可以一次突發讀寫4個或者2個數據。突發讀寫時數據的建立和保持時間最少可以設置成1個時鐘周期,如圖中所示。但為了通信可靠,一般采用2個時鐘周期。突發方式最大的節省時間是連續的其他數據將不再需要建立和保持周期,而是直接進行讀寫,一般只需要兩個時鐘周期就可以完成一個數據的讀寫。最快情況下,突發讀寫8個數據只需要20個時鐘周期,讀寫速率達到53.2M×32b/s,滿足大部分設備的要求。

        圖5 突發讀時序圖

        總結
        dMAX的特有結構使得其可以實現FIFO。本文介紹了基于C6727B的dMAX的基本結構以及基于dMAX的FIFO軟硬件,設置通用GPIO引腳作為中斷,為了加快FIFO的傳輸速率,使用突發讀寫方式進行數據傳輸。

        linux操作系統文章專題:linux操作系統詳解(linux不再難懂)

        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 延吉市| 东台市| 霍州市| 南靖县| 伊金霍洛旗| 武平县| 泸定县| 秭归县| 鲜城| 铜川市| 沙田区| 民县| 安福县| 平远县| 桂林市| 筠连县| 红河县| 韩城市| 全州县| 平江县| 中牟县| 高安市| 运城市| 平遥县| 宝兴县| 长岛县| 宽甸| 渑池县| 阿拉善左旗| 通辽市| 贡觉县| 黎川县| 普格县| 建始县| 花莲市| 拜泉县| 宝丰县| 陆丰市| 墨竹工卡县| 阿鲁科尔沁旗| 凭祥市|