色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

采用FPGA器件實現數據采集系統中高速大容量存儲板的設計

電子設計 ? 來源:郭婷 ? 作者:電子設計 ? 2019-08-26 08:03 ? 次閱讀

1 引言

高速數據采集系統目前已在雷達、聲納、圖像處理、語音識別通信、瞬態信號測試等領域得到廣泛應用。它的關鍵技術是高速ADC技術、數據存儲與傳輸技術和抗干擾技術。當大量的高速實時數據經過模數轉換后,必須高速存儲,多通道高采樣率的數據采集系統會產生巨大的數據流。這樣就需要高速大容量的存儲板將數據存儲起來,然后再讀回計算機進行處理。基于以上原因,本文設計了可以同時存儲兩通道采樣數據的大容量存儲板,板中采用了64片Samsung公司的高速大容量存儲器K9F2G08UOM,使整塊板卡的存儲容量達到128Gbit。采用FPGA作為控制器,通過標準的CPCI工控機箱操作存儲板,并通過CPCI總線將存儲板上的數據高速讀回計算機,提高了讀取數據的速度。

2 K9F2G08UOM簡介

NOR Flash和NAND Flash是目前市場上的兩種主要的非易失性閃存技術,本設計的目的是為了高速存儲大容量的數據,因此,選擇NAND型K9F2G08U0M存儲器。它的存儲容量是2 Gbit,8位位寬,頁大小為2 048×8 bit,每塊由64頁組成,共有2 048塊。每頁帶有64×8 bit的空閑存儲區,共有8 192 K×8 bit的空閑存儲區。頁編程的典型時間為300μs,最大頁編程時間為700μ8。頁內連續最小訪問時間為30 ns/Byte,即數據寫入Flash數據寄存器的速度可達33 MB/s。但是單頁數據的典型編程速度為2 048/300μs=6.8 MB/s,最慢的編程速度為2 048/700μs=2.9 MB/s。塊擦除的典型時間為2 ms。K9F2G08U0M具有硬件數據保護功能,即在電源上電、掉電期間關閉編程/擦除操作。K9F2G08U0M內部寫控制器使得所有的編程和擦除操作自動進行,片內包含一個頁(2 048+64字節)的數據寄存器,讀寫過程中始終是將存儲單元數據或外部數據先緩存到數據寄存器,然后再讀出數據或寫入存儲單元。因此,它是基于頁讀寫,基于塊擦除的。當然,它也支持隨機讀寫。但本設計目的是高速存儲數據,因此對它的讀寫操作完全是基于頁的。K9F2G08U0M的主要引腳有CLE(命令鎖存允許)、ALE(地址鎖存允許)、CE(片選)、WE(寫允許)、RE(讀允許)、WP(寫保護)、R/B(準備好/忙)、PRE(上電讀使能)、I/O0~I/O7(輸入,輸出)。其中I/O0~I/O7既可作為數據輸入輸出引腳,又可作為命令地址的輸入引腳,命令、地址、數據分時復用,根據不同的命令區分地址和數據。一般的操作流程為:

1) 寫入命令,通知器件所要完成的操作(讀、寫、擦除等);

2) 寫入地址,即寫入要讀寫數據的起始地址,包括列地址和頁地址;

3) 如果是讀或者擦除,寫入一個確認命令。如果是寫操作,輸人待編程的數據,完成后輸入編程確認命令。

因為K9F2G08U0M共有128 K頁,每頁的大小為(2 048+64)×8 bit,所以在寫入地址時列地址需要12根地址線,頁地址需要17根地址線。這樣就需要5個時鐘周期來寫入地址。前兩個時鐘寫入列地址,后三個時鐘寫人頁地址。

3 系統設計

3.1 總體硬件設計

外部數據采集系統是2個40 MHz采樣的16位A/D通道,所以設計時分成兩個通道獨立設計。雖然K9F2G08U0M的數據寄存器寫入速度可達33MB/s,但在FPGA設計時,為了在時序上更加可靠,選擇使用25 MHz的時鐘設計,則K9F2G08U0M的寫入速度為50 MB/s(把兩個K9F2G08U0M并成16bit,寫入速度即為25 M×l6 b/s)。這樣,在FPGA內部開辟3個頁大小的雙口RAM作為緩存區就能滿足40 M×16 b/s的寫入速度,即在寫第2、3個RAM的時間(25 ns×2 048×2=102.4μs)內,啟動第1個RAM把數據寫入Flash的數據寄存器,所需時間為40 ns×2 048=81.92μs,小于102.4μs。

