FPGA上電後IO的預設狀態
概述
在進行FPGA硬體設計時,引腳分配是非常重要的一個環節,特別是在硬體電路上需要與其他晶片通行的引腳。Xilinx FPGA從上電之後到正常工作整個過程中各個階段引腳的狀態,會對硬體設計、引腳分配產生非常重要的影響。這篇專題就針對FPGA從上電開始 ,配置程式,到正常工作整個過程中所有IO的狀態進行分析。
從時間階段可以分為兩部分,第一階段是從FPGA上電開始直到配置(Configuration)完成之前。第二個階段是配置完成之後,FPGA開始正常工作開始。
從引腳型別上分,可以分為三大類:第一類是普通的IO,其中又分為程式設計中使用到的IO和程式設計中沒有使用的IO(即在ucf或者XDC檔案中沒有進行約束的IO);第二類是專用下載配置引腳(Dedicated Pins),這類引腳只用於專用的功能,包括有M[2:0]、TCK、TMS、PROGRAM_B、INIT_B等。第三類為功能複用引腳,這類引腳在使用特定的功能時使用,例如在使用BPI配置模式時,D[00-31]和A[00-28]需要使用。如果使用SYSMON時,I2C_SDA和I2C_SCL需要使用。但在當前沒有使用該功能的情況下,功能複用引腳可以看成普通IO。
FPGA IO的基本結構
在《IO輸入輸出的各種模式》介紹了處理器IO的各種輸入輸出模式以及原理,那麼FPGA的IO是什麼樣的結構和原理?圖 1為Xilinx文件中提供的IOB的內部結構,可以看出:
- 在FPGA IOB內部,Pad輸出之前,內建上下拉電阻。且可以通過Passive Pull-up/Pull-down模組控制兩個MOS管的導通與否來控制是否使能上下拉電阻。
- 內部連線Pad的分別有一個Input Buffer和Output Buffer。其中Input
Buffer對外應該始終呈現高阻狀態,同時可以將Pad上的電平通過Input Buffer傳到I1和I2,或者是下部的FF。Output Buffer有兩個控制訊號,分別是Slew Rate Control,用來控制輸出訊號的Slew Rate;另一個是三態控制訊號T,可以控制Output Buffer輸出高阻。 - 內部輸出訊號Out,可以通過上半部分的FF,經Output Clock同步後打出,也可以直接連線到Output buffer的輸入端,直接輸出。
- 同樣Input Buffer的輸出,可以直接連線到I1和I2,也可以經過下半部分的FF,經過input clock的同步之後輸出到內部匯流排上。
- 上下兩個MOS並不是推輓輸出的兩個MOS管,因為並不受到互補訊號的控制,並不一定一個導通另一個閉合。
這裡介紹一下輸入快取器的結構和原理,其結構如圖 2所示,其原理與推輓輸出電路非常類似,只是輸入端訊號作為了兩個互補MOS管的控制端,控制著輸出端的電平。由於輸入緩衝器有自己的供電電壓,所以輸入電平必須與緩衝器的電源電壓相匹配。D1和D2兩個鉗位二極體用於防治輸入電壓過低或者過高,損壞輸入緩衝器。
普通IO
配置完成之前
在FPGA上電到配置完成之前,由於當前FPGA還沒有下載程式,無法區分哪些引腳被設計所使用,哪些引腳沒有被使用。此時的普通IO包括兩部分:
- 該封裝中所有的通用IO引腳。
- 當前所選擇的模式下沒有使用到的所有功能複用管腳。
在Spartan6系列以及之前的器件中這些引腳的狀態是根據HSWAPEN的狀態決定的。
在7系列以後的器件,包括Ultrascale器件中,這些引腳的狀態是根據PUDC_B(Pull-Up During Configuration)引腳
這兩個引腳的功能是相似的,都是用來控制在Configuration完成之前,所有普通IO的上拉電阻是否使能的。對應到圖 1中,即Output Buffer輸出高阻,Input Buffer對外始終為高阻,此時選擇是否連線上拉電阻。
配置完成之後
在配置完成之後,FPGA就進入正常工作的模式了。在配置完成之後,普通引腳可以分為以下兩種:
- 工程設計中使用的IO,即在UCF或者XDC中有明確約束的IO。
- 其餘沒有使用,也沒有約束的IO。(稱為Unassigned Pins)
首先,對於第一種情況,由於已經在設計中明確設定了這些引腳的設定,包括方向、電平、驅動能力等等,所以在配置完成之後,這些引腳的狀態已經被設定為了預設的狀態。
對於沒有約束的IO,又複雜一些了。在ISE開發環境下,工程完成Implement之後,在Processà Process properties àConfiguration Options中有"-g UnusedPin Unused IOB Pins"屬性,可以選擇Pull Down、Pull Up或者Floating。預設狀態是Pull-Down。對應到圖 1中,是高阻輸出,導通下拉電阻。另兩個設定就是高阻加上上拉電阻或者只是上下拉電阻均不導通。
在Vivado中也有相同的設定,必須在實現完成之後,開啟Implementation Design之後選擇bitstream Settings,其中在"Configure additional bitstream settings"中的Configuration欄中,有如下屬性選擇項。
專用IO
所有的專用配置引腳全部位於Bank0,包括CFGBVS、M[2:0]、TCK、TMS、TDI、TDO、PRORAM_B、INIT_B、DONE以及CCLK。專用引腳的含義就是無論在配置過程中還是配置完成之後,這些引腳無論在什麼階段都只用於配置。
所以對於這些引腳考慮相對比較簡單,分為輸入訊號和輸出訊號。輸入訊號的狀態始終保持LVCMOS電平標準,電壓值為VCCO(輸入訊號為什麼也有電平標準要求,需要與Input buffer的供電電壓相匹配,見圖 2)。輸出訊號的狀態始終保持LVCMOS電平標準,電壓為VCCO,12mA drive,fast slew rate。
功能複用IO
相比於其他引腳,功能複用引腳的情況是最複雜的,這些管腳包括與配置相關的PUDC_B、EMCCLK、CSI_B、CSO_B、DOUT、RDWR_B、D00_MOSI、D01_DIN、D[00-31]、A[00-28]、FCS_B、FOE_B、FEW_B、ADV_B、RS0以及RS1;以及與System Monitor相關的AD0P至AD15P、AD0N至AD15N,I2C_SDA以及I2C_SCLK。
為了說清楚功能複用管腳在不同階段的狀態,將複用管腳分為以下幾類:
在當前所選擇的功能中使用到的功能複用管腳,例如在選擇BPI配置時的D[00-31]和A[00-28]。
在當前所選擇的功能中沒有使用到的功能複用管腳。例如在選擇SPI配置時的D[00-31]和A[00-28]。
在完成配置之前需要作為輸出或者雙向,總之有可能向外輸出訊號的管腳,例如I2C_SDA和I2C_SCLK。
配置完成之前
在FPGA上電至配置完成之前的這段時間內,前面列出的第一類引腳,即在當前所選擇的功能中使用到的功能複用管腳,狀態等同於專用配置IO管腳。輸入訊號的狀態始終保持LVCMOS電平標準,電壓值為VCCO。輸出訊號的狀態始終保持LVCMOS電平標準,電壓為VCCO,12mA drive,fast slew rate。
前面列出的第二類引腳,即在當前所選擇的功能中沒有使用到的功能複用管腳,視同於普通IO,其狀態受到HSWAPEN或者PUDC_B訊號的控制,決定是高阻還是連線弱上拉電阻。
第三類引腳的情況比較複雜,目前所知的只有I2C_SDA和I2C_SCLK,這兩個訊號會在配置完成前出現一些不確定的狀態。所以如果FPGA的IO還有富餘,並且要求所有連線到外部的引腳有確定的狀態,那麼最好不要使用這兩個引腳作為連線外設的IO。
配置完成之後
在FPGA配置完成之後,前面提到的三種引腳會被分成另外三類:
第一類是在使用者設計中明確配置了需要保留的功能引腳,例如對於配置相關的引腳設定了Persist option屬性,這種情況下這些引腳會繼續保持之前與配置相關的功能,其狀態為輸入訊號的狀態始終保持LVCMOS電平標準,電壓值為VCCO。輸出訊號的狀態始終保持LVCMOS電平標準,電壓為VCCO,12mA drive,slow slew rate。再例如設計中使用了SYSMON,I2C_SDA和I2C_SCLK引腳則繼續保持DRP I2C的功能。
第二類是在使用者設計配置中沒有要求保留其特殊功能,這些引腳在配置完成之後會變成普通IO,且在使用者設計中沒有使用到的IO。這些IO相當於Unassigned IO,如前所述,這些IO在配置完成之後的狀態受到相應設定的影響,可以是上拉、下拉或者Floating。
第三類是在使用者設計配置中沒有要求保留其特殊功能,這些引腳在配置完成之後會變成普通IO,並且在使用者設計中使用到的IO。這些IO的狀態由使用者設計控制,會在XDC或者UCF中設定。如果沒有設定就會按照預設的狀態,輸入埠預設狀態為LVCMOS電平標準,電壓值為VCCO;輸出訊號預設狀態為保持LVCMOS電平標準,電壓為VCCO,12mA drive,slow slew rate。
文章轉自網際網路,版權歸原作者所有。
附錄 參考文件
[1] UG380 Spartan-6 FPGA Configuration
[2] UG470 7 Series FPGAs Configuration
[3] UG570 UltraScale Architecture Configuration
[4] UG580 UltraScale Architecture System Monitor
[5] https://forums.xilinx.com/t5/7-Series-FPGAs/Default-State-of-IOs-during-Configuration/td-p/402059
[6] https://forums.xilinx.com/t5/Spartan-Family-FPGAs/a-question-for-spartan6-lx16-io-state/td-p/399715
[7] https://forums.xilinx.com/t5/Spartan-Family-FPGAs/Spartan-6-FPGA-IO-state-before-configuration/td-p/259300
[8] https://forums.xilinx.com/t5/Design-Entry/Unassigned-Pin-Behavior/td-p/34114
[9] https://forums.xilinx.com/t5/7-Series-FPGAs/About-Create-Programmable-Ground-Pins-Unused-IO-Pad-Termination/td-p/698241
[10] https://courses.cs.washington.edu/courses/cse467/03wi/FPGA.pdf
相關文章
- 後端的狀態碼後端
- c++ io條件狀態 的一個例子C++
- 玩家——受傷後的保護狀態
- 狀態機設計
- 用設計模式去掉沒必要的狀態變數 —— 狀態模式設計模式變數
- Win10系統揚聲器設定為預設狀態的操作方法Win10
- FPGA 將1bit的flag量轉化為狀態保持的開關量(verilog)FPGA
- PRemiere介面怎麼恢復?PR介面功能恢復預設狀態的技巧REM
- SAP 電商雲 UI State persistence 狀態持久化設計的入口 - initSyncUI持久化
- 系統設計架構:有狀態與無狀態架構
- 設計模式:狀態模式設計模式
- 設計模式-狀態模式設計模式
- Xcode 檔案後狀態標識XCode
- 【架構設計】無狀態狀態機在程式碼中的實踐架構
- 請求更改狀態介面後,執行 sql 查出來狀態不對SQL
- vue-cli 預設路由再子路由選中下的選中狀態問題Vue路由
- win10系統預設輸入法改成英文狀態怎麼設定Win10
- SAP Fiori和WebClient UI的有狀態和無狀態行為設計原理WebclientUI
- python設計模式狀態模式Python設計模式
- 設計模式(十五)狀態模式設計模式
- 設計模式之——狀態模式設計模式
- GPUDepthStencilState物件設定depthStencil狀態GPU物件
- 通用的後端返回給前端的狀態資訊Result後端前端
- 使用 Provider 管理 Flutter 應用狀態 (上)IDEFlutter
- 架構設計(五):有狀態服務和無狀態服務架構
- win10 如何修改預設英文輸入法_win10 如何修改預設輸入法為英文狀態Win10
- 前端提交資料後http狀態碼400前端HTTP
- MUI——設定沉浸式狀態列UI
- 設計模式-狀態模式(State Pattern)設計模式
- PHP 設計模式之狀態模式PHP設計模式
- 《Head First 設計模式》:狀態模式設計模式
- 設計模式20之狀態模式設計模式
- 簡說設計模式——狀態模式設計模式
- 極簡設計模式-狀態模式設計模式
- 設計模式之狀態模式(State)設計模式
- GoLang設計模式14 - 狀態模式Golang設計模式
- python設計模式【9】-狀態模式Python設計模式
- 直播app原始碼,狀態列和導航欄設定成透明狀態APP原始碼