《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > 基于DSP的SOPC技術設計
基于DSP的SOPC技術設計
摘要: 隨著微電子技術和計算機工具軟件的發展,可編程片上系統SOPC的設計理念和設計方法成為了一種趨勢。為了解決傳統DSP處理器所面臨的速度問題、硬件結構不可重構性問題、開發升級周期長和不可移植性等問題,我們應用Altera公司推出的Nios II嵌入式軟核處理器,提出了一種具有常規DSP處理器功能的Nios II系統SOPC解決方案。
關鍵詞: 接口IC DSP SoPC 接口模塊
Abstract:
Key words :


結合Altera公司推出的Nios II嵌入式軟核處理器,提出一種具有常規DSP處理器功能的NiosII系統SOPC解決方案;利用NiosII可自定叉指令的特點。

  通過Matlab和DSP Builder或直接用VHDL設計并生成復數乘法器、整數乘法器和浮點乘法器等硬件模塊,將它們定制為相應的指令,從而將軟件的靈活性和硬件的高速性結合起來,較好地解決了傳統DSP處理器所面臨的速度問題、硬件結構不可重構性問題、開發升級周期長和不可移植性等問題。

  隨著微電子技術和計算機工具軟件的發展,可編程片上系統SOPC的設計理念和設計方法成為了一種趨勢。為了解決傳統DSP處理器所面臨的速度問題、硬件結構不可重構性問題、開發升級周期長和不可移植性等問題,我們應用Altera公司推出的Nios II嵌入式軟核處理器,提出了一種具有常規DSP處理器功能的Nios II系統SOPC解決方案。

  由于可編輯的Nios II核含有許多可配置的接口模塊核,因此用戶可根據設計要求,利用Quar-tusII和SOPC Builder對NiosII及其外圍系統進行構建。而且用戶可通過Matlab和DSP Builder,或直接用VHDL等硬件描述語言設計,為Nios II嵌入式處理器設計各類硬件模塊,并以指令的形式加入Nios II的指令系統,從而成為Nios II系統的一個接口設備,與整個片內嵌入式系統融為一體,而不是直接下載到FPGA中生成龐大的硬件系統。正是Nios II所具有的這些重要特點,使得可重構單片DSP處理器功能系統的設計成為可能。

  1 系統結構

  本系統為單片DSP可重構系統,能實現數字信號處理方面各種功能。其中,Nios II軟核處理器的建立,主要起人機交互和控制作用。FPGA的邏輯模塊從Nios II處理器接收控制信號和數據后,實現相應的硬件功能。系統結構框圖如圖l所示。除了軟核處理器Nios II外,存儲器和I/O接口以及FIR數字濾波器、IIR數字濾波器和DDS等應用模塊均可作為外設嵌入在FPGA中。這樣,整個DSP的數字信號處理部分全部集成在FPGA器件中,各模塊均受Nios II處理器的控制。Nios II處理器系統中有Avalon總線,它規定了控制器與從屬模塊間的端口連接以及模塊閫通信的時序。數字頻率合成器DDS通過Avalon總線與Nios II處理器相連,能很方便地完成控制及數據傳送。

 

  本系統的FPGA采用Cyclone EPICl2,它有12 060個邏輯單元(LE)和2個鎖相環(PLLs),提供6個輸出和層次時鐘結構以及復雜設計的時鐘管理電路。選用超高速10位D/A轉換器565l實現D/A轉換功能,轉換速率最高為150 MHz。整個系統在Nios II處理器的控制下,可實現FIR數字濾波、IIR數字濾波、快速傅里葉變換(FFT)算法、編/解碼、DDS功能模塊設計,以及由它構成的數控頻率調制、正交載波調制解調、數控相位調制等功能的信號發生器。

  系統中各功能模塊的選擇,以及輸出信號調制方式和頻率的選擇,均可通過外接的按鍵自由選擇。下面構建一個具有常規DSP處理器功能的Nios II系統。

  2 Nios II嵌入式系統設計流程

  NiosII嵌入式處理器是Altera公司推出的一種專門為單芯片可編程系統(SOPC)設計而優化的CPU軟核,是一種面向用 
