基于CPLD的PLC背板總線協議接口芯片設計
信號包括數據/地址信號、復位信號Reset、中斷信號INT.主機和從機協議芯片的內部結構框圖相同,如圖3 所示。
協議芯片內部有狀態機控制器、幀控制器、移位寄存器、接收/發送FIFO 和讀寫緩存。單片機發送的周期性、非周期性數據幀,首先都寫到寫緩存,在發送FIFO 中進行排隊發送,在SPI 時鐘SCLK 的驅動下數據幀被轉換為串行數據發送到背板總線;在SPI 時鐘的作用下, 接收來自背板總線上的串行數據;在狀態機和幀控制器的協調下,接收FIFO 中的有效數據幀被提取并放進讀緩存區,等待單片機來讀取,如果是非周期性數據則發中斷信號通知單片機來取數據。讀緩存中的周期性數據是可以覆蓋的,新接收到的周期性數據直接覆蓋舊的周期性數據,而非周期性數據是單獨存放的,不能覆蓋,由單片機讀取并清除。
圖3 協議芯片內部結構框圖
協議芯片使得外接的單片機可以在空閑的情況下訪問讀緩存和寫緩存,單片機不必頻繁地通過中斷技術處理周期性數據,也使得PLC 主機可以無等待地訪問從機的周期性數據。
3 基于CPLD 的協議芯片實現
3.1 CPLD 芯片選型。
本設計選用lattice 公司的MachXO 系列芯片,該系列CPLD 集成了部分FPGA 的功能, 除了內置豐富的LUT 資源以外,還有大量分布式的SRAM 位和嵌入式的專用于FIFO 設計的SRAM 塊, 并有模擬鎖相環(PLL)支持時鐘信號的倍頻、分頻等,I/O引腳可配置成1.2/1.5/1.8/3.3V 電平兼容。
3.2 基于Verilog HDL 語言的硬件程序設計
本設計采用Verilog HDL 語言進行協議芯片的程序設計,Verilog HDL 語言是一種硬件描述語言,設計數字芯片時可以按照層次描述,并可以進行時序建模。本設計采用混合設計模式,主要設計的模塊有狀態機、協議幀檢測、FIFO 控制器設計等。
1)狀態機設計。
協議芯片的頂層模塊是狀態控制器部分,協議芯片共有四個狀態, 分別處理基于Verilog HDL 程序語言的狀態機描述偽代碼如下:
2)協議幀檢測。
本協議芯片的幀校驗和采用簡單的加和形式進行,在接收一方,如果數據幀中有用數據的加和同后續的校驗和字節相同,則協議是正確的,否則丟棄該幀。協議幀校驗和計算的代碼如下:
3)FIFO 設計。
FIFO 利用了MachXO 系列CPLD 的嵌入式SRAM 塊的資源,Lattice 公司的ispLEVER 7.0 軟件提供了可配置的IP 軟核,該軟核可以采用基于嵌入式SRAM 塊實現, 也可以使用查找表實現,FIFO 的IP 核框圖如圖4 所示,FIFO 的可配置參數包括FIFO字節深度、EmptyFull、AlmostEmpty 和AlmostFull觸發字節深度、數據寬度、大小端模式等。
評論