《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于FPGA的多路正弦波信號發生器專用芯片設計
基于FPGA的多路正弦波信號發生器專用芯片設計
于國蘋,王桂海,桑圣鋒
(山東科技大學 信息學院,山東 青島 266510)
摘要: 基于開源思想與SOPC技術,采用32位開源軟核處理器OR1200和開源軟核DDS,在FPGA上實現了頻率、相位可預置并且可調的3路正弦波信號發生器專用芯片的設計。該專用芯片基于OR1200固化專用程序實現,通過UART傳輸控制數據,可同時控制3路正弦波的產生,其頻率范圍為1 Hz~100 MHz,步進頻率為1 Hz,相位范圍為0°~359°。設計方案在DE2-70開發板上進行了實際驗證,證明了設計的正確性和可行性。
Abstract:
Key words :

摘  要: 基于開源思想與SOPC技術,采用32位開源軟核處理器OR1200和開源軟核DDS,在FPGA上實現了頻率、相位可預置并且可調的3路正弦波信號發生器專用芯片的設計。該專用芯片基于OR1200固化專用程序實現,通過UART傳輸控制數據,可同時控制3路正弦波的產生,其頻率范圍為1 Hz~100 MHz,步進頻率為1 Hz,相位范圍為0°~359°。設計方案在DE2-70開發板上進行了實際驗證,證明了設計的正確性和可行性。
關鍵詞: 開源;軟核;OR1200DDS;專用芯片

    目前,正弦波信號發生器技術正逐漸成熟,各種直接數字頻率合成器(DDS)集成電路如AD9850等已得到廣泛應用;FPGA方面也已經有相關的DDS設計。但DDS專用芯片還很少見。本文介紹了一種工作頻率為25 MHz、可進行異步串行通信、頻率相位可調的3路正弦波信號發生器專用芯片的設計方法。
    本設計采用OR1200處理器作為主控制器,通過Wishbone總線將3個DDS模塊、UART控制器模塊、片內RAM模塊連接到系統中,構建出一個硬件平臺;然后對OR1200進行軟件編程,使UART控制器接收專用芯片外部異步串口傳送的數據,將這些數據進行處理后傳送到DDS模塊相應寄存器,從而產生特定頻率相位的正弦波信號;最后將程序固化到片內RAM中,在FPGA上實現多路正弦波信號發生器專用芯片的設計。
1 理論分析
    直接數字頻率合成技術是20世紀60年代末出現的第三代頻率合成技術。該技術從相位概念出發,以Nyquist時域采樣定理為基礎,在時域中進行頻率合成。DDS頻率轉換速度快、頻率分辨率高,并在頻率轉換時可保持相位的連續,因而易于實現多種調制功能。DDS是全數字化技術,其幅度、相位、頻率均可實現程控,并可通過更換波形數據靈活實現任意波形。本設計實現頻率相位可控的正弦波輸出。所用DDS IP軟核原理框圖如圖1所示(未給出時鐘和復位信號)。


    圖1中,ftw_i為頻率控制字,phase_i為相位控制字,ampl_o為正弦波信號幅度輸出,phase_o為正弦波信號相位輸出。本設計中頻率控制字的位寬為32位,選用的ROM波形數據為10×10結構,因此相位控制字的位寬為10位,正弦波幅度輸出位寬也為10位。
    圖1中第1個加法器和第1個單位延時電路構成相位累加器。它在時鐘的控制下以步長ftw_i做累加,輸出的N位二進制碼與M位相位控制字phase_i相加作為波形ROM的地址。由于在ROM中存取的是1/4周期的正弦波形數據,因此,根據正弦波不同的象限,由相位控制字的2個最高有效位(MSB)來控制是否對波形ROM地址進行移位或者對幅度輸出進行反相,最終輸出10位的正弦波數字信號。

    頻率相位值從UART串口輸入,OR1200處理器根據式(1)和式(2)對數據進行處理得出頻率相位控制字,賦給相應DDS模塊的頻率相位寄存器,從而輸出特定頻率相位的正弦波信號[1]。
2 專用芯片硬件設計
2.1 專用芯片總體結構設計

    正弦波信號發生器專用芯片的結構框圖如圖2所示。Wishbone總線是整個硬件平臺的系統總線,OR1200處理器的數據BIU(Bus Interface Unit)和指令BIU作為Wishbone總線的主設備,UART控制器、3個DDS模塊以及FPGA片上RAM作為Wishbone總線的從設備,它們通過Wishbone總線連接到系統中。OR1200是整個硬件平臺的主控制器,控制該專用芯片配置數據的讀入與轉換。UART控制器模塊主要實現該專用芯片與外部異步串口的通信,負責讀入配置數據。3個DDS模塊是產生正弦波信號的核心模塊,根據頻率控制字和相位控制字產生特定頻率相位的正弦波信號。FPGA片上RAM作為該專用芯片的片內RAM,系統軟件要固化在RAM中。OR1200處理器、Wishbone總線、UART控制器模塊及片內RAM模塊的時鐘直接連到外部時鐘源上,3個DDS模塊的時鐘由外部時鐘源通過PLL倍頻得到。本專用芯片為低電平復位。