戶、可以靈活定村的通用RISC(精簡指令集)嵌入式CPU。它采用Avalon總線結構通信接口,帶有增強的內存、調試和軟件功能,可采用匯編或C、C++等語言進行程序優化開發;具有32位指令集、32位數據通道和可配置的指令及數據緩沖。與普通嵌入式CPU系統的特性不同,其外設可以靈活選擇或增刪,可以自定制用戶邏輯為外設,可以允許用戶定制自己的指令集。由硬件模塊構成的自定制指令可通過硬件算法操作來完成復雜的軟件處理任務,也能訪問存儲器或Nios II系統外的接口邏輯。設計者可以使用Nios II加上外部的Flash、SRAM等,在FPGA上構建一個嵌入式處理器系統。

  完整的基于Nios II的SOPC系統是一個軟硬件復合的系統,因此在設計時可分為硬件和軟件兩部分。Nios II的硬件設計是為了定制合適的CPU和外設,在SOPCBuider和Quartus II中完成。在這里,可以靈活定制NiosII CPU的許多特性甚至指令;可以使用Altera公司提供的大量IP核來加快開發Ntos II外設的速度,提高外設性能;也可使用第三方的IP核,或VHDL自己來定制外設。完成Nios II的硬件開發后,SOPC Buider可自動生成與自定義的Nios II CPU和外設系統、存儲器、外設地址映射等相對應的軟件開發包SDK;在生成的SDK基礎上,進入軟件開發流程。可使用匯編或C語言,甚至C++語言來進行嵌入式程序設計,使用GNU工具或其他第三方工具進行程序的編譯、鏈接及調試。

3 系統硬件設計

  系統的硬件系統包括3個部分:FPGA部分、存儲器部分和外圍元器件部分。FPGA部分是建立在FPGA內的,在SOPC Buider中需要設計的就是該部分。其中包含1個NiosII CPU核,1個內部時鐘,1個Avalon總線控制器,連接Nios II核的下載和調試程序的JTAG_UART通信模塊,DDS接口模塊及DDS模塊,FIR、IIR數字濾波器接口模塊及功能模塊,編解碼模塊及接口模塊,以及Flash存儲器模塊等。其設計與一般的嵌入式開發不同,可在Nios II核外(但還在同一個FPGA芯片內)加入相應的外設模塊核,并通過在片上的Avalon總線與Nios II相連。為使具有DSP處理器功能的Nios II系統正常工作,在FPGA外圍接有一些控制鍵,以調度各模塊的應用。

  3.1 建立Nios II嵌入式處理器系統

  首先,利用Quartus II建立項目工程,選用的目標器件為Cyclone EPIC12; 
