《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 在NIOS-II系統中A/D數據采集接口的設計與實現
在NIOS-II系統中A/D數據采集接口的設計與實現
摘要: 在FPGA系統中,實現對外部A/D數據采集電路的控制接口邏輯,由于其邏輯功能不是很復雜,因此可采用自定義的方式。采用這種方法進行設計有兩種途徑。①從軟件上去實現。這種方案將NIOS處理器作為一個主控制器,通過編寫程序來控制數據轉換電路。由于NIOS處理器的工作頻率相對于外部設備來說要高出許多,故此種方法會造成CPU資源極大的浪費;②用FPGA 的邏輯資源來實現A/D采集電路的控制邏輯。FPGA有著豐富的邏輯資源和接口資源,在其中實現并行的數據采集很少會受到硬件資源的限制,在功能上,設計的接口控制邏輯相當于一個主控制器,它是針對具體的外部電路而實現的,容易滿足要求、又能節約資源,提高系統性能。因此,采用硬件邏輯去實現控制將是一種較好的方式。
Abstract:
Key words :

  在FPGA系統中,實現對外部A/D數據采集電路的控制接口邏輯,由于其邏輯功能不是很復雜,因此可采用自定義的方式。采用這種方法進行設計有兩種途徑。①從軟件上去實現。這種方案將NIOS處理器作為一個主控制器,通過編寫程序來控制數據轉換電路。由于NIOS處理器的工作頻率相對于外部設備來說要高出許多,故此種方法會造成CPU資源極大的浪費;②用FPGA 的邏輯資源來實現A/D采集電路的控制邏輯。FPGA有著豐富的邏輯資源和接口資源,在其中實現并行的數據采集很少會受到硬件資源的限制,在功能上,設計的接口控制邏輯相當于一個主控制器,它是針對具體的外部電路而實現的,容易滿足要求、又能節約資源,提高系統性能。因此,采用硬件邏輯去實現控制將是一種較好的方式。

  設計方案

  通過對系統需求進行仔細分析,此模塊的功能設計可分為數據采集控制邏輯、數據接口、數據處理邏輯三部分,其整體功能框架圖如圖1。

模塊功能框圖

圖1 模塊功能框圖

  說明:AVALON總線主要是用于連接片內處理器與外設,以構成可編程單芯片系統。

  功能描述

  • 數據采集控制邏輯:產生A/D轉換需要的控制信號。
  • 數據接口:提供一個外部A/D采集的數據流向AVALON總線的數據通道,主要是完成速度匹配,接口時序轉換。
  • 數據處理單元:此部分主要是提供一些附加功能,如檢測外部信號或內部其它單元的工作狀態,進行簡單信息處理。

  設計分析

  數據采集控制邏輯

  在此以典型的模數轉換芯片ADC0804為例,進行電路設計,ADC0804的數據寬度為8位,數據轉換時間最快為100ms,轉換時鐘信號可以由內部施密特電路和外接RC電路構成的震蕩器產生,也可以直接由外部輸入,其頻率范圍:100KHz~1460KHz。在本設計中ADC0804的時鐘為最大輸入頻率,控制信號時序如圖2。

ADC0804控制信號時序圖

圖2 ADC0804控制信號時序圖

  由ADC0804的時序可知,轉換過程由一個寫信號啟動,轉換完成后,輸出INTR信號,此時可以讀取數據。之后即可

 

進入下一個轉換周期。由ADC0804的轉換時間可知,其最大采集頻率為10KHz,只要用戶設置的采樣頻率不超過這個數值,ADC0804就可以正常的工作。因此設計時要注意兩點:①寫信號的頻率要低于ADC0804的最大轉換頻率;②在寫信號之后至少要有100ms的時延,才能輸出讀信號。

 

  在此,提出兩種方法來實現ADC0804的控制信號時序:①主動模式—控制電路啟動A/D轉換后,在INTR信號的作用下,輸出讀信號,同時從ADC0804的數據總線上讀入數據,之后輸出一個寫信號,開始下一次轉換。②被動模式—ADC0804的讀寫信號完全由控制電路按照固定的時序產生,與其自身輸出無關。

  數據接口

  相對于AVALON總線信號來說,A/D采樣的速率非常低,而且,AVALON總線的接口信號和ADC0804數據輸出的接口信號時序不一致。因此,要實現滿足要求的數據通道,要做到兩點:①數據緩沖,實現速率匹配;②信號隔離,實現接口時序的轉換。解決這兩點,可以將兩端口通過一個異步的FIFO連接,該FIFO應該是可以在不同的時鐘信號下進行異步的讀寫。這樣的一個FIFO的實現可以在Quartus-II里面用ALTERA公司提供的FIFO Core進行定制。在本設計中,定制的FIFO模塊如圖3。