2.2 OR1200處理器
    OpenRISC1200處理器(簡稱OR1200)是Opencores組織發布維護的基于GPL并屬于OpenRISC1000序列的一款RISC處理器。OR1200是32位RISC,它具有哈佛結構、5級整數流水線,支持虛擬內存(MMU),帶有基本的DSP功能,并且外部數據和地址總線接口符合Wishbone標準[2]。
    OR1200通用框架由CPU/DSP核心、直接映射的數據Cache、直接映射的指令Cache、基于DTLB的Hash表的數據MMU和指令MMU、電源管理單元及接口、Tick定時器,調試單元及開發接口、中斷控制器和中斷接口、指令及數據Wishbone主機接口[3]組成。
2.3 片內RAM設計
    片內RAM由Altera公司的EDA工具QuartusII中MegaWizard Plug-In Manager…生成。它為單端口RAM,數據總線32位,大小為8 KB。編寫的固化軟件程序編譯鏈接后轉換為hex格式,在RAM初始化時固化到其中。由QuartusII生成的片內RAM模塊不具有Wishbone接口,本設計為其添加了1個Wishbone總線接口。
2.4 DDS模塊
    DDS模塊也是Opencores上的開源IP軟核,沒有標準的Wishbone接口模塊,本設計為DDS模塊添加了1個Wishbone總線接口。該DDS模塊主要有兩類配置數據:頻率控制字和相位控制字。給DDS模塊加入2個硬件寄存器DDS_FTW和DDS_PHASE,利用這2個寄存器來控制連接到Wishbone總線接口上的輸出數據是頻率控制字還是相位控制字。
2.5 UART控制器模塊
    UART控制器模塊是Opencores上符合工業標準16550A的開源IP核。該IP核的設計采用Wishbone總線接口規范,支持可選擇的32位數據模式和8位數據模式;使用FIFO操作實現,寄存器及所實現的具體功能符合NS16550A標準[4]。在本設計中,UART控制器的波特率默認值為9 600 b/s,UART控制器模塊用于與專用芯片外部UART串口通信,通過URXD引腳接收外部串口數據,通過UTXD向外部串口發送數據。
2.6 Wishbone總線主從設備分配
    Wishbone總線仲裁采用Opencores上開源軟核wb_conmax,為8×16結構,即在該Wishbone總線模塊中可以使用8個主設備和16個從設備[5]。本系統中,OR1200的指令和數據單元為Wishbone總線的主設備;片內RAM模塊、URAT控制器模塊以及3個DDS模塊為Wishbone總線的從設備。
    根據各子模塊在Wishbone總線上的位置和wb_conmax的邏輯實現,相應從設備的地址分配如下:
    片內RAM   :  0x00000000
    DDS1        :  0x10000000
    DDS2        :  0x20000000
    DDS3        :  0x30000000
    UART        :  0x90000000
2.7 頂層模塊設計
    本系統頂層模塊例化各子模塊,采用Wishbone總線接口技術將各個子模塊集成在一起,為每個子模塊分配時鐘和復位信號,實現硬件平臺的總體設計。設計中所用FPGA開發板的時鐘為50 MHz,OR1200處理器時鐘為25 MHz,Wishbone總線時鐘為25 MHz,3個DDS模塊時鐘為100 MHz。其他模塊的時鐘都為25 MHz,設計中所用時鐘都是通過FPGA芯片中的PLL分頻及倍頻實現的。正弦波專用芯片的時鐘設為各模塊時鐘的最小值(25 MHz),3個DDS模塊的100 MHz時鐘通過PLL倍頻實現。各模塊的復位信號由頂層模塊統一分配。
3 專用芯片固化程序設計
    正弦波信號發生器專用芯片的固化程序主要包括UART控制器初始化程序和串口數據處理程序兩部分:UART控制器初始化程序初始化UART控制器中的各個寄存器,使該控制器能夠正常工作。串口數據處理程序采用查詢方式接收串口數據,將接收到的數據賦給相應寄存器變量,根據式(1)和式(2)進行計算,得到3路DDS模塊的頻率控制字和相位控制字,其固化程序流程圖如圖3所示。固化程序首先初始化OR1200處理器的各個寄存器,然后對UART控制器進行初始化,最后循環處理串口數據。