再用SOPC Bider創建Nios II組件模型,生成硬件描述文件,鎖定引腳后進行綜合與適配,生成Nios II硬件系統下載文件;然后建立Nios II嵌入式系統,從SOPC Buider組件欄中加入所需的組件(如Nios IICPU核、定時器Timer、JTAG_UART、Avalon三態總線橋、鍵輸入I/O口和Flash等)。另外,為了實現NiosII處理器對EPCS Flash存儲器的讀寫訪問,還要加入一個EPCS Serial F1ash Controller組件。通過此控制器將用于FPGA配置的SOF文件和CPU運行的軟件一并存于EPCS器件中,以便大大簡化硬件系統組成結構。為了保證所有組件的地址安排是合法的,要對各組件地址實行自動分配;最后進行全程編譯(即分析、綜合、適配和輸出文件裝配),完成Nios II硬件系統的設計。

  在Nios II硬件系統設計完成后。將配置文件下載到指定的FPGA中。通過SOPC Buider軟件窗口,可進入Nios II IDE軟件開發環境進行軟件設計。

  3.2 DSP處理器功能系統的建立

  使用DSP Buider在FPGA上進行DSP模塊的設計,可實現高速DSP處理。但是,在實際應用中,除了要求DSP高速外,由于DSP處理的算法往往比較復雜,如果單純使用DSP Bider來實現純硬件的DSP模塊,會耗費過多的硬件資源,因此有時也無法完成許多算法復雜的模型。而Nios II則是一個建立在FPGA上的嵌入式微處理器軟核,它有一個重要的特性是具有自定制指令。

  在DSP算法中會反復出現一些運算(如復數乘法器、整數乘法器、浮點乘法器等),而在通用的CPU中都沒有專門用于復數乘法計算和浮點乘法計算的相關指令。在系統設計中,利用MATLAB、DSP Buider或者VHDL設計并生成復數乘法器、整數乘法器、浮點乘法器等硬件模塊。在Quartus II環境中對上述文件做一些修正后,在SOPC Buider窗口中將它們定制為相應的指令,并可設定或修改執行該指令的時鐘周期。在進行DSP算法運算時,可通過匯編或C語言,甚至C++語言來運用這些自定義指令進行嵌入式程序設計。

  根據復數運算的算法,假設有2個復數為a+bj和c+dj,則乘法表述為:

 

  圖2是用MATLAB、DSP Buider設計的復數乘法器模型。它實現了一個16位的復數乘法,虛部和實部都是16位,可以用一個32位的值表示該復數。在設計中,NiosII為32位數據,正好可以放置2個復數。

 

  要將這個復數乘法器硬件模塊設置成相應的指令,還須進行以下操作:

  ①單擊圖標SignalCompiler對其進行轉換,選擇器件(用Cyclone)和Quartus II綜合器.轉換后使其生成SOPCBuider的PTF文件。

  ②退出MATLAB后,在Quartus II環境中對轉換后所生成的復數乘法器的頂層VHDL文件進行修改。在SOPC Buider窗口雙擊CPU項,進入“指令加入”編輯窗,將這個硬件模塊設置成自定義的復數乘法指令。

  指令生成后,可利用Quartus II編輯C程序進行測試;測試成功后,在DSP算法計算中遇到復數乘法就可以運用復數乘法指令。這種方法將常用的硬件模塊生成指令,通過軟硬件并存的設計方法在FPGA中實現較復雜的DSP算法,能夠將軟件的靈活性和硬件的高速性結合起來,較好地解決了現代DSP設計中的諸多問題。但對于DDS模塊,還是以硬件形式固化在FPGA中。可以根據需要,利用DDS設計出幅度、相位和頻率調制器。

  另外,Nios II的外設是可任意定制的,Nios II系統的所有外設都是通過Avalon總線與Nios II CPU相接的。Avalon總線是一種協議較為簡單的片內總線,Nios II通過Avalon總線與外界進行數據交換。在本系統中,采用AvalonSlave外設方式加入了自定制AvalorL總線組件A/D轉換接口模塊、D/A接口模塊,用于控制采樣A/D的工作以及高速D/A的波形數據輸出;而自定義的Avalon總線組件DDS模塊接口和DSP功能轉換控制接口,則用于Nios II CPU對DDS模塊的控制,以及通過外部鍵盤來控制DSP功能的選擇。

  結語

  整個系統除了A/D、D/A轉換器和控制選擇鍵盤外接外,其余都在一片FPGA町編程芯片中。由于有NiosII作CPU,因此既可自定義指令,也可通過Avalon總線自定義各種接口模塊組件,使整個DSP系統的使用靈活多樣,在現代DSP技術中有著越來越多的應用。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
