《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于FPGA的CPCI系統設計與實現
基于FPGA的CPCI系統設計與實現
2018年電子技術應用第11期
魏建勇
武漢虹旭信息技術有限責任公司,湖北 武漢430074
摘要: 集成工控機箱使用CPCI接口兼容各種可插拔板卡,板卡的CPCI設計多使用專用芯片搭配FPGA實現,降低了可擴展性,增加了板卡面積和成本。為了解決上述問題,設計了一種基于FPGA的CPCI接口。介紹了使用FPGA實現的CPCI協議、仿真及外部通信總線協議、外部中斷機制、沖突避免機制,該設計在量產的各種CPCI板卡中使用,用于各種廠家的CPCI機箱。與傳統實現方案相比,該方案具有成本低、體積小、靈活性好、兼容性高等優點,在小型工控領域內具有明顯的優勢。
關鍵詞: CPCI FPGA ARM
中圖分類號: TN836
文獻標識碼: A
DOI:10.16157/j.issn.0258-7998.181546
中文引用格式: 魏建勇. 基于FPGA的CPCI系統設計與實現[J].電子技術應用,2018,44(11):50-52,56.
英文引用格式: Wei Jianyong. Design and implementation of CPCI system based on FPGA[J]. Application of Electronic Technique,2018,44(11):50-52,56.
Design and implementation of CPCI system based on FPGA
Wei Jianyong
Wuhan Hongxu Information technologies Co.,Ltd,Wuhan 430074,China
Abstract: The integrated industrial control chassis is compatible with all kinds of pluggable boards using CPCI interface. The CPCI design of board card uses special chips to match the FPGA, which reduces the extensibility, and increases the area and cost of the card. In order to solve these problems, a CPCI interface based on FPGA is designed. This paper describes the CPCI protocol implemented with FPGA, simulation and external communication bus protocol, external interrupt mechanism, and conflict avoidance mechanism. This design is used in various CPCI cards produced by the mass production, and it is used in the CPCI chassis of various manufacturers. Compared with the traditional implementation scheme, the scheme has the advantages of low cost, small size, good flexibility and high compatibility. It has obvious advantages in the field of small industrial control.
Key words : CPCI;FPGA;ARM

0 引言

    目前的儀器或者工控系統多數使用集成式工控機箱,機箱背板一般通過CPCI(Compact PCI)接口連接所有的插卡,包括工控電腦和各種采集卡、控制卡等。設計板卡時需要考慮CPCI接口實現及通信機制,現有板卡多使用專用接口芯片,例如PCI9054芯片,這類芯片可擴展性不強,需要外擴FPGA芯片,使用不靈活;且直接使用FPGA的IP核實現CPCI協議占用資源多,開發成本較高,在有某些特殊需求時不便擴展。

    本文提出了一種基于FPGA的CPCI系統的設計和實現,使用廉價FPGA芯片實現CPCI通信協議,同時利用FPGA的可編程特性實現電源控制、靈活中斷、外部觸發、外部通信等特殊應用的功能,解決了CPCI協議經過CPCI橋時的沖突問題。

1 系統設計

1.1 系統框圖

    如圖1所示,本系統主要包含嵌入式板卡和CPCI工控機箱,板卡插入到CPCI機箱背板插槽。嵌入式板卡內的FPGA與CPCI插槽間使用CPCI總線和用戶IO連接,FPGA與ARM之間通過特定IO實現的總線連接,同時FPGA上連接一個三極管驅動的繼電器[1]

ck1-t1.gif

1.2 系統功能

    FPGA和背板接口為CPCI接口,通過CPCI協議通信;ARM使用自定義總線協議將數據寫入到FPGA的RAM緩存,然后使用CPCI接口發送給主控機,反之亦然。FPGA能識別CPCI的信號給ARM產生中斷,也能夠識別ARM的信號給CPCI產生有效中斷,還可以通過繼電器控制板卡上電、下電、復位,能通過IO控制實現ARM的ISP(在線升級,僅需控制一個ARM管腳)功能并產生背板觸發信號。

    下文從FPGA設計、ARM設計和通信機制三方面進行說明。

2 FPGA設計

    如圖2所示,FPGA內部主要包括CPCI協議、IO_MEM、ARM解碼、讀中斷產生、CPCI中斷產生、電源控制等模塊[2-3]。FPGA芯片根據使用資源和成本選擇Xilinx公司的XC2S100,最后使用387個Slice寄存器(占比16%)、882個LUTs(占比36%)。

ck1-t2.gif

2.1 CPCI協議模塊

2.1.1 協議

    CPCI協議兼容PCI2.2協議,擴展了部分用戶接口,所以模塊按照標準PCI2.2協議完成,實現配置空間管理、IO讀寫、Memory單字讀寫、Memory突發讀寫、仲裁和中斷等功能。協議細節參看文獻[4]、[5]。

