沒有直接可用的Pmod驅(qū)動?傳授你一招填坑秘籍
傳授你一招填坑秘籍
之前我們提到過「Pmod傳感模塊」,這一搭配FPGA開發(fā)板進行快速原型系統(tǒng)開發(fā)的利器。事實上,除了Pmod標準定義接口的專利方 —— Digilent公司所提供的近百種功能豐富的原廠Pmod傳感模塊之外(一般都配有免費的ip驅(qū)動供開發(fā)者直接調(diào)用),市場上存在著很多來自不同供應商所提供的可用Pmod模塊。
然鵝,很多來自于不知名小廠的Pmod(以臺灣、深圳的山寨廠商居多),往往并不提供模塊驅(qū)動,需要用戶自己去寫驅(qū)動填坑。如果你不幸中招,聊表安慰之余,今天就傳授你一招填坑秘籍,教你在沒有可用驅(qū)動情況下的應對之策。
先說重點:如果沒有可用的驅(qū)動,可以使用Zynq SoC PL端(可編程邏輯)的Pmod橋模塊,它讓我們能夠在選用的開發(fā)板與Pmod端口之間建立正確的映射,然后開發(fā)我們自己的Zynq PS(處理系統(tǒng))驅(qū)動。假如你仔細研究正規(guī)廠商所提供的Pmod驅(qū)動,你會發(fā)現(xiàn)這些驅(qū)動其實也是使用Pmod橋加上一個AXI I2C或者SPI組件所實現(xiàn)的。
圖:Digilent PmodAD2:12位四通道模擬數(shù)字轉(zhuǎn)換器的驅(qū)動組件
此文中,我們就將以Digilent(迪芝倫)PmodDA4:8通道DAC模塊,以及PmodAD2:4通道ADC模塊為例,我們將這兩個模塊整合在一起,借助Pmod橋模塊自行開發(fā)驅(qū)動,用PmodDA4生成模擬信號,并用PmodAD2來接收信號。
圖:用Digilent Analog Discovery口袋儀器對PmodDA4測試
Pmod橋模塊允許我們定義開發(fā)板板載Pmod接口上下兩排的輸入類型,可以選擇定義為GPIO、UART、I2C或者SPI協(xié)議接口。我們?yōu)樗栩?qū)動的板載Pmod接口上下層都進行相應的選擇配置,使得Pmod傳感器的管腳輸出(pinout)與對應的板載接口標準一致。有興趣的朋友,可點擊「閱讀原文」,下載查看Digilent Pmod傳感器的接口標準文檔。
對于PmodDA4,我們只需要在板載Pmod接口上層使用SPI協(xié)議。這樣選擇后,我們需要提供實際的SPI通信通道。由于我們使用的是Zynq SoC開發(fā)板(Digilent Arty Z7),所以這里我們有兩個選擇。第一個方法是在PL端使用AXI SPI IP模塊與Pmod橋模塊建立連接。第二個方法(也是這里我們將采用的)是使用EMIO建立Zynq PS SPI與Pmod橋中間的連接。這一方法將讓我們能夠在PS SPI端口與Pmod橋模塊輸入管腳之間建立直連。
為了實現(xiàn)這一點我們需要閱讀官方的Pmod接口標準文檔來確保SPI管腳與Pmod橋輸入管腳之間正確的映射(例如哪個PS SPI信號連接到IN_0)。Pmod 橋模塊的管腳代表不同的接口類型,它們的命名也是通用的。下面的框圖展示了這里我們是如何實現(xiàn)PmodDA4管腳的映射。在這個示例中我們完成管腳映射后就可以構(gòu)建工程,導出到SDK,編寫軟件程序驅(qū)動DA4。
我們可以使用SDK中由BSP創(chuàng)建的SPI驅(qū)動來驅(qū)動PmodDA4。為了實現(xiàn)與PmodDA4的交互,第一件事我們要做的就是初始化SPI控制器。我們設(shè)置好SPI時鐘相位和主操作選項后就可以定義緩沖區(qū),并使用輪詢傳輸模式將所需的信息傳遞給PmodDA4。更復雜的驅(qū)動則將使用中斷驅(qū)動方式而非輪詢的方式。
下面,我們對創(chuàng)建好的PmodDA4驅(qū)動文件進行測試。我們驅(qū)動一個簡單的諧波輸出,并使用Digilent Analog Discovery口袋儀器的示波器功能來監(jiān)測DAC輸出。接收到的信號如下:
完成了所有設(shè)置PmodDA4以預期的方式正常工作,然后我們將PmodDA4與PmodAD2連接在一起,這樣Zynq SoC才能夠接收信號:
測試時我們要非常仔細,以確保PmodDA4輸出的信號在PmodAD2的工作范圍內(nèi),全部完成后則會顯示PmodDA4能夠在硬件上正常工作。
到這里,相信大家已經(jīng)了解了在沒有可用驅(qū)動的情況下如何自行創(chuàng)建Pmod驅(qū)動。當然,填坑往往是不得已而為之,人生苦短,芳華有限,盡量少碰不提供驅(qū)動的山寨小廠Pmod才是王道。