chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

CY68013A進行數(shù)據(jù)傳遞FPGA進行格式轉(zhuǎn)換的數(shù)據(jù)采集與仿真系統(tǒng)

電子設(shè)計 ? 2018-08-30 10:44 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

隨著軟件無線電思想與技術(shù)的發(fā)展,現(xiàn)代數(shù)字通信系統(tǒng)中,越來越多地使用DSP數(shù)字信號處理器結(jié)合高速AD、DA轉(zhuǎn)換器進行OSI 7層通信體系模型中物理層(信號的調(diào)制、解調(diào))和數(shù)據(jù)鏈路層(信道編、解碼)部分的數(shù)據(jù)處理工作。近年來,數(shù)字信號處理理論發(fā)展迅猛,數(shù)字信號處理器工作頻率及能力不斷提高,數(shù)字通信系統(tǒng)中越來越多的工作能夠通過DSP來完成,因而DSP本身的程序結(jié)構(gòu)也越來越復雜。由于通信信號(尤其是無線通信)本身具有很強的實時性、隨機性的特點,造成DSP的輸入數(shù)據(jù)缺乏規(guī)律性,一閃即逝,從而導致相應(yīng)的處理程序出現(xiàn)了問題不易復現(xiàn),且問題難于追蹤、捕捉,這就給DSP的程序設(shè)計與調(diào)試帶來了較大困難。針對這一問題,本文根據(jù)一般底層通信協(xié)議棧的數(shù)據(jù)處理方法,設(shè)計了一套適合于對底層協(xié)議棧進行開發(fā)和調(diào)試的數(shù)據(jù)采集與仿真系統(tǒng),以達到追蹤、再現(xiàn)問題并查找程序缺陷的目的。

1 數(shù)據(jù)采集系統(tǒng)

數(shù)據(jù)采集系統(tǒng)主要完成從正在工作中的通信終端中采集數(shù)據(jù)的任務(wù)。

1.1 采集點的選擇

整個通信系統(tǒng)中有多個數(shù)據(jù)采集切入點可選,可以對中頻信號直接采樣,也可以對基帶信號采樣,還可以通過模擬系統(tǒng)中的AD數(shù)據(jù)接收時序,直接接收AD輸出數(shù)據(jù)。但前兩種采集點不能確保采集到的信號數(shù)據(jù)與DSP輸入數(shù)據(jù)完全一致,而模擬AD數(shù)據(jù)時序的方式則可能影響DSP與AD之間的主從關(guān)系,影響DSP協(xié)議棧的正常運行,而且各種外部中斷的采集也比較困難。因而最為穩(wěn)妥的方式是DSP通過數(shù)據(jù)總線輸出其接收到的數(shù)據(jù)。這種方法的缺點是需要占用DSP少量資源,但這與協(xié)議棧運行相比,完全可以忽略不計,不計不會影響協(xié)議棧本身的運行。

1.2 硬件連接

參考文獻[1]對各種數(shù)據(jù)采集系統(tǒng)進行了分析比較,并指出USB總線為數(shù)據(jù)采集卡與PC機較理想的接口,因此選用CY68013A作為USB接口芯片。采用1片FPGA進行DSP與CY68013A之間數(shù)據(jù)格式的轉(zhuǎn)換,CY68013A固件程序存放在E2PROM中,通過I2C總線連接,連接方式如圖1所示。

其中,DSP除了輸出16位數(shù)據(jù)總線之外,還引出7位地址線(A0~A6),用以區(qū)分不同的數(shù)據(jù)類型。FPGA須將DSP外部總線輸出的數(shù)據(jù)格式轉(zhuǎn)換為CY68013A外部GPIF可兼容的格式。

1.3 FPGA程序設(shè)計