2.1.2 FPGA仿真

    對ISE布線后的文件用ModelSimXE進行時序后仿真,下面給出通過CPCI總線進行Memory突發讀寫的仿真,因IO讀寫和Memory單字讀寫時序與Memory突發讀寫類似,在此不再贅述[6-8]

    圖3上半部分是Memory突發寫的時序過程,在地址0xd000處連續寫入10個依次遞增的32 bit數據,起始數據為0x15896345。下半部分是寫完之后的Memory突發讀時序,可見從0xd000讀出的連續若干32 bit數據,與寫入完全一致。

ck1-t3.gif

    此CPCI板卡在插入實際機箱槽位時出現這樣的問題:某些廠家的機箱特定槽位插入會死機。該問題使用市面上的成品CPCI板卡也會遇到,經過分析,修改了CPCI板卡協議里的一個關于CPCI橋的接口,死機情況不再發生。

2.2 IO_MEM模塊

    本模塊由3個雙口RAM組成,在CPCI系統中命名為BA0、BAR1、BAR2,BAR0和BAR2是16 B的IO空間,僅支持單個字讀取,BAR1為2 048 B的MEM空間,支持單字讀寫和突發讀寫。其中BAR1僅支持1 B的空間訪問,只用來進行電源控制和ISP,不可通過其他外設訪問。

2.3 ARM解碼模塊

    本模塊實現FPGA與ARM之間IO和Memory接口時序,因兩者時序基本相同,以Memory時序為例說明,定義如圖4和圖5所示。硬件接口由時鐘、使能、RAM選擇、讀寫選擇、地址數據總線(8根)組成。特別需要注意的是,時鐘線必須連接到FPGA的全局時鐘管腳上。

ck1-t4.gif

ck1-t5.gif

    Memory讀/寫時序必須保證在地址A有效之后的第2個時鐘周期開始接收/輸入數據,32 bit數據由4 B組成,按低位字節到高位字節的順序輸出/輸入,數據組合/拆分由ARM完成。接收/寫入不同地址段的數據必須先使en_arm無效,然后再使能。

2.4 ARM讀中斷

    當FPGA內部的BAR0寫有效時使能int_arm,該信號會觸發ARM的外部IO中斷。通過CPCI接口往BAR0寫入任何數據均可產生一個脈沖觸發信號,可以使用此信號去中斷ARM。

2.5 CPCI中斷

    ARM需要給CPCI產生中斷,機制如下:

    (1)ARM給IO0空間偏移地址2寫入0x01,在INTA#上出現低電平觸發信號;

    (2)主控機檢測到此電平觸發中斷,馬上禁止中斷,往IO1空間偏移地址0寫入0xfb,之后INTA#被拉高,此時ARM無法通過步驟(1)再次發送中斷,也就是說,INTA#無法被ARM拉低;

    (3)主控機處理完臨界代碼之后,往IO1空間偏移地址0寫入0xfa,允許ARM產生中斷,也即,ARM可以通過步驟(1)再次產生中斷。

2.6 外圍控制

    電源控制和觸發信號都是通過ARM或者主控機給CPCI的特定空間寫入預定信息,檢測信息之后做出相應的處理[6]

    (1)主控機向BAR2空間的0偏移寫入0xff、0xfe、0xfd、0xfc實現上電、掉電、復位、ISP功能;

    (2)主控機往BAR2空間的0偏移寫入一個小于128的數,此數值是給背板產生的觸發脈沖個數;

    (3)ARM往BAR0空間的1偏移寫入一個小于256的數,此數值是給背板產生的觸發脈沖個數,ARM能產生的觸發脈沖比主控機多一倍。

3 ARM設計

    在本系統中,ARM和FPGA的總線連接使用IO口模擬實現。按照前面描述的時序,ARM中接口相關功能有:

    (1)響應中斷信號,讀取、執行IO命令;

    (2)讀取IO數據;

    (3)讀寫Memory數據。

    因接口時序的ARM代碼實現較簡單,在此不再贅述,具體的實現機制可參看后續的通信機制設計。

4 通信機制設計

    從CPCI的角度看,ARM和主控機為主設備,FPGA為從設備。對于FPGA來說,CPCI接口和ARM接口完全獨立,但是兩者都可以對RAM進行讀寫,如果沒有一個協調機制,很可能發生讀寫沖突,必須有一個規則來協調數據的傳送[9-10]。因為CPCI為標準接口,所以需要定義的是FPGA和ARM的接口和主控機驅動讀寫規則,下面介紹FPGA和ARM的接口和主控機讀寫規則。