在讀回數據時,如以20 MHz讀取Flash,以40MHz讀出緩沖區中的數據,3個雙口RAM就能剛好滿足要求,如圖1。讀取K9F2G08U0M一頁數據能達到33 MHz的速度,為了讓讀寫Flash使用同一時鐘,讀Flash也采用25 MHz的速度。同時為了增加系統設計的冗余,采用4頁的雙口RAM作為緩沖區。所以每片FPGA內部至少需要4×2 048×16 bit=131 072 bit的存儲空間。

采用FPGA器件實現數據采集系統中高速大容量存儲板的設計

由于數據在寫入Flash后還有較長的編程時間,一頁的編程時間典型值為300μs,最大值為700μs。數據在存儲上不能有任何的停頓,否則就會丟失數據,所以不能使用R/B信號進行設計。為了系統更加可靠,選擇最大編程時間700μs。兩次對同一組Flash進行寫操作的時間間隔為700μs+81.92μs=781.92μs,一頁的數據寫到雙口RAM要用25ns×2 048=51.2μs。總時間除以寫一頁數據的時間:781.92/51.2=15.3μs,說明一個循環內至少需要16組Flash才能滿足要求。所以在設計中,對于每路A/D采樣通道都用一片FPGA作為緩沖和控制系統,在每片FPGA內部都采用4個緩沖區,每個緩沖區對應一條外部總線,每條總線上掛有4組K9F2G08U0M×2(將兩片Flash并成16位操作,即把I/O并成16位,共用控制信號線)。系統整體框圖如圖2所示。

采用FPGA器件實現數據采集系統中高速大容量存儲板的設計

圖2中2個外部接口連接2個A/D通道,采用兩片FPGA作為控制和緩沖區,每片控制16組Flash。存儲板通過PCI9054與CPCI總線相連,通過CPCI總線可以將存儲板數據高速讀回計算機。

3.2 系統設計思想

為了解決高速的數據采集和低速的Flash訪問速度之間的矛盾,采取將數據流串并轉換,復制多個操作模塊并行處理的設計方法。通過利用FPGA內部的存儲區實現4個雙口RAM作為緩沖區。每條外部Flash總線用一個雙口RAM,采集到的數據分時加載到4個RAM中,然后再寫入Flash。寫入Flash的操作以流水方式進行,具體方式如圖3所示。首先,外部A/D采樣通道寫數據到RAM1。當RAM1寫滿時,加載數據到第一組Flash數據寄存器,加載完成后第一組Flash進入自動編程階段;當RAM2寫滿時,第2組Flash加載開始,數據加載完成后,進入自動編程階段。依次加載RAM3,當RAM4寫滿,第4組Flash開始加載后,FPGA內部控制重新寫RAM1,開始對第5組Flash操作,然后依此循環方式對第6~16組Flash進行操作;當第16組數據加載完成后,第1組Flash已經編程結束,接著從第1組Flash開始加載和編程。可看出向16組Flash寫入數據是并行的,通過并行寫操作,可存儲高速采集的數據。

采用FPGA器件實現數據采集系統中高速大容量存儲板的設計

FPGA內部設計大體可劃分為PCI9054操控部分和數據錄放部分。PCI9054操控部分一方面跟PCI9054接口,一方面要完成對Flash的操作。數據錄放部分主要完成外部數據寫入、讀出以及擦除、建立無產塊信息列表等功能。由于對4組Flash的操作都是一樣的,所以數據錄放部分可以分為數據流控制部分和Flash操控部分。數據流控制部分控制數據寫入或讀取哪組Flash;Flash操控部分用于對Flash的具體操作。圖4為數據錄放部分FPGA功能結構。為了節省內部存儲單元的數量,寫入和讀取數據要使用同樣的緩存區。

采用FPGA器件實現數據采集系統中高速大容量存儲板的設計

3.3 無效塊的建立和操作

當一個塊中有一位或更多位不能正確操作時,就定義此塊為無效塊。無效塊并不影響其他塊的正常工作,各個塊之間是相互獨立的。所選的K9F2G08U0M在出廠時可能存在無效塊,在使用中也可能產生新的無效塊,但是器件的第一個塊一定不是無效塊。NAND Flash在出廠時就標記本身的無效塊,每個塊的第一頁或第二頁的空閑區的第一個數據不是FFh,則表示此塊為無效塊。為了保證Flash的正確操作,必須在操作之前建立無效塊信息表。在每片FPGA中設計了4個2 048×1 bit的RAM用于存儲無效塊的信息。RAM的每一個存儲單元存儲相應總線上的4組Flash的無效塊信息。其中某一塊的無效塊信息是4組Flash的無效塊信息相“與”后的結果(1表示正常,0表示無效塊)。在對Flash進行讀、寫或擦除操作之前,應先從RAM中讀取無效塊信息,然后根據無效塊信息決定是否對當前塊操作。