CY68013A外部GPIF端口可作為數(shù)據(jù)輸入端口的僅有16位(FD0~FD15),而DSP輸出的信息數(shù)據(jù)一共有23位(16位數(shù)據(jù)線D0~D15和7位地址線A0~A6),故而需要將多出的7位地址信息嵌入到數(shù)據(jù)中去。將1個16位數(shù)據(jù)拆分成2個,每個數(shù)據(jù)中的低8位(FD0~FD7)用于存儲原數(shù)據(jù)信息(D0~D7或D8~D15),高7位(FD8~FD14)存放地址類型信息(A0~A6),最高位(FD15)用于標識當前數(shù)據(jù)中FD0~FD7是原數(shù)據(jù)的D0~D7或是D8~D15,具體格式如圖2(b)所示。CY68013A GPIF端口使用內(nèi)部48 MHz時鐘,根據(jù)參考文獻[2],每個GPIF信號周期為20.83 ns,二者時鐘不同步,F(xiàn)PGA為了與高速設(shè)備兼容,需要使用更高的時鐘源。因此,為了保證GPIF能夠采集到RDY信號,F(xiàn)PGA輸出的信號至少需要保持1.5個GPIF信號周期。GPIF每次從外部讀取數(shù)據(jù)存入FIFO需要6個狀態(tài),故而每個輸出數(shù)據(jù)間隔應(yīng)大于6個GPIF信號周期。以TI公司C55系列DSP為例,主頻時鐘144 MHz,與FPGA連接的為EMIFS外部總線,則FPGA轉(zhuǎn)換信號時序如圖2所示。其中,圖2(a)為DSP EMIFS輸出時序, 圖2(b)為經(jīng)FPGA轉(zhuǎn)換后的CY68013A GPIF輸入時序及數(shù)據(jù)格式。

考慮到DSP輸出數(shù)據(jù)時鐘可能較CY68013A GPIF采集時鐘快,因而FPGA需要設(shè)計內(nèi)置的FIFO存儲器,用于緩存DSP輸出的數(shù)據(jù)。

1.4 USB固件設(shè)計

由于CY68013A內(nèi)置的8051內(nèi)核時鐘周期較慢,不適于高速傳輸,因而采集程序中僅使用8051進行初始化配置,而不干預(yù)數(shù)據(jù)傳輸過程。CY68013A通過外部GPIF讀取數(shù)據(jù)存入FIFO中,F(xiàn)IFO滿時通過USB傳入PC機。采用Cypress公司提供的通用程序框架以及圖形化GPIF設(shè)計工具,參照圖2(b)的時序,編輯GPIF波形。USB總線選擇傳輸大量數(shù)據(jù)時比較常用的Bulk傳輸模式,硬件配置程序采用Cypress公司提供的程序模板,參考文獻[3]對該模板進行了詳細說明,這里不再贅述,程序框架與參考文獻[4、5]類似。

1.5 PC機接收程序

USB接口驅(qū)動程序可直接使用Cypress公司提供的ez-usb驅(qū)動。由于ez-usb驅(qū)動沒有提供高級的文件操作IO方式,因而需要調(diào)用比較底層的DeviceIoControl函數(shù)來處理。考慮到Bulk傳輸方式完全是由主機端(PC機)發(fā)起讀操作,從機端(采集板)只能被動地等待,而當CY68013A內(nèi)置的FIFO寫滿之后,如果主機不能及時地發(fā)起讀操作,則FIFO不再接收數(shù)據(jù)寫入操作,因而會有少量的數(shù)據(jù)丟失。對于底層協(xié)議棧調(diào)試,這種少量的數(shù)據(jù)丟失可能引起程序流程錯誤,是不能接受的。因此PC機端接收程序應(yīng)采用多線程處理方式,將接收USB數(shù)據(jù)的工作列為單獨的線程,并將其優(yōu)先級設(shè)置為實時性最高的THREAD_PRIORITY_TIME_CRITICAL,防止接收數(shù)據(jù)過程被系統(tǒng)中其他進程打斷,以確保每次讀操作能夠及時發(fā)出。同時也要保證負責數(shù)據(jù)采集的PC機操作系統(tǒng)中同時運行的進程盡量少,關(guān)掉不必要的后臺進程。

PC機接收到的數(shù)據(jù)先存入臨時文件中,以備后續(xù)解析、仿真程序使用。臨時文件以字(16 bit)為單位存儲,每個數(shù)據(jù)用2個字來表示,低字節(jié)在前,與FPGA轉(zhuǎn)換后的數(shù)據(jù)格式一致,如表1所示。

2 仿真系統(tǒng)

仿真系統(tǒng)使用采集系統(tǒng)采集到的數(shù)據(jù),再現(xiàn)通信終端中的協(xié)議棧運行狀態(tài),便于開發(fā)者隨時檢查程序錯誤,對程序進行調(diào)試。

2.1 系統(tǒng)框架

