《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于SOPC技術的EPA現場控制器的設計
基于SOPC技術的EPA現場控制器的設計
摘要: 本文介紹了一種基于SOPC技術的EPA現場控制器的設計。該控制器應用于EPA工業現場中,實現了EPA通信協議棧,可對EPA系統中其他設備的狀態進行檢測、控制、實時顯示和報警。
Abstract:
Key words :

 引言
      隨著以太網技術的飛速發展,工業以太網漸漸成為自動化控制系統里主流的高速率的通信方式,工業以太網技術已經成為一個獨立發展的分支。EPA是我國第一個擁有自主知識產權、并被國際標準化組織接收和采用的工業自動化標準。該標準是一種基于以太網、無線局域網、藍牙等信息網絡通信技術的,適用于工業自動化控制系統裝置與儀器儀表間、工業自動化儀器儀表相互間數據通信的工業控制網絡通信標準。
    大量的EPA現場設備都是通過加裝EPA通信卡來進行通信,該通信卡的處理器多數采用ARM核。近年來,隨著半導體技術的飛速發展,傳統的芯片設計方法正在進行一場革命,其標志就是系統芯片(SoC)被業界廣泛接受,并成為研究和開發的熱點。隨著SoC技術應運而生的是SOPC 技術。它結合了SoC和FPGA的優點,可裁減、可擴充、可升級,并具備軟硬件在系統中可編程的功能。SOPC能夠提供更好的性能以及更低的功耗,有效節省電路板空間并降低產品的總成本,電子工業正逐漸向SOPC設計轉移,使SOPC成為現代電子系統的最佳選擇之一。在充分研究EPA網絡通信和SOPC技術的基礎上,開發了一種基于SOPC技術的EPA控制器。

 


圖1基于FPGA的EPA控制器的硬件結構框圖

SOPC技術

SOPC技術是美國Altera公司于2000年最早提出的,并同時推出了相應的開發軟件Quartus II。SOPC是基于FPGA解決方案的SoC,與ASIC的SoC解決方案相比,SOPC系統及其開發技術具有更多的特色,并具備以下的基本特征:至少包含一個以上的嵌入式處理器IP核;具有小容量片內高速RAM資源;豐富的IP核資源可供靈活選擇;有足夠的片上可編程邏輯資源;處理器調試接口和FPGA編程接口共用或并存;可包含部分可編程模擬電路;單芯片、低功耗。

SOPC是一種新的系統設計技術,也是一種新的軟硬件綜合設計技術。通過它,可以很快地將硬件系統(包括微處理器,存儲器,外設以及用戶邏輯電路等)和軟件設計都放在一個可編程的FPGA芯片中,以達到系統的IC設計。這種設計方式,具有開發周期短以及系統可修改等優點。設計完成的SOPC可以通過HARDCOPY轉為ASIC芯片,從而可以實現快速量產。

EPA現場控制器設計

針對控制系統中連接管理網、控制網和現場設備單元的要求,采用SOPC技術、現場總線技術和自動控制技術,設計一種適用于EPA工業以太網的控制器,并在其可編輯軟核的CPU處理器上實現了實時操作系統及EPA通信協議棧。該EPA現場控制器可實現實時控制信息的輸入輸出,并對以太網上的其他的EPA設備進行監控、顯示和故障報警。本文將針對該EPA控制器的基于SOPC技術的CPU核心處理模塊和通信處理模塊分別進行說明。

EPA現場控制器的硬件設計總體方案

圖1是EPA現場控制器的硬件系統結構框圖。整個設計中,硬件上實現EP1C12Q240C8芯片、LAN91C111芯片的外圍接口電路的設計;實現了串口通信和網絡通信的設計;實現了復位電路、JTAG、時鐘電路、電源電路的設計;實現了鍵盤電路、LCD顯示電路、蜂鳴器報警電路的設計;實現了HY57V641620芯片、AM29LV160芯片外圍電路的設計,拓展了豐富的存儲器資源,可移植linux、windows CE操作系統等;拓展了總線接口,可以根據工業現場的實際需要接入相應的板卡(如DI/DO模塊、AI/AO模塊,實現與現場數據之間的數模、模數轉換、拓展MMC存儲卡,拓展其存儲容量等)。