3.4 讀寫Flash操作

對Flash的讀寫操作都是基于頁的,讀寫操作的時序分別如圖5和圖6所示。計算機通過CPCI總線發送出讀或寫命令后,FPGA內部根據接收到的命令執行相應操作。寫Flash時,外部采集的數據輸入RAM1,RAM1滿后,開始向RAM2寫入數據,同時選通第一條總線上第一組Flash的寫模塊,在寫模塊中通過計數器產生ALE、CLE、WE、RE等控制寫Flash的相應時序,將數據從RAM中編程到Flash內存,并令頁地址加1,依次循環(循環流程見圖3)。當總線上的第4組Flash的頁地址為64時,塊地址加1,并讀取無效塊信息,如果為無效塊,則屏蔽此塊,重新讀取下一塊信息,直至讀取到正常塊為止。如果是正常塊,則向此塊中寫入數據,同時將頁地址清零。讀操作與寫操作類似,只不過是將Flash中的數據讀出先送到RAM,然后依循環次序讀取RAM即可。

采用FPGA器件實現數據采集系統中高速大容量存儲板的設計

3.5 PCI9054操控部分的設計

通過編寫PCI9054專用的驅動和應用軟件,實現由計算機通過CPCI總線操控存儲板卡。在應用軟件中,對Flash讀寫或者擦除等命令自定義為對CPCI總線發送特定的數據。而在FPGA內部根據PCI9054發送的局部端數據線上的特定數據判斷是何種操作,并執行相應操作。FPGA和PCI9054通信的主要信號線有LHOLD、LHOLDA、READY、ADS、ADDR、DATA,利用這些信號線可以實現PCI9054局部端和FPGA握手。將數據寫到計算機中。在PCI9054專用的驅動和應用軟件中,利用DMA方式讀取Flash,讀取速度可提高至1.3 MHz×16 bit。

4 結束語

本設計采用流水、并行處理技術,利用FPGA內部嵌入的存儲塊設計一組高速數據緩沖區,使得多個慢速的存儲器件并行工作,令系統內外部數據的速率匹配,避免了外置高速緩存,簡化了硬件電路,且極大地提高了存儲數據的速率。大容量高密度閃存器件可使單片存儲板容量高達128 Gbit。在FP-GA內部設計中,建立Flash無效塊信息列表,并在此基礎上對Flash進行讀、寫、擦除及重建無效塊信息等操作。使系統具有集成度高、靈活性好、可移植性強、速度快等特點。通過CPCI總線采取DMA方式讀取,極大地提高了讀取速度。當接收到的數據帶寬很大,速度很高時,可將存儲板并聯起來,多個存儲板級聯可滿足更大的存儲容量需求,也可將級聯并聯二者結合起來以滿足不同系統的要求。整個系統基于CPCI工控機箱,更適合于野外的工作環境,并能及時保存、分析數據。

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

    關注

    1629

    文章

    21729

    瀏覽量

    603010
  • 控制器
    +關注

    關注

    112

    文章

    16332

    瀏覽量

    177812
  • 數據采集
    +關注

    關注

    38

    文章

    6053

    瀏覽量

    113623