要想再現(xiàn)底層協(xié)議棧運行狀態(tài),除了保證協(xié)議棧整體輸入、輸出一致外,最大的難度在于系統(tǒng)的定時,要能夠準確再現(xiàn)各種事件的發(fā)生時刻?;谲浖o線電技術(shù)的數(shù)字通信系統(tǒng)大都采用過采樣方式,AD/DA速率都比較高而且穩(wěn)定,因而底層協(xié)議棧也大多以AD/DA的輸入、輸出中斷作為系統(tǒng)定時。當通信終端作為接收機時,底層協(xié)議棧需要以AD采樣數(shù)據(jù)作為其他部分(信道估計與均衡、解調(diào)、信道解碼等)的驅(qū)動數(shù)據(jù);作為發(fā)射機時,DA輸出數(shù)據(jù)是底層協(xié)議棧的最終輸出結(jié)果,需要仿真程序進行驗證。故而仿真程序可以采用AD/DA中斷來劃分程序運行的最小時間片,其他各種事件的發(fā)生都通過中斷個數(shù)來計時,仿真程序通過判斷AD/DA數(shù)據(jù)的個數(shù)調(diào)用各程序函數(shù)來再現(xiàn)底層協(xié)議棧運行狀況及數(shù)據(jù)流向。這樣就可以在不增加開銷的情況下,盡最大可能保證仿真程序與實際DSP中運行的協(xié)議棧一致,方便再現(xiàn)問題。

2.2 輸出數(shù)據(jù)

根據(jù)1.1節(jié)所選擇的數(shù)據(jù)采集點,需在DSP的底層協(xié)議棧代碼中輸出仿真時所用的數(shù)據(jù): (1)需要輸出的為前端AD/DA數(shù)據(jù),以及底層協(xié)議棧與上層協(xié)議棧之間的交互數(shù)據(jù),這是底層通信協(xié)議棧接收、發(fā)射信息時所需的輸入數(shù)據(jù)與最終的輸出結(jié)果; (2)其他外圍設(shè)備產(chǎn)生的中斷和輸入數(shù)據(jù)也會影響底層協(xié)議棧流程,是仿真時所必須的部分;(3)底層協(xié)議棧各任務(wù)掛起、運行、結(jié)束等狀態(tài)變化需要輸出,以保證仿真程序運行時刻與實際情況一致。另外,在2次AD/DA中斷之間會發(fā)生多次變化的全局變量也需要輸出,以彌補時間片劃分的不足。

2.3 數(shù)據(jù)解析

1.5節(jié)中所存儲的接收數(shù)據(jù)不方便直接用于仿真,需要進行格式轉(zhuǎn)換。根據(jù)2.1節(jié)中所述系統(tǒng)框架,所有事件通過AD/DA數(shù)據(jù)計時,故而除AD/DA數(shù)據(jù)外,其他類型數(shù)據(jù)需要記錄AD/DA數(shù)據(jù)個數(shù)信息,作為時間戳,因而可將所有數(shù)據(jù)分為兩大類:AD/DA數(shù)據(jù)和非AD/DA數(shù)據(jù)。為仿真方便,將這2種類型數(shù)據(jù)分別存放于2個文件中。在解析數(shù)據(jù)時,需要將1.3小節(jié)中為了與CY68013A兼容而通過FPGA拆分開的2個16位數(shù)據(jù)重新合并為1個,并將不同類型的數(shù)據(jù)分開。AD/DA數(shù)據(jù)一般長度固定,由AD/DA轉(zhuǎn)換器分辨率(位數(shù))而定,例如,AD/DA數(shù)據(jù)為16位,每次中斷輸出1個數(shù)據(jù),則解析后的數(shù)據(jù)格式如表2所示。


非AD/DA數(shù)據(jù)根據(jù)程序需求,長度不固定,可在協(xié)議棧程序輸出數(shù)據(jù)中包含長度信息,也可在接收程序與輸出程序中提前規(guī)定好數(shù)據(jù)長度。例如,非AD/DA數(shù)據(jù)以字為單位,數(shù)據(jù)長度為N,則解析后的數(shù)據(jù)格式如表3所示。

由于底層協(xié)議棧需要兼顧外圍硬件控制,各種外部中斷比較多,很可能會打斷數(shù)據(jù)輸出,因而在解析數(shù)據(jù)時,需要考慮各種數(shù)據(jù)之間的嵌套。為此,可以對每種數(shù)據(jù)采用單獨的緩沖區(qū),待解析到1條完整數(shù)據(jù)之后再存入文件中,同時還要保證文件中各種非AD/DA數(shù)據(jù)按照發(fā)生時間的先后順序排列。其流程如圖3所示。

2.4 系統(tǒng)仿真

