沒有直接可用的Pmod驅(qū)動?
傳授你一招填坑秘籍
之前我們提到過「Pmod傳感模塊」,這一搭配FPGA開發(fā)板進行快速原型系統(tǒng)開發(fā)的利器。事實上,除了Pmod標準定義接口的專利方 —— Digilent公司所提供的近百種功能豐富的原廠Pmod傳感模塊之外(一般都配有免費的ip驅(qū)動供開發(fā)者直接調(diào)用),市場上存在著很多來自不同供應(yīng)商所提供的可用Pmod模塊。
然鵝,很多來自于不知名小廠的Pmod(以***、深圳的山寨廠商居多),往往并不提供模塊驅(qū)動,需要用戶自己去寫驅(qū)動填坑。如果你不幸中招,聊表安慰之余,今天就傳授你一招填坑秘籍,教你在沒有可用驅(qū)動情況下的應(yīng)對之策。
先說重點:如果沒有可用的驅(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接口上下層都進行相應(yīng)的選擇配置,使得Pmod傳感器的管腳輸出(pinout)與對應(yīng)的板載接口標準一致。有興趣的朋友,可點擊「閱讀原文」,下載查看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)建工程,導(dǎo)出到SDK,編寫軟件程序驅(qū)動DA4。
我們可以使用SDK中由BSP創(chuàng)建的SPI驅(qū)動來驅(qū)動PmodDA4。為了實現(xiàn)與PmodDA4的交互,第一件事我們要做的就是初始化SPI控制器。我們設(shè)置好SPI時鐘相位和主操作選項后就可以定義緩沖區(qū),并使用輪詢傳輸模式將所需的信息傳遞給PmodDA4。更復(fù)雜的驅(qū)動則將使用中斷驅(qū)動方式而非輪詢的方式。
下面,我們對創(chuàng)建好的PmodDA4驅(qū)動文件進行測試。我們驅(qū)動一個簡單的諧波輸出,并使用Digilent Analog Discovery口袋儀器的示波器功能來監(jiān)測DAC輸出。接收到的信號如下:
完成了所有設(shè)置PmodDA4以預(yù)期的方式正常工作,然后我們將PmodDA4與PmodAD2連接在一起,這樣Zynq SoC才能夠接收信號:
測試時我們要非常仔細,以確保PmodDA4輸出的信號在PmodAD2的工作范圍內(nèi),全部完成后則會顯示PmodDA4能夠在硬件上正常工作。
到這里,相信大家已經(jīng)了解了在沒有可用驅(qū)動的情況下如何自行創(chuàng)建Pmod驅(qū)動。當然,填坑往往是不得已而為之,人生苦短,芳華有限,盡量少碰不提供驅(qū)動的山寨小廠Pmod才是王道。
-
賽靈思
+關(guān)注
關(guān)注
33文章
1795瀏覽量
132032 -
傳感模塊
+關(guān)注
關(guān)注
0文章
9瀏覽量
7892 -
Pmod驅(qū)動
+關(guān)注
關(guān)注
0文章
1瀏覽量
1934
原文標題:只需一招,Zynq搭配Pmod開發(fā),沒驅(qū)動也不怕
文章出處:【微信號:FPGA-EETrend,微信公眾號:FPGA開發(fā)圈】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
通孔電鍍填孔工藝研究與優(yōu)化

PCB 焊接難題怎么破?健翔升科技傳授秘籍,溫度誤區(qū)全攻克!
從樹脂塞孔到電鍍填孔:PCB填孔技術(shù)的發(fā)展歷程
一招治“浮”! 高精度3D線激光輪廓測量儀保障螺絲裝配

如果不使用EEPROM的話,使用bios,BIOS來寫驅(qū)動填這個eeprom的值?
教你三招異地訪問NAS

存儲空間告急?NAS擴容一招搞定,輕松無憂!

pam5102a不能直接驅(qū)動1w的喇叭,有沒有可以驅(qū)動1w 8Ω的喇叭的?
MOS管電源IC直接驅(qū)動電路

PCB盲孔填銅,提升電路性能的關(guān)鍵一步
想用運放直接驅(qū)動一些小型繼電器,請問有沒有合適的芯片推薦?
艾體寶干貨 IOTA流量分析秘籍第三招:檢測黑名單上的IP地址

艾體寶干貨 IOTA流量分析秘籍第一招:網(wǎng)絡(luò)基線管理

評論