3.1 UART控制器初始化程序
    UART控制器中的寄存器都是8位或16位,通過對UART控制器的寄存器賦值來初始化UART控制器。上電復位后UART控制器的初始化工作包括:
    (1)清空接收和發送FIFO。
    (2)清零接收和發送移位寄存器。
    (3)關閉中斷。
    (4)設置Line控制寄存器為8個數據位、1個停止位、無奇偶校驗的通信模式。
    (5)讀取Line控制寄存器的值,將其最高位置1,允許Divisor鎖存器存取;通過設置Divisor鎖存器的值設置波特率為9 600 b/s;將LCR賦回原值。
3.2 串口數據處理程序
    正弦波信號發生器專用芯片從外部串口接收到的數據分為3類:相位、頻率選擇信號,相位或頻率值,3路正弦波選擇信號。固化程序定義了1個32位的數據寄存器變量和1個8位狀態寄存器變量。串口數據處理程序采用查詢方式接收串口數據,接收到的前4個數據進行相應轉換后賦給數據寄存器變量,第5個數據放入狀態寄存器變量中,作為相位信號、頻率選擇信號和3路正弦波選擇信號。若為相位信號,則將數據寄存器變量中的數據與0x3ff相“與”,然后根據式(2)得到相位控制字;若為頻率信號,則根據式(1)得到頻率控制字。最后根據這個信號將數據寄存器變量中的值送入相應的DDS模塊硬件寄存器中(DDS_FTW和DDS_PHASE)。
    在FPGA上實現了一個多路正弦波信號發生器專用芯片的設計。本設計在友晶公司的DE2-70開發板上進行了驗證,使用開發板上3路10位視頻數字信號轉模擬信號的控制芯片ADV7123作為D/A轉換芯片,最后得到3路頻率相位可調的正弦波信號。該正弦波信號發生器專用芯片通過串口控制,而未來的設計中可以擴展數字按鍵控制或者觸摸屏控制,不使用外部主控MCU也可以產生特定頻率相位的正弦波信號。