系統(tǒng)仿真之前,首先要將運行于DSP中的底層協(xié)議棧代碼轉(zhuǎn)換為PC機上可運行的代碼,一般DSP大多采用C語言匯編語言相結(jié)合的方式進行開發(fā),C代碼基本上不需要進行大量修改,而匯編代碼需要根據(jù)其工作原理,轉(zhuǎn)譯成C代碼。系統(tǒng)仿真時采用2.3節(jié)中解析后的數(shù)據(jù)文件作為輸入,按照2.1節(jié)定義的仿真系統(tǒng)框架,以AD/DA數(shù)據(jù)為驅(qū)動,通過判斷非AD/DA數(shù)據(jù)的發(fā)生時刻(AD/DA數(shù)據(jù)計數(shù)值)來調(diào)動底層協(xié)議棧各部分任務(wù)運行,以達到再現(xiàn)協(xié)議棧運行狀況、調(diào)試程序的目的。仿真流程如圖4所示。有些硬件操作需要底層協(xié)議??刂疲抡鏁r可以按照“[發(fā)生時間] 硬件操作內(nèi)容”的格式寫到文件中作為仿真程序的輸出。這樣通過查詢輸出文件,各種硬件操作的先后關(guān)系一目了然,更形象化,有利于發(fā)現(xiàn)硬件控制上的邏輯錯誤。

本文設(shè)計了一種專門用于底層協(xié)議棧開發(fā)的數(shù)據(jù)采集與仿真系統(tǒng),利用USB高速傳輸特點以及物理連接的便利性,采用CY68013A進行數(shù)據(jù)傳遞,充分利用其GPIF資源,使用FPGA進行格式轉(zhuǎn)換。文中對仿真系統(tǒng)的整體框架和數(shù)據(jù)轉(zhuǎn)換細節(jié)進行了詳細說明。該系統(tǒng)可用于各種類型協(xié)議棧調(diào)試,便于追蹤、再現(xiàn)問題。經(jīng)過實驗驗證,系統(tǒng)可承受100 Mb/s的實時數(shù)據(jù)流,在數(shù)字集群手持終端開發(fā)中進行了廣泛應(yīng)用,不僅降低了協(xié)議棧的開發(fā)難度,而且縮短了開發(fā)周期,有很高的實用性。(電子技術(shù)應(yīng)用 作者:黃建堯 劉開華 李 琨 )

參考文獻:

[1].Bulkdatasheethttp://www.dzsc.com/datasheet/Bulk_2523104.html.
[2].ez-usbdatasheethttp://www.dzsc.com/datasheet/ez-usb_305660.html.

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • dsp
    dsp
    +關(guān)注

    關(guān)注

    560

    文章

    8239

    瀏覽量

    366297
  • FPGA
    +關(guān)注

    關(guān)注

    1660

    文章

    22395

    瀏覽量

    635615
  • 數(shù)據(jù)采集
    +關(guān)注

    關(guān)注

    41

    文章

    8012

    瀏覽量

    120791
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    基于USB數(shù)據(jù)采集系統(tǒng)的研究與設(shè)計--ResearchandDesignofDataAequisitio

    顯示、數(shù)據(jù)保存以及數(shù)據(jù)打印等功能。系統(tǒng)硬件部分實現(xiàn)數(shù)據(jù)采集功能,并將采集數(shù)據(jù)送至USB控制器,
    發(fā)表于 06-10 00:57

    基于QuickUSB的數(shù)據(jù)采集系統(tǒng)設(shè)計

    數(shù)字輸出對于模擬輸入存在6個時鐘的延時。同時,為了減小系統(tǒng)的功耗,在不需要進行ADC轉(zhuǎn)換的時候,可以通過FPGA將ADS803E的時鐘停止。圖2ADC
    發(fā)表于 06-11 05:00

    CY68013A Win8故障該怎么辦?

    嗨~CY68013A連接到Wi7/XP是可以的。當CY68013A連接到Win8時,Win8上的設(shè)備管理器不會顯示任何內(nèi)容。但它出現(xiàn)了未知的設(shè)備WHEC668013A & Gt;USB集線器-Gt;PC.。請讓我知道如何解決這個
    發(fā)表于 09-03 07:14

    FPGA實現(xiàn)數(shù)據(jù)采集的方式對比(傳統(tǒng)串口、數(shù)據(jù)采集卡及外設(shè)計接口)

    來完成對數(shù)據(jù)采集與傳輸。1 數(shù)據(jù)采集和傳輸系統(tǒng)方案設(shè)計數(shù)據(jù)采集和傳輸系統(tǒng)主要由3部分組成,US
    發(fā)表于 01-07 07:00

    怎么將cy68013a與spartan3e連接起來?

    我正在嘗試將EZ-USB CY68013a 56針與xilinx spartan 3e(xc3s500e-pq208)連接。我正在加載verilog代碼的位文件,該代碼將串行數(shù)據(jù)轉(zhuǎn)換為JTAG
    發(fā)表于 04-02 06:36

    CY68013A USB芯片如何下載程序和使用?

    CY68013A這款USB芯片如何下載程序和使用?
    發(fā)表于 10-17 08:37

    基于CY7C68013的USB數(shù)據(jù)采集系統(tǒng)

    本文介紹了高速USB2.0芯片CY7C68013的特點。設(shè)計出一種主要由CY7C68013與Altera公司EP1C6芯片構(gòu)成的USB2. 0數(shù)據(jù)采集系統(tǒng).首先介紹了
    發(fā)表于 09-14 14:33 ?133次下載

    如何更好地進行數(shù)據(jù)采集

    如何更好地進行數(shù)據(jù)采集 工程師經(jīng)常需要進行數(shù)據(jù)采集來驗證產(chǎn)品的性能和指標,或者對一些特定的應(yīng)用進行監(jiān)測和控制,以便確定其物理參數(shù),例如溫度、應(yīng)力、壓
    發(fā)表于 01-04 10:32 ?1775次閱讀
    如何更好地<b class='flag-5'>進行數(shù)據(jù)采集</b>

    基于CY7C68013A的并口轉(zhuǎn)USB口數(shù)據(jù)采集系統(tǒng)設(shè)計

    設(shè)計了一個以 CY7C68013A 為接口芯片的并口轉(zhuǎn)USB口的數(shù)據(jù)采集系統(tǒng),討論了CY7C68013A的性能及傳輸方式,給出了該系統(tǒng)的硬件
    發(fā)表于 08-29 14:26 ?0次下載
    基于<b class='flag-5'>CY7C68013A</b>的并口轉(zhuǎn)USB口<b class='flag-5'>數(shù)據(jù)采集</b><b class='flag-5'>系統(tǒng)</b>設(shè)計

    基于CY7C68013AFPGA配置和通信接口設(shè)計

    為了同時實現(xiàn)計算機對FPGA進行在線配置和高速數(shù)據(jù)傳輸,提出了一種基于CY7C68013A芯片的USB2.0接口設(shè)計方案。介紹了以CY7C68013
    發(fā)表于 09-23 17:57 ?175次下載

    USB2.0微控制器CY7C68013數(shù)據(jù)采集系統(tǒng)的設(shè)計

    USB2.0微控制器CY7C68013數(shù)據(jù)采集系統(tǒng)的設(shè)計
    發(fā)表于 01-22 14:10 ?30次下載

    基于CY7C68013AFPGA的4路數(shù)據(jù)采集系統(tǒng)設(shè)計_智丹

    基于CY7C68013AFPGA的4路數(shù)據(jù)采集系統(tǒng)設(shè)計_智丹
    發(fā)表于 01-13 21:40 ?26次下載

    設(shè)備數(shù)據(jù)采集網(wǎng)關(guān)如何連接設(shè)備進行數(shù)據(jù)采集工作

    工作。 一、設(shè)備數(shù)據(jù)采集網(wǎng)關(guān)的基本功能 設(shè)備數(shù)據(jù)采集網(wǎng)關(guān)是一種智能硬件設(shè)備,它通過串口、網(wǎng)口或無線方式與現(xiàn)場設(shè)備進行連接,并采集設(shè)備的運行數(shù)據(jù)
    的頭像 發(fā)表于 11-29 18:03 ?2606次閱讀

    隧道沒信號怎么進行數(shù)據(jù)采集

    隧道沒信號怎么進行數(shù)據(jù)采集
    的頭像 發(fā)表于 12-06 13:27 ?1925次閱讀

    使用CAN總線進行數(shù)據(jù)采集的方法

    使用CAN總線進行數(shù)據(jù)采集的方法通常涉及一系列步驟,這些步驟確保了數(shù)據(jù)的準確采集、處理和存儲。以下是一個詳細的方法指南: 一、了解CAN總線系統(tǒng) 首先,需要對CAN總線
    的頭像 發(fā)表于 12-20 18:18 ?4032次閱讀