FIFO模塊

圖3 FIFO模塊

  設計實現

  圖4為在Quartus-II中設計實現的ADC0804數據采集接口控制模塊的原理圖。

A/D數據采集控制模塊原理圖

圖4  A/D數據采集控制模塊原理圖

  其中read、readdata、reset、irq分別與AVALON總線相同命名的信號線相連,readclk與AVALON總線中clk相連, AD_50與FPGA的系統時鐘相連,wr_n、rd_n、writedata分別與ADC0804的寫信號線、讀信號線、數據線相連。ADC0804控制信號產生單元的實現,采用的是上文提到的被動模式,該單元以固定的時序產生讀寫信號,本設計使用的采樣頻率約為3200Hz,此頻率可以根據用戶的需要而設定( 不大于10KHz即可)。

  當系統加電后,wr_n輸出一個有效的寫信號啟動A/D轉換,經過足夠的時間后(T=327μs~328μs),輸出讀信號,此時數據接口單元的寫允許信號wr_fifo變為有效,同時外部A/D轉換器的讀允許信號也變為有效,此后ADC0804的數據端口上輸出有效數據,在wr_clk的上升沿將A/D轉換器的數據讀入FIFO。控制邏輯單元的時序仿真圖如圖5。

  由圖5可知,wr_fifo有效時,ADC0804必須在wr_clk的上升沿到來之前在其數據端口輸出有效的數據。由于wr_clk的周期為1ms,ADC0804的輸出鎖存由其讀引腳rd控制,rd變為有效即可輸出有效的數據,故只要ADC0804的讀信號rd在外部輸入的作用下變為有效的時間不超過500ns,讀操作就不會出現問題。ADC0804的rd信號三態延時最大為200ns,典型值為125ns,因此控制信號產生邏輯單元滿足要求。

 

控制信號時序仿真

圖5  控制信號時序仿真

  當NIOS系統需要讀取數據時,在read和readclk上出現的是系統AVALON總線上的讀時序。時序圖如圖6。

基本從端口讀傳輸

圖6  基本從端口讀傳輸

  在AVALON總線中定義了兩種類型的信號,一種是高電平有效,另一種是低電平有效。在本設計中選用的是高電平有效的類型。圖6是低電平有效的總線信號,與之對應的高電平有效的總線信號時序圖中,read在有效時為高電平對應于圖6中的readn的低電平部分。而address,be-n和chipselect在此可以不與考慮,添加到AVALON總線時,系統會自動處理其連接問題。

  當系統不讀取A/D轉換的數據時,采集的數據由數據處理單元控制處理。數據處理單元實現了對外部信號量的異常檢測,即,當外部信號的幅值超出設定范圍時,該單元產生一個

 

中斷信號,通知CPU采取相關處理措施,否則,在FIFO滿的時候,將其內容清空。

 

  結語

  經測試,本設計可以不間斷無數據丟失的進行數據采集,CPU可以主動的讀取數據,也可以在數據處理單元檢測到外部異常信號時被動的獲取數據,并且CPU讀取數據的操作極其簡單,運行時只占用很少的CPU資源,在此,謹希望本文能在如何設計NIOS系統外設方面給讀者以參考借鑒。

此內容為AET網站原創,未經授權禁止轉載。
主站蜘蛛池模板: 免费一级特黄特色黄大任片 | 亚洲天堂影院在线观看 | 欧美满嘴射 | 性视频亚洲 | 国产喷水女王在线播放 | 亚洲欧美手机在线观看 | 国产亚洲精品久久久久91网站 | 国产精品v一区二区三区 | 亚洲国产精久久久久久久 | 欧美一二三 | 国产午夜亚洲精品 | 免费人成黄页网站在线观看国产 | 精品国产91久久久久久久a | 就草草在线观看视频 | 国产在线观看高清精品 | 99精品在线免费观看 | 国产精品久久久久久久专区 | 成人在线精品 | 国产免费一级视频 | 日韩专区亚洲精品欧美专区 | 香港aa三级久久三级 | 日本韩国一级 | 中文字幕精品在线观看 | 久久久久久亚洲精品影院 | 欧美国产成人一区二区三区 | 国产女厕偷窥系列在线视频 | 国产成人精品福利网站在线 | 日韩中文字幕免费观看 | 91热久久 | 国产精品久久不卡日韩美女 | 亚洲在线国产 | 黄网站色视频免费观看w | 亚洲福利视频一区二区三区 | 久久青草热 | 免费看岛国视频在线观看 | 国产第二页 | 国产黄色大片网站 | 黄 色 免费网 站 成 人 | 国语自产精品视频 | 亚洲在线看 | 无内丝袜透明在线播放 |