收藏 人收藏

    評論

    相關推薦

    基于ARM+FPGA高速同步數據采集

    FPGA邏輯電路控制A/D采集和FIFO緩存模塊,實現長時間不間斷的數據采集數據轉換;同時系統
    發表于 08-31 09:14

    高速容量數據存儲技術

    數據采集中所用的ADC最高采樣率已達到幾百MSPS甚至幾十GSPS的水平,這就要求采樣數據存儲器的速度也要與之匹配,也就是采用高速緩存:二是
    發表于 04-16 08:42

    常見的幾種不同的高速數據采集存儲系統介紹

    、衛星、無線電、光電、激光等高頻物理信號),因試驗、監測及裝備的需要,對于原始信號的長時間捕捉與存儲需求也日益增強。做為實現這些需求的手段,一般搭建一套高速數據采集
    發表于 07-04 06:08

    基于FPGA高速數據采集系統該怎么設計?

    目前,在數據采集系統的硬件設計方案中,有采用通用單片機和USB相結合的方案,也有采用DSP和USB相結合的方案,前者雖然硬件成本低,但是時鐘頻率較低,難以滿足
    發表于 09-05 07:22

    如何利用FPGA實現高速連續數據采集系統設計?

    高速連續數據采集系統的背景及功能是什么?如何利用FPGA實現高速連續
    發表于 04-08 06:19

    高速數據采集系統中高速緩存與海量緩存的實現

    探討了高速數據采集系統中高速采樣緩存的重要性和實現途徑,闡述了基于ADSP-21065L的并行多通道數據
    發表于 04-23 17:08 ?23次下載

    容量固態存儲設備的FPGA實現

    采用容量的固態Flash作為存儲介質,用FPGA作為存儲陣列的控制器,設計了高速
    發表于 12-08 17:25 ?29次下載

    采用FPGA高速數據采集系統

    采用FPGA高速數據采集系統 隨著科學技術的發展,數據采集技術進入到越來越多的領域。目前,已
    發表于 04-20 11:03 ?2220次閱讀
    <b class='flag-5'>采用</b><b class='flag-5'>FPGA</b>的<b class='flag-5'>高速</b><b class='flag-5'>數據采集</b><b class='flag-5'>系統</b>

    單片機系統中高速數據采集實現

    介紹一種單片機系統高速數據采集實現方法,在單片機與高速A/D轉換器之間以靜態存儲器作緩沖
    發表于 07-18 16:59 ?193次下載
    單片機<b class='flag-5'>系統</b><b class='flag-5'>中高速</b><b class='flag-5'>數據采集</b>的<b class='flag-5'>實現</b>

    基于SATA硬盤和FPGA高速數據采集存儲系統

    為解決現有采集存儲系統不能同時滿足高速采集,大容量脫機且長時間持續存儲的問題,設計了一種基于S
    發表于 11-15 11:35 ?169次下載
    基于SATA硬盤和<b class='flag-5'>FPGA</b>的<b class='flag-5'>高速</b><b class='flag-5'>數據采集</b><b class='flag-5'>存儲系統</b>

    高速容量數據采集系統設計與實現

    高速容量數據采集系統設計與實現,下來看看
    發表于 05-10 11:24 ?14次下載

    基于FPGA高速數據采集硬件系統設計

    基于FPGA高速數據采集硬件系統設計.
    發表于 05-10 17:06 ?45次下載

    基于FPGA高速數據采集系統接口設計

    基于FPGA高速數據采集系統接口設計.
    發表于 05-10 17:06 ?27次下載

    如何使用FPGA和DSP進行高速數據采集系統設計

    介紹了1種基于FPGA和DSP的高速數據采集系統的設計和實現,其FPGA
    發表于 11-07 17:18 ?20次下載
    如何使用<b class='flag-5'>FPGA</b>和DSP進行<b class='flag-5'>高速</b><b class='flag-5'>數據采集</b><b class='flag-5'>系統</b>設計

    如何使用FPGA設計高速實時數據采集存儲系統的資料概述

    設計了以FPGA器件XCSVIXS0為核心處理芯片的高速數據采集存儲系統。在XCSVLXS0內部實現
    發表于 12-10 16:47 ?22次下載
    如何使用<b class='flag-5'>FPGA</b>設計<b class='flag-5'>高速</b>實時<b class='flag-5'>數據采集</b><b class='flag-5'>存儲系統</b>的資料概述
    主站蜘蛛池模板: 99国产这里只有精品视频| 韩国演艺圈悲惨在线| 羞羞漫画视频| 嫩B人妻精品一区二区三区| 国产成A人片在线观看| 伊人久久亚洲精品一区| 日本欧美久久久久免费播放网| 好看的电影网站亚洲一区| 成人毛片大全| 2023国产精品一卡2卡三卡4卡| 午夜福利理论片高清在线| 欧美6O老妪与小伙交| 久久精品成人免费网站| 动漫AV纯肉无码AV电影网| 最近2019中文字幕免费版视频| 亚洲2023无矿砖码砖区| 日本19禁啪啪吃奶大尺度| 美女岔开腿露出粉嫩花苞| 国产一区二区三区乱码在线观看| www.av天堂网.com| 91国在线产| 在线视频久久只有精品第一日韩| 小莹的性荡生活40章| 日韩精品一卡二卡三卡四卡2021| 美国特级成人毛片| 久草在线一免费新视频| 国产午夜精品自在自线之la| 丰满的寡妇hd高清在线观看| 99久久99久久精品国产片果冻| 一级毛片两人添下面| 亚洲精品免费观看| 性色欲情网站IWWW| 无码人妻精品一区二区蜜桃在线看 | 亚洲国产AV无码综合在线| 色人格影院第四色| 强上轮流内射高NP男男| 欧美精品专区第1页| 暖暖高清视频免费| 欧美黄色一级| 热久久视久久精品18| 全黄H全肉细节文NP|