在設計時,考慮到由于該控制器的結構、功能較為復雜,涉及到的器件種類較多。所以在設計時,將硬件板卡分為兩部分來做。第一部分:CPU核心處理模塊,包含CPU處理器EP1C12Q240C8、存儲器(FLASH、SDRAM)、電源部分、時鐘源、JTAG、EPCS下載口和復位電路。第二部分:通信處理模塊,包含網絡通信(LAN91C111網卡芯片和RJ45)、串口通信(MAX3232)、LCD接口、鍵盤接口和蜂鳴器。

 


圖2 芯片系統結構框圖

基于SOPC技術的CPU核心處理模塊

整個方案的實現是以接入實時工業以太網絡為目的,在芯片內部實現部分EPA協議,同時控制器實現對工業以太網上的其他設備的監控、顯示及數據分析。設計中采用Altera公司的新一代低成本的FPGA芯片EP1C12Q240C8芯片,該芯片包含有12060LE(邏輯單元),可根據實際需要,配置其NIOSⅡCPU軟核、與CPU相連的片內外設和存儲器以及與片外存儲器和片外設備相連的接口等。其芯片系統結構框圖如圖2所示。

整個CPU處理器的硬軟件設計均在Quartus II 5.1版本上實現。NIOSⅡ處理器核是Altera公司的第二代用戶可配置的通用32位RISC軟核微處理器,是Altera公司特有的基于FPGA架構的可配置的軟CPU內核,其特性和外設可根據實際需要進行增加或剪裁。所有NIOSⅡ處理器系統使用統一的指令和編程模型,并有三種類型以滿足不同設計的要求,分別是快速型、經濟型和標準型。在本控制器中,所定制的NIOSⅡ軟核選用快速型,該內核處理速度為49DMIPS,耗費的邏輯門數為1400~1800LE,同時帶有硬件乘法器和硬件除法器。根據EPA網絡對控制器的要求,添加與CPU相連的片內外設和片外設備接口:SDRAM控制器、片內RAM、三態橋、UART、定時器、通用I/O口、LCD顯示驅動電路和以太網接口。按照設計要求,在Quartus II 5.1版本下的對CPU的配置情況如圖3所示。FPGA芯片可根據實際需要靈活地增加功能,同樣對不必要的功能也可進行刪減,以滿足快速、高效和低成本的設計。

在配置完CPU處理器的內部結構以后,按照設計需要對CPU的外圍進行配置。由于該控制器是接入EPA網絡,需要實現EPA協議,而FPGA芯片EP1C12Q240C8的內部只有288K的RAM,所以在片外擴展了16M bits的FLASH-AM29LV160D和64M bits的SDRAM-HY57V641620的。從外部引入12V的直流電源,經過電平轉換以后得到3.3V和1.5V的電源,為CPU、存儲器及其他受電設備供電。CPU上的時鐘源使用的是50MHz的鐘振。JTAG和EPCS下載口用于硬軟件的下載。將在Quartus Ⅱ上編輯的硬件程序和軟件程序通過JTAG和EPCS下載口,下載到FLASH和RAM(片內或者片外)中,可進行在線調試。該復位電路是由10KW電阻、10mF電容和按鍵組成,可實現按鍵低電平復位和上電低電平復位。

 


圖3 EP1C12Q240C8芯片配置情況

通信處理模塊

整個設計以FPGA芯片EP1C12Q240C8為數據處理中心,通過網絡通信,完成對工業以太網上的其他設備的數據通信,同時通過MAX3232實現和上位機的串口通信。在該模塊中,加入了LCD接口、行列式鍵盤接口和蜂鳴器接口,對工業以太網上的其他EPA設備進行監控和顯示,有較好的人機交互的功能。