主控機與ARM需要交互的數據全部放在FPGA的RAM中進行緩沖。實現規則如下:

    (1)IO空間只分配1 B,存放主控機發送的命令;

    (2)Memory中讀寫空間分開,偏移0~999為主控機寫、ARM讀數據空間,1 000~2 048為主控機讀、ARM寫數據空間。

    圖6描述了ARM、CPCI和主控機的數據流向和讀寫流程。為避免系統讀寫沖突,需按照如下規則執行操作:

ck1-t6.gif

    (1)ARM讀寫CPCI的Memory空間之前,使write_acc或read_acc無效,讀寫完畢使之有效。

    (2)主控機讀Memory時首先讀read_acc,如果有效,開始讀所需內存,否則等待一段時間重試;寫Memory時首先讀write_acc,如果有效,開始往指定內存寫數據,否則等待一段時間重試;主控機對IO的寫不需要讀write_acc。

    (3)主控機寫Memory一般過程為:先根據所需命令確定需要將數據寫入哪些空間,然后將配置數據寫入Memory中,最后把控制命令寫入IO空間;讀Memory則直接讀取數據。

    本方案用于數據采集卡、數字基帶模擬卡、本振信號發生卡、中頻變頻接收卡等多種功能應用,兼容研華、凌華等幾大廠家的工控機箱。

5 結束語

    本文給出了一種基于FPGA的CPCI系統設計方案,介紹了實施基本框架、CPCI協議、自定義總線通信協議和通信沖突避免機制,按照設計方案實現了低成本、高密度、易擴展的CPCI通信系統,在工程上便于實現,能廣泛應用于工控和測量領域,對類似設計提供了參考。

參考文獻

[1] 任勇峰,彭巧君,劉占峰.基于FPGA的CPCI高速讀數接口設計[J].電子器件,2015(1):148-151.

[2] 田源,王立德,嚴翔,等.基于FPGA+CPCI的WTB通信板設計[J].機車電傳動,2014(4):28-32,56.

[3] 王銳,張友方,陳延云,等.基于FPGA的數據采集卡的CPCI接口設計[J].電子技術,2010,37(2):35-37.

[4] PICMG2.0R3.0,CompactPCI Specification[Z].1999.

[5] PCI Local Bus Specification(Revision 2.3)[Z].PCI Local Bus,2001.

[6] 劉青,馬天乙.CPCI數據總線接口的設計與實現[J].電子科技,2011,24(6):95-96,100.

[7] SHANLEY T,ANDERSON D.PCI系統結構[M].北京:電子工業出版社,2000.

[8] 李貴山,戚德虎.PCI局部總線開發者指南[M].西安:西安電子科技大學出版社,1997.

[9] 巫幪,蘇濤,史佳歡.通用信號處理板卡的CPCI總線接口設計和驅動開發[J].國外電子元器件,2007(2):26-30.

[10] 郭立俊,譚劍波.一種基于FPGA的CPCI總線接口設計方法[J].合肥工業大學學報(自然科學版),2014(5):596-599.



作者信息:

魏建勇

