新聞中心

        EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > DSP/ARM雙核系統(tǒng)的通信接口設(shè)計

        DSP/ARM雙核系統(tǒng)的通信接口設(shè)計

        作者: 時間:2009-12-21 來源:網(wǎng)絡(luò) 收藏

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

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

          HPI可用I/O端口方式,也可以用I/O存取方式。平臺采用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)核中其他代碼一樣運(yùn)行在內(nèi)核模式,驅(qū)動程序如果出錯就會使受到嚴(yán)重破壞,因此需要將物理地址映射到內(nèi)核空間。在Linux下通過virtul_address=(u32)ioremap (HPI_BASE,HPI_LENGTH)實(shí)現(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),由于增強(qiáng)型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)的總體框圖,詳細(xì)介紹了ARM和DSP接口的。這一方法可以適用于大多數(shù)現(xiàn)代嵌入式系統(tǒng)的設(shè)計,有一定的實(shí)用價值。


        上一頁 1 2 3 下一頁

        評論


        相關(guān)推薦

        技術(shù)專區(qū)

        關(guān)閉
        主站蜘蛛池模板: 饶河县| 阳原县| 齐河县| 栖霞市| 鸡西市| 习水县| 阿拉善盟| 成武县| 巨野县| 漳浦县| 铜山县| 北宁市| 镇康县| 永州市| 新绛县| 剑阁县| 奉贤区| 弥勒县| 黑龙江省| 阿尔山市| 雷波县| 深泽县| 台前县| 惠水县| 敦煌市| 东宁县| 盱眙县| 正阳县| 汶上县| 革吉县| 类乌齐县| 磴口县| 旅游| 南昌县| 海城市| 保定市| 阿坝县| 镇远县| 湖州市| 华亭县| 定南县|