在該設計中,網絡通信分為有線和無線兩種通信方式。其中,有線網絡通信使用的是10M/100M的LAN91C111的自適應網卡芯片,并通過RJ45網口接入EPA網絡。LAN91C111是SMSC公司為嵌入式應用系統推出的第三代快速以太網控制器。LAN91C111的芯片上集成了遵循SMSC/CD協議的MAC(媒體層)和PHY(物理層),符合IEEE802.3/802.U-100Base-Tx/10Base-T規范。在本控制器上預留了藍牙模塊和ZigBee模塊的無線通信接口,作為輔助處理模塊。可根據工業現場的實際情況,接入無線通信模塊,實現與EPA網絡的無線通信,通過該模塊能夠監測無線現場設備的運行情況及相關參數。

在整個EPA通信協議棧網絡層和傳輸層接收報文處理流程中。NIOSⅡ處理器復位后初始化UC/OS Ⅱ操作系統、網絡接口、堆棧以及定時器等外圍設備接口。從外部存儲器FLASH中獲取IP地址和MAC地址等網絡信息。當收到的報文IP地址和MAC地址都是本機地址時,把報文以LWIP所要求的特殊結構體形式存儲在接收緩沖區中,然后發送到EPA協議棧中進行處理,當檢查到UDP端口號是0x88BC時,將報文交由EPA應用層處理模塊進行處理。
其部分報文處理程序如下:

/*報文發送*/
void SendTask(void *pdata){
struct netconn *conn;
struct ip_addr remote_addr,local_addr;
struct netbuf * buf;
struct udp_pcb * udpbuf;
struct pbuf * buf;
char text[] = "A static test";
/*設置遠程主機的IP地址*/
remote_addr.addr = htonl(0x8080023D);
/*設置本地主機的IP地址*/
local_addr.addr = htonl(0x80800233);
for(;;){
/*建立一個新連接*/
conn = netconn_new(NETCONN_UDP);
/*綁定本地IP地址和端口號*/
netconn_bind(conn,&local_addr,0x88BC);
/*連接遠程主機*/
netconn_connect(conn,&remote_addr,0x88BC);
buf = netbuf_new();
/*建立任意的數據*/
netbuf_ref(buf,text,sizeof(text));
netconn_send(conn,buf);
netconn_delete(conn);
netbuf_delete(buf);
OSTimeDlyHMSM(0,0,1,0);
buf = pbuf_alloc(PBUF_RAW, 60,
PBUF_RAM);
memcpy(buf->payload,text,
sizeof(text));
udpbuf = udp_new();
udpbuf->local_port = 0x88bc;
udpbuf->remote_port = 0x88bc;
udpbuf->local_ip = local_addr;
udpbuf->remote_ip = remote_addr;
udp_bind(udpbuf, &udpbuf->local_ip,
udpbuf->local_port);
udp_sendto(udpbuf,buf,&remote_addr,udpbuf->remote_port);
udp_remove(udpbuf); //釋放
udp_pcb內存
pbuf_free(buf);
OSTimeDlyHMSM(0,0,1,0);
/* Main initializes lwIP, creates a single task and starts task scheduler. */
void ReceiveTask(void * pdata){//該任務
和IP協議棧相關,該任務由
_sys_thread_new函數來創建
struct netbuf * buf1,*buf2,*buf1_temp;
struct netconn * conn1,*conn2;
void * payload;
u16_t len;
struct ip_addr remote_addr,local_addr;
char text[] = "I get a EPA packet,please
give me another,I need you, baby.";
remote_addr.addr = htonl
(0x8080023D);
local_addr.addr = htonl(0x80800233);
conn1 = netconn_new(NETCONN_
UDP);
conn2 = netconn_new(NETCONN_
UDP);
netconn_bind(conn2, &local_addr, 0x88bc);
netconn_connect(conn2,&remote_addr,
0x88BC);
netconn_bind(conn1, &local_addr, 0x88bc);
while((buf1_temp = netconn_recv
(conn1))!=NULL){
//關于netbuf的結構可以參看api.h文件,在該結構體中,成員p是指向pbuf的一個指針
buf1 = netbuf_new();
buf1 = buf1_temp;
payload = buf1->p->payload;
len = buf1->p->len;
netbuf_delete(buf1);
buf2 = netbuf_new();
netbuf_ref(buf2,text,sizeof(text));
netconn_send(conn2,buf2);
netbuf_delete(buf2);

 


圖4 EPA協議棧接收報文處理流程圖

結語

在完成整個設計,控制器接入EPA網絡中能夠正常運行。由于控制器中的處理器使用的是FPGA芯片,有較強的靈活性,能夠進行編程、除錯、再編程和重復操作,因而可以充分地進行設計開發和驗證。當電路有少量改動時候,更凸現出其優勢,其現場編程能力可以延長產品在市場上的壽命,可以用來系統升級,從而大大提高了控制器的性能。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲视频免费观看| 亚洲精品久久久久| 亚洲破处大片| 樱桃国产成人精品视频| 国产精品久久国产三级国电话系列 | 国产精品黄色在线观看| 欧美顶级少妇做爰| 免费不卡在线观看| 久久精品二区| 久久精品视频在线看| 久久精品卡一| 久久九九久久九九| 久久露脸国产精品| 蜜桃视频一区| 欧美99在线视频观看| 欧美不卡一区| 欧美刺激性大交免费视频| 欧美成年人在线观看| 欧美不卡在线视频| 欧美激情视频免费观看| 欧美日韩亚洲天堂| 国产精品每日更新在线播放网址| 国产精品啊v在线| 国产美女在线精品免费观看| 国产日韩精品电影| 国内激情久久| 亚洲第一区色| 一区二区三区www| 亚洲摸下面视频| 久久精品国产91精品亚洲| 亚洲国产精品第一区二区三区 | 免费亚洲网站| 欧美连裤袜在线视频| 欧美日韩综合在线| 国产精品免费网站| 国产网站欧美日韩免费精品在线观看| 韩国福利一区| 最新国产乱人伦偷精品免费网站 | 欧美日韩午夜视频在线观看| 国产精品国产精品| 国产一区二区三区在线观看精品| 极品少妇一区二区| 日韩视频在线免费| 欧美一区二区三区日韩| 久久高清福利视频| 一本久久精品一区二区| 欧美一二三区精品| 免费亚洲一区| 国产精品免费福利| 在线国产精品一区| 一区二区不卡在线视频 午夜欧美不卡在 | 久久综合久久美利坚合众国| 欧美顶级少妇做爰| 国产精品日韩久久久| 狠狠久久亚洲欧美专区| 亚洲国产精品一区二区三区| 一区二区三区国产在线观看| 欧美中文字幕在线视频| 99在线|亚洲一区二区| 久久动漫亚洲| 欧美激情综合色综合啪啪| 国产欧美1区2区3区| 亚洲国产精品成人综合色在线婷婷| 一本色道久久综合亚洲精品按摩| 久久精品免费| 午夜精品视频在线观看| 欧美极品影院| 国内揄拍国内精品少妇国语| 一区二区动漫| 亚洲日本一区二区| 久久成人国产| 欧美日韩亚洲一区| 在线播放不卡| 亚洲欧美国产高清| 一本色道久久精品| 麻豆精品一区二区综合av| 国产精品久久网站| 亚洲三级电影全部在线观看高清| 香蕉久久一区二区不卡无毒影院 | 久久精品日韩欧美| 欧美日韩在线精品| 亚洲高清一区二| 欧美资源在线| 欧美一区二区性| 欧美视频在线一区| 最近看过的日韩成人| 久久都是精品| 翔田千里一区二区| 欧美日韩高清在线观看| 精品成人一区二区三区| 小处雏高清一区二区三区| 亚洲一级片在线观看| 欧美理论电影网| 亚洲国产成人午夜在线一区| 性做久久久久久免费观看欧美| 亚洲一区二区三区精品在线| 欧美精品日韩| 亚洲高清一二三区| 亚洲国产欧美一区二区三区丁香婷| 欧美专区中文字幕| 国产精品国产三级国产普通话蜜臀| 亚洲人成人99网站| 亚洲精品乱码久久久久久| 久久色在线播放| 国产一二三精品| 亚洲欧美在线x视频| 亚洲欧美一区在线| 国产精品黄视频| 亚洲深夜福利| 亚洲已满18点击进入久久| 欧美午夜精品久久久久久久| 亚洲精品一区二区三区不| 亚洲欧洲精品一区二区三区波多野1战4 | 午夜视频在线观看一区| 欧美理论在线| 亚洲精品日韩欧美| 夜夜爽av福利精品导航| 欧美精品电影在线| 亚洲精品美女久久7777777| 亚洲三级影院| 欧美国产日产韩国视频| 91久久极品少妇xxxxⅹ软件| 亚洲三级免费电影| 欧美精品久久久久久久免费观看 | 久久精品99| 久热这里只精品99re8久| 精品电影一区| 亚洲人成7777| 欧美激情2020午夜免费观看| 亚洲精品免费一区二区三区| 日韩视频久久| 欧美日本韩国一区二区三区| 99精品热视频| 性欧美18~19sex高清播放| 国产精品视频专区| 午夜精品福利一区二区三区av | 亚洲天堂第二页| 久久国产综合精品| 国内外成人在线| 亚洲精品中文字幕女同| 欧美日韩午夜在线| 亚洲一区亚洲| 久久人人97超碰精品888| 在线色欧美三级视频| 99亚洲视频| 国产精品中文在线| 欧美在线亚洲一区| 欧美成人免费全部| 日韩视频免费看| 羞羞漫画18久久大片| 国产一区二区三区无遮挡| 亚洲国产精品久久91精品| 欧美日本韩国一区二区三区| 亚洲午夜在线视频| 久久久水蜜桃av免费网站| 亚洲电影视频在线| 亚洲小说春色综合另类电影| 国产精品一区二区女厕厕| 亚洲国产精品毛片| 欧美日韩精品| 亚洲欧美日韩在线高清直播| 免播放器亚洲一区| 国产精品99久久久久久www| 久久精品国产综合精品| 在线欧美小视频| 亚洲男人第一av网站| 激情综合亚洲| 亚洲一区在线看| 伊人久久男人天堂| 亚洲欧美日韩国产一区| 影音先锋另类| 午夜视频在线观看一区二区三区 | 日韩视频免费看| 国产日韩视频一区二区三区| 亚洲肉体裸体xxxx137| 国产精品美女久久久久av超清 | 欧美国产先锋| 午夜精品久久久久久久99热浪潮 | 日韩网站在线看片你懂的| 国产农村妇女毛片精品久久莱园子| 亚洲黄网站在线观看| 国产精品久久久999| 亚洲全部视频| 国产亚洲综合性久久久影院| 宅男精品视频| 狠狠色丁香婷婷综合影院| 亚洲性图久久| 亚洲电影av| 久久精品国产综合精品| 亚洲作爱视频| 免费视频最近日韩| 性做久久久久久久免费看| 欧美特黄一级| 亚洲人成人一区二区三区| 国产日本欧洲亚洲| 亚洲视频在线观看网站| 在线观看一区视频| 久久精品国产综合精品| 一区二区三区日韩精品视频| 欧美+日本+国产+在线a∨观看|