黄色在线一区| 久久精品九九| 亚洲永久免费精品| 日韩视频在线观看国产| 韩国福利一区| 国产一区久久| 国产区欧美区日韩区| 国产精品成人一区二区三区夜夜夜 | 欧美日韩视频在线一区二区| 欧美国产日韩视频| 欧美国产精品专区| 欧美激情亚洲综合一区| 欧美成va人片在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎| 久久欧美中文字幕| 麻豆乱码国产一区二区三区| 久久综合久久88| 欧美a级大片| 欧美成人一品| 欧美日韩一级黄| 国产精品国产精品国产专区不蜜| 国产精品wwwwww| 国产乱码精品一区二区三| 国产精品综合久久久| 国产一区二区高清| 在线观看视频一区二区| 精品成人a区在线观看| 影音先锋日韩资源| 亚洲经典在线看| 一本色道久久88亚洲综合88| 亚洲精品一区二区三区樱花| 日韩午夜在线播放| 亚洲图色在线| 欧美一区二区三区成人| 久久精品视频在线看| 亚洲日韩成人| 亚洲午夜在线| 亚洲欧美日韩国产成人精品影院| 欧美亚洲系列| 久久夜色精品国产欧美乱| 欧美国产一区二区| 欧美视频在线免费| 国产亚洲日本欧美韩国| 亚洲成在人线av| 一本久久a久久精品亚洲| 午夜一区在线| 亚洲精品在线观看免费| 欧美精品一区二区三区在线看午夜| 国产在线播放一区二区三区| 国产在线乱码一区二区三区| …久久精品99久久香蕉国产| 亚洲精品一区二区在线| 亚洲欧美日本视频在线观看| 久久精品视频在线| 亚洲视频精品| 久久精品综合一区| 欧美精品激情blacked18| 国产精品久久久久久久免费软件| 国产亚洲一二三区| 亚洲精品乱码久久久久久蜜桃91 | 亚洲一区三区视频在线观看| 久久成人精品电影| 中文有码久久| 久久午夜精品| 欧美视频精品在线观看| 激情久久婷婷| 一区二区三区四区五区精品视频 | 在线看欧美视频| 在线视频亚洲欧美| 亚洲国产高清自拍| 亚洲欧美在线aaa| 欧美不卡视频一区发布| 国产精品嫩草影院av蜜臀| 亚洲高清二区| 亚洲一区二区三区在线视频| 亚洲片区在线| 久久精品1区| 欧美天堂亚洲电影院在线观看| 韩国v欧美v日本v亚洲v| 一区二区三区欧美在线| 亚洲国产日韩综合一区| 欧美一级理论片| 欧美日韩国语| 极品裸体白嫩激情啪啪国产精品| 在线中文字幕日韩| 亚洲精品欧美极品| 久久精品国产亚洲一区二区三区| 欧美日韩在线大尺度| 曰韩精品一区二区| 香蕉久久夜色精品国产| 中文久久乱码一区二区| 欧美成人精品在线| 国产亚洲欧美一区二区三区| 中文国产一区| 一区二区三区四区国产| 免费久久99精品国产自| 国产欧美成人| 亚洲视频精品在线| 亚洲成色www8888| 一本色道久久99精品综合| 亚久久调教视频| 亚洲欧美日本国产专区一区| 欧美老女人xx| 亚洲第一精品福利| 久久成人精品一区二区三区| 性高湖久久久久久久久| 欧美三级午夜理伦三级中文幕| 亚洲国产小视频| 91久久精品国产91性色 | 羞羞色国产精品| 欧美日韩一区二区免费在线观看| 亚洲国产精品久久久久秋霞不卡 | 欧美亚洲免费| 欧美在线观看视频一区二区三区| 欧美视频中文字幕在线| 亚洲三级免费电影| 亚洲精品久久久久久一区二区| 久久久久久69| 国产亚洲成精品久久| 午夜亚洲福利| 欧美资源在线观看| 国产女精品视频网站免费| 亚洲嫩草精品久久| 欧美一级在线视频| 国产噜噜噜噜噜久久久久久久久| 亚洲一区二区三区午夜| 午夜精品亚洲| 国产精品专区h在线观看| 亚洲免费视频一区二区| 欧美亚洲色图校园春色| 国产色综合久久| 欧美专区中文字幕| 蜜桃av噜噜一区| 亚洲国产精品一区二区www| 亚洲美洲欧洲综合国产一区| 免费黄网站欧美| 亚洲精品日韩在线| 亚洲尤物精选| 国产欧美日韩不卡| 久久成人亚洲| 母乳一区在线观看| 日韩午夜电影av| 午夜在线不卡| 国内久久婷婷综合| 亚洲茄子视频| 欧美三级免费| 亚洲欧美日韩在线观看a三区| 久久激情五月丁香伊人| 亚洲成人在线视频网站| 一区二区欧美视频| 国产精品日韩久久久久| 欧美一级黄色网| 欧美成年人视频网站欧美| 亚洲精品乱码久久久久久久久| 亚洲香蕉伊综合在人在线视看| 国产精品区免费视频| 欧美在线视频全部完| 欧美成人综合在线| 中文欧美字幕免费| 久久人人精品| 亚洲精品美女久久7777777| 亚洲一区二区在线观看视频| 国产农村妇女精品一二区| 最新成人av在线| 欧美午夜电影在线| 欧美在线黄色| 欧美日韩免费区域视频在线观看| 亚洲一区二区成人| 蜜臀久久99精品久久久画质超高清| 亚洲精品一区在线| 久久精品色图| 亚洲精品综合| 久久国产夜色精品鲁鲁99| 亚洲欧洲日韩在线| 欧美在线播放高清精品| 亚洲国产视频一区| 欧美一区成人| 91久久精品www人人做人人爽| 性欧美大战久久久久久久久| 精品av久久久久电影| 亚洲一区二区三区精品动漫| 狠狠久久亚洲欧美| 亚洲一区二区三区精品动漫| 激情成人在线视频| 亚洲综合日本| 91久久精品网| 久久精品2019中文字幕| 日韩视频在线播放| 另类综合日韩欧美亚洲| 亚洲一区二区三区影院| 欧美黄色一级视频| 欧美在线观看视频一区二区| 欧美日韩亚洲综合一区| 久久国产日韩欧美| 国产精品久久久久影院色老大| 亚洲国产日韩一级| 国产色综合网| 亚洲欧美综合一区| 亚洲精品免费在线| 久久欧美肥婆一二区|