整個方案的實現是以接入實時工業以太網絡為目的,在芯片內部實現部分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芯片,有較強的靈活性,能夠進行編程、除錯、再編程和重復操作,因而可以充分地進行設計開發和驗證。當電路有少量改動時候,更凸現出其優勢,其現場編程能力可以延長產品在市場上的壽命,可以用來系統升級,從而大大提高了控制器的性能。
評論
查看更多