新聞中心

        EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 一種基于CPLD的單片機與PCI接口設計解決方案

        一種基于CPLD的單片機與PCI接口設計解決方案

        作者: 時間:2010-01-06 來源:網(wǎng)絡 收藏

          2.2 讀寫C語言程序

          在在幫助下,讀寫設備就變得相當簡單。首先,將pci_cbe等寄存器都聲明為外部存儲器變量,并根據(jù)指定地址。然后,傳遞適當?shù)膮?shù)給以下兩個讀寫子函數(shù),即可完成對設備配置空間、I/O空間、存儲器空間的讀寫操作。從PCI設備的返回數(shù)據(jù)存放在全局變量savedata中。

          實際上在寫PCI設備時,也可以從pci_data中得到返回數(shù)據(jù)。這個數(shù)據(jù)必須等于往PCI設備寫的數(shù)據(jù)。利用這一點可以進行差錯檢驗和故障判斷,視具體應用而定。

           bdate unigned char request;

           sbit IRDY0=request^4;

           sbit FRAME0=request^5;

           sbit VALID=request^7;

           void readpci(unsigned char addr,unsigned char cbe){

           pci_address0=addr;

           pci_cbe=cbe;

           request=pci_request;

           while(!IRDY0 FRAME0)) request=pci_request;

           savedata0=pci_data0;

           savedata1=pci_data1;

           savedata2=pci_data2;

           savedata3=pci_data3;

           if(!VALID)printf(Data read is invalid! );

           }

           void writepci(uchar addr,uchar value0,uchar cbe){

           data uchar temp;

           pci_address0=addr;

           pci_datas0=value0;

           pci_cbe=cbe;

           request=pci_request;

           while(!(IRDY0 FRAME0)) request=pci_request;

           if(!VALID)printf(Data write is invalid!);

           }

          3 結論

          用實現(xiàn)與PCI總線的并行通信,電路結構簡單、體積小,1片CPLD芯片足夠,并且控制方便,實時性強,通信效率高。本方法已成功地應用于作者開發(fā)的各種數(shù)據(jù)采集系統(tǒng)中,用作單片機與PC104之間的并行數(shù)據(jù)通信,效果非常理想。


        上一頁 1 2 3 下一頁

        評論


        相關推薦

        技術專區(qū)

        關閉
        主站蜘蛛池模板: 阿拉尔市| 博湖县| 涞源县| 措勤县| 台北县| 土默特右旗| 海原县| 积石山| 临颍县| 青海省| 嫩江县| 兰溪市| 定南县| 北宁市| 赤城县| 高清| 五原县| 抚宁县| 雅安市| 南乐县| 建瓯市| 邮箱| 华容县| 土默特右旗| 邵阳市| 太原市| 株洲县| 迁西县| 柘荣县| 峨眉山市| 漳浦县| 通江县| 永德县| 三都| 历史| 高淳县| 华安县| 清丰县| 新密市| 湟源县| 屏东市|