參考文獻
[1] KUMM M. Direct digital synthesizer IP core. pdf[EB/OL]. (2008-12-22).[2009-10-02].http://www.opencores.org/projects.
[2] 徐敏,孫愷,潘峰.開源軟核處理器OpenRisc的SOPC設計[M].北京:北京航空航天大學出版社,2008:4-5.
[3] 倪繼利,陳曦,李揮.CPU源代碼分析與芯片設計及Linux移植[M].北京:電子工業出版社,2007:64-65.
[4] GORBAN J. UART IP core specification. pdf[EB/OL]. (2002-8-11)[2009-10-02].http://www.opencores.org/projects.
[5] OpenCoresOrganization.Wishbone system-on-chip(SoC) interconnection architecture for portable IP cores. pdf[EB/OL]. (2002-09-07)[2009-10-02].http://www.opencores.org/projects.
 

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产日韩精品久久| 亚洲激情偷拍| 欧美国产先锋| 久久久久看片| 午夜视频久久久久久| 在线视频中文亚洲| 亚洲精品久久久久久久久久久久 | 激情综合久久| 国产一区二区剧情av在线| 国产精品免费网站| 国产精品久久激情| 国产精品高潮呻吟久久av黑人| 欧美日韩久久不卡| 欧美日韩免费区域视频在线观看| 免费日韩av片| 欧美成人精品在线播放| 免费一级欧美片在线播放| 久久亚洲综合网| 久久综合伊人77777麻豆| 久久久人人人| 久久久久欧美精品| 久久五月婷婷丁香社区| 久久精品国产综合| 久久精品理论片| 久久久久久久久久久成人| 久久精选视频| 老色批av在线精品| 欧美gay视频激情| 欧美激情一区二区三区高清视频| 欧美国产精品日韩| 欧美日韩高清在线| 国产精品v日韩精品| 国产精品久久久久av| 男女av一区三区二区色多| 欧美寡妇偷汉性猛交| 欧美精品网站| 国产精品高潮呻吟久久av无限 | 国产日韩精品电影| 狠狠色狠狠色综合日日小说 | 黄色一区二区三区| 亚洲国产精品成人精品| 亚洲精选91| 亚洲视频一区在线| 亚洲欧美一区二区三区久久 | 久久aⅴ乱码一区二区三区| 久久久久国产精品午夜一区| 美女诱惑黄网站一区| 欧美国产日韩在线观看| 欧美午夜一区二区| 国产一区久久| 91久久久久久久久| 一区电影在线观看| 欧美一区二区三区在线播放| 亚洲国产精品成人精品| 99国产欧美久久久精品| 亚洲尤物影院| 久久蜜桃精品| 欧美日韩二区三区| 国产欧美日韩免费| 亚洲国产成人在线| 亚洲午夜伦理| 亚洲第一视频网站| 亚洲一区二区成人| 久久乐国产精品| 欧美欧美全黄| 国产色综合天天综合网| 在线不卡亚洲| 亚洲天堂激情| 亚洲高清免费视频| 亚洲已满18点击进入久久| 久久久精品一品道一区| 欧美日韩二区三区| 国内成人在线| 一本高清dvd不卡在线观看| 久久www免费人成看片高清| 日韩一级裸体免费视频| 欧美亚洲在线| 欧美精品一区二区久久婷婷| 国产精品午夜av在线| 亚洲国产一成人久久精品| 亚洲永久精品大片| 亚洲精品视频在线观看网站| 亚洲欧美日韩视频一区| 欧美成人影音| 国产亚洲精品久久久久婷婷瑜伽 | 亚洲精品在线观| 欧美在线亚洲| 亚洲欧美国产精品va在线观看 | 欧美高清成人| 国产一区香蕉久久| 99精品热视频| 亚洲国产综合91精品麻豆| 性视频1819p久久| 欧美日韩99| 国内一区二区三区| 亚洲香蕉网站| 日韩午夜在线播放| 另类图片综合电影| 国产精品网站一区| av成人激情| 日韩网站免费观看| 久久午夜国产精品| 国产伦精品一区二区三区照片91 | 国产一区二区三区四区三区四| 日韩视频一区二区三区| 亚洲黄色在线| 久久国产精品久久久久久久久久 | 一区二区视频免费完整版观看| 亚洲无玛一区| 一本色道久久加勒比精品| 欧美sm重口味系列视频在线观看| 国产日韩在线一区| 亚洲一区二区3| 亚洲一区在线看| 欧美精品v日韩精品v国产精品 | 91久久久久久久久| 亚洲日本一区二区| 欧美成人精品福利| 亚洲成色999久久网站| 亚洲国产日韩一区二区| 美女脱光内衣内裤视频久久影院| 激情丁香综合| 亚洲高清色综合| 蜜桃精品久久久久久久免费影院| 精品二区视频| 亚洲人成在线影院| 欧美劲爆第一页| 亚洲毛片在线免费观看| 宅男噜噜噜66一区二区66| 欧美日韩一区二区三| 一区二区三区四区蜜桃| 午夜精品久久久久久99热| 国产精品亚洲综合色区韩国| 亚洲欧美国产毛片在线| 欧美在线视频观看| 国产一区二区在线免费观看| 亚洲大胆美女视频| 欧美福利视频网站| 日韩小视频在线观看| 亚洲免费视频一区二区| 欧美精品久久久久久久久久| 在线看片日韩| 99精品国产福利在线观看免费 | 久久免费午夜影院| 伊人婷婷久久| 久久高清国产| 麻豆91精品91久久久的内涵| 亚洲国产另类久久精品| 亚洲裸体视频| 欧美日本不卡| 日韩一级裸体免费视频| 午夜免费电影一区在线观看| 国产精品乱子乱xxxx| 亚洲在线国产日韩欧美| 亚洲欧美国产日韩天堂区| 国产精品毛片a∨一区二区三区|国| 亚洲天堂偷拍| 99re热精品| 欧美日韩一区二区三区四区在线观看| 亚洲精品一区在线观看| 亚洲视频一二三| 国产精品美女一区二区在线观看| 一区二区高清在线| 久久久国产精品一区| 黄色一区三区| 亚洲美女诱惑| 欧美性大战久久久久久久蜜臀| 欧美亚洲综合久久| 久久久人成影片一区二区三区观看| 黑人巨大精品欧美一区二区小视频 | 亚洲午夜女主播在线直播| 国产精品视频最多的网站| 亚洲一区二区三区精品在线| 久久国产日本精品| 黄色欧美成人| 亚洲区在线播放| 国产精品久久久久久久久久妞妞| 亚洲在线一区二区| 久久久夜色精品亚洲| 亚洲国产成人高清精品| 欧美在线观看一二区| 好看的日韩视频| 日韩网站免费观看| 国产精品v欧美精品v日韩精品| 久久精品欧美日韩| 欧美理论电影网| 亚洲一区二区三区视频| 两个人的视频www国产精品| 国产精品99久久久久久久久久久久 | 欧美激情日韩| 亚洲一区二区三区精品动漫| 欧美亚洲视频在线观看| 亚洲韩国精品一区| 亚洲自拍高清| 好看的日韩视频| 国产精品99久久久久久久久| 在线不卡中文字幕| 亚洲欧美一区在线| 亚洲福利国产| 午夜免费久久久久|