(武漢虹旭信息技術有限責任公司,湖北 武漢430074)

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲精品美女久久7777777| 午夜精品免费在线| 一本色道婷婷久久欧美| 一区二区三区在线免费观看| 国产精品日韩久久久久| 欧美日韩国产成人在线| 暖暖成人免费视频| 久久在线免费观看视频| 久久国产乱子精品免费女| 亚洲欧美在线免费观看| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲日本中文字幕免费在线不卡| 亚洲国产精品一区| 久久国产精品久久国产精品| 亚洲制服av| 亚洲一区二区三区视频播放| 在线一区观看| 一区二区三区四区五区在线| 一区二区三区视频免费在线观看| 亚洲美女电影在线| 亚洲毛片av在线| 99热免费精品| 夜夜嗨av一区二区三区中文字幕| 亚洲人成小说网站色在线| 亚洲区欧美区| 亚洲伦理一区| 亚洲最新色图| 亚洲一区999| 亚洲欧美视频一区二区三区| 亚洲欧美综合精品久久成人| 午夜精品福利视频| 篠田优中文在线播放第一区| 亚洲欧美在线一区| 久久国产精品电影| 91久久国产自产拍夜夜嗨| 亚洲黄色影院| 亚洲乱码一区二区| 亚洲午夜国产成人av电影男同| 亚洲一区二区三区四区视频| 亚洲欧美成人在线| 久久精品1区| 久久在线免费观看| 欧美精品免费观看二区| 欧美视频一区二区| 国产精品日产欧美久久久久| 国产视频久久久久| 激情久久五月| 亚洲精品国产系列| 亚洲图片欧美午夜| 欧美一区二区三区电影在线观看 | 伊人婷婷久久| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲男人第一av网站| 欧美一级日韩一级| 另类av一区二区| 欧美日韩一区在线播放| 国产欧美日韩亚洲精品| 一区免费观看| 99国产精品99久久久久久粉嫩| 午夜电影亚洲| 亚洲精品久久嫩草网站秘色| 亚洲男女自偷自拍图片另类| 巨胸喷奶水www久久久免费动漫| 欧美日韩三级在线| 国产视频亚洲| 日韩视频精品在线| 欧美一区免费视频| 一区二区三区av| 久久久久久夜| 欧美伦理一区二区| 国产婷婷97碰碰久久人人蜜臀| 亚洲高清在线观看一区| 亚洲免费人成在线视频观看| 91久久久在线| 午夜影院日韩| 欧美高清一区二区| 国产精品视频yy9099| 亚洲国产欧美另类丝袜| 午夜精品福利视频| av成人老司机| 可以看av的网站久久看| 国产精品日韩在线| 亚洲黄一区二区| 欧美一区二区三区免费观看| 亚洲小说区图片区| 免费成人你懂的| 国产热re99久久6国产精品| 亚洲乱码日产精品bd| 亚洲国产精品国自产拍av秋霞 | 久久夜色精品国产欧美乱极品| 欧美日韩中文字幕精品| 一区二区三区在线观看欧美| 中文日韩在线视频| 日韩一区二区精品葵司在线| 久久久91精品国产一区二区精品| 欧美性猛交99久久久久99按摩| 亚洲国产精品一区二区久| 亚洲欧美国产三级| 亚洲深夜影院| 欧美α欧美αv大片| 国模套图日韩精品一区二区| 亚洲尤物在线视频观看| 亚洲婷婷综合色高清在线 | 国产精品美女999| 亚洲麻豆视频| 亚洲欧洲日夜超级视频| 久久久久久九九九九| 国产精品欧美久久| 日韩一区二区精品| 亚洲精品中文字| 欧美成人午夜激情视频| 国产在线拍偷自揄拍精品| 午夜欧美不卡精品aaaaa| 亚洲免费小视频| 欧美日韩一区二区视频在线| 亚洲精品一区中文| 亚洲精品久久久久久久久久久久| 老司机精品导航| 激情综合网址| 久久精品国产99| 久久这里有精品15一区二区三区| 国产一区二区电影在线观看| 欧美一级久久久久久久大片| 欧美亚洲免费在线| 国产精品欧美日韩久久| 亚洲一品av免费观看| 亚洲欧美日韩视频一区| 欧美午夜精品伦理| 亚洲深夜激情| 亚洲欧美成人网| 国产精品欧美日韩一区| 亚洲欧美日韩一区二区在线 | 亚洲免费在线视频| 国产精品美女xx| 亚洲天堂成人在线观看| 亚洲欧美日韩区| 国产日韩欧美视频在线| 欧美一区二区三区免费观看| 久久久久久久久久久久久女国产乱 | 麻豆精品视频在线观看视频| 在线国产精品一区| 亚洲欧洲综合另类| 欧美精品videossex性护士| 亚洲美女网站| 亚洲先锋成人| 国产麻豆精品theporn| 久久成人精品视频| 麻豆精品精华液| 亚洲人成人77777线观看| 亚洲五月六月| 国产麻豆午夜三级精品| 久久精品国产99国产精品| 嫩草国产精品入口| 亚洲巨乳在线| 亚洲在线成人| 国产午夜精品一区二区三区欧美 | 久久麻豆一区二区| 亚洲第一福利在线观看| 一区二区三区日韩欧美| 国产精品国内视频| 欧美一区视频在线| 麻豆久久久9性大片| 亚洲精品日韩在线观看| 亚洲欧美日韩另类| 黄色小说综合网站| 一本一道久久综合狠狠老精东影业| 欧美日韩在线三区| 欧美一区二区三区视频| 欧美大片va欧美在线播放| 一区二区国产精品| 久久精品国产99精品国产亚洲性色 | 亚洲精品久久久久久一区二区 | 欧美一区二区三区在| 在线国产精品播放| 亚洲一区二区在线播放| 国产综合视频在线观看| 99精品欧美一区二区三区综合在线 | 国产精品外国| 亚洲国产美女精品久久久久∴| 欧美日韩一区二区三区四区五区| 性欧美大战久久久久久久久| 欧美黑人在线观看| 亚洲欧美日韩国产一区二区三区| 看欧美日韩国产| 亚洲视频播放| 免费观看日韩av| 亚洲永久在线| 欧美精品成人一区二区在线观看 | 日韩系列在线| 久久久视频精品| 一区二区免费看| 久热国产精品视频| 亚洲欧美国产日韩中文字幕| 欧美日韩国产精品一卡| 久久精品二区| 国产精品麻豆成人av电影艾秋| 亚洲精品少妇网址| 国产一区亚洲一区| 午夜精品一区二区三区在线| 亚洲日韩欧美视频一区|