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

電子發(fā)燒友App

硬聲App

掃碼添加小助手

加入工程師交流群

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>嵌入式開發(fā)>基于Linux平臺的天氣雷達高速數(shù)據(jù)采集系統(tǒng)的驅(qū)動

基于Linux平臺的天氣雷達高速數(shù)據(jù)采集系統(tǒng)的驅(qū)動

2017-10-30 | rar | 0.6 MB | 次下載 | 1積分

資料介紹

Linux是開放源代碼、網(wǎng)絡(luò)化的操作系統(tǒng),具有穩(wěn)定、高效、內(nèi)核可自由配置等特點。采用Linux 操作系統(tǒng)作為開發(fā)平臺與采用VxWorks 和Windows 作為開發(fā)平臺相比不僅有免費的優(yōu)勢,而且對于發(fā)展核心技術(shù),提高信息安全有著極其重要的意義,是自主研發(fā)的一個方向。隨著我國天氣雷達的快速發(fā)展,天氣雷達在民用和軍事領(lǐng)域的應(yīng)用越來越廣泛。目前,天氣雷達高速數(shù)據(jù)采集、傳輸?shù)裙δ艽蠖蓟赪indows平臺進行開發(fā)實現(xiàn),實現(xiàn)由Windows平臺向Linux平臺的轉(zhuǎn)換,對于發(fā)展中國自主知識產(chǎn)權(quán)氣象軟件核心技術(shù), 提高信息安全有著極其重要的意義。本文基于Linux 操作系統(tǒng)(2.6.23內(nèi)核),實現(xiàn)了天氣雷達高速數(shù)據(jù)采集及處理,對天氣雷達系統(tǒng)由Windows平臺向Linux平臺移植具有參考價值。
  1 數(shù)據(jù)采集系統(tǒng)分析
  1.1 工作原理
  天氣雷達高速數(shù)據(jù)采集系統(tǒng)由I/Q數(shù)據(jù)采集、FIFO緩沖、FPGA控制模塊及PCI總線芯片PLX9054組成,系統(tǒng)結(jié)構(gòu)框圖如圖1所示。
  基于Linux平臺的天氣雷達高速數(shù)據(jù)采集系統(tǒng)的驅(qū)動
  其核心部分為FPGA控制模塊,主要實現(xiàn)4個功能:(1)根據(jù)雷達量程和距離分辨率調(diào)整AD采樣時鐘的頻率;(2)控制AD兩路采樣數(shù)據(jù)寫入FIFO 緩沖以及DMA 傳輸時從FIFO中連續(xù)讀出數(shù)據(jù); (3)與PCI總線控制芯片PLX9054 進行控制交互, 實現(xiàn)局部總線的讀寫控制、地址譯碼和中斷觸發(fā);(4)與PLX9054 進行數(shù)據(jù)交互,使用FPGA內(nèi)部RAM保存控制天氣雷達發(fā)射機和接收機工作的命令及數(shù)據(jù),完成對雷達工作的控制。
  I/Q數(shù)據(jù)采集輸出數(shù)據(jù)速度為2.4 Mb/s(I、Q數(shù)據(jù)各為24 bit),通過FPGA控制,合并寫入到FIFO緩沖。FIFO緩沖為32 bit、深度為16 KB的數(shù)據(jù)緩存,有效位為24 bit;與計算機總線的接口采用32 bit的PCI總線接口芯片PLX9054,PC機通過它完成與數(shù)據(jù)采集系統(tǒng)的數(shù)據(jù)交互。
  1.2 PC機與采集系統(tǒng)數(shù)據(jù)訪問
  1.2.1 局部地址分配
  PC機與天氣雷達高速數(shù)據(jù)采集系統(tǒng)的數(shù)據(jù)訪問通過PCI總線芯片PLX9054實現(xiàn),訪問目標為FIFO緩沖和FPGA片內(nèi)RAM。對FIFO緩沖和FPGA片內(nèi)RAM分配不同局部地址,通過對局部地址總線進行譯碼確定需要訪問的目標。FIFO 數(shù)據(jù)采用DMA傳輸方式連續(xù)讀出, 每次傳輸長度最大為8 KB,因此,設(shè)置FIFO空間32 bit局部地址范圍為0x20000000~0x2000FFFF,映射空間為PCI 地址空間bar2。
  FPGA片內(nèi)RAM位寬為32 bit, 采用局部地址范圍為0x40000000~0x400FFFFF。映射空間為PCI地址空間bar3。
  1.2.2 數(shù)據(jù)訪問方式
  FIFO緩沖為可編程FIFO,由FPGA根據(jù)片內(nèi)存儲的雷達參數(shù)進行控制。當(dāng)FIFO中數(shù)據(jù)達到設(shè)置的大小時,觸發(fā)PCIPLX9054引發(fā)PCI中斷,通過該中斷向驅(qū)動程序申請發(fā)起DMA 傳輸。驅(qū)動程序響應(yīng)該中斷后設(shè)置PCIPLX9054的DMA寄存器, 發(fā)起方向從局部總線到PCI總線的DMA傳輸,完成FIFO數(shù)據(jù)向PC機的傳輸。
  FPGA片內(nèi)RAM通過PCI地址映射,使用IO操作方式進行數(shù)據(jù)讀寫訪問。
  2 Linux程序?qū)崿F(xiàn)
  天氣雷達高速數(shù)據(jù)采集系統(tǒng)基于Linux2.6內(nèi)核平臺程序,由基于PCI總線的設(shè)備驅(qū)動程序、數(shù)據(jù)采集及處理程序組成。
  2.1 設(shè)備驅(qū)動程序?qū)崿F(xiàn)
  設(shè)備驅(qū)動程序的功能是在Linux2.6系統(tǒng)平臺下,通過對PCI總線控制芯片PLX9054的控制,實現(xiàn)PC機與采集板的數(shù)據(jù)交互,實現(xiàn)雷達采集數(shù)據(jù)的實時接收及雷達工作狀態(tài)的控制。從功能結(jié)構(gòu)上,設(shè)備驅(qū)動主要由設(shè)備裝載及初始化、提供給用戶層的接口函數(shù)、中斷及DMA數(shù)據(jù)傳輸三部分組成。
  2.1.1 設(shè)備裝載及卸載
  設(shè)備裝載和卸載即是Windows系統(tǒng)中設(shè)備驅(qū)動安裝和卸載。在Linux2.6中,裝載和卸載主要通過調(diào)用系統(tǒng)提供的PCI總線驅(qū)動注冊函數(shù)pci_register_drive和注銷函數(shù)pci_unregister_driver來實現(xiàn),其注冊的driver數(shù)據(jù)結(jié)構(gòu)如下:
  static struct pci_driver plx9054_pci_driver = {
  .name = ‘pci9054’,
  .id_table = plx9054_pci_tbl,
  .probe = plx9054_probe,
  .remove = plx9054_remove,
  };
  當(dāng)系統(tǒng)引導(dǎo)時,高速數(shù)據(jù)采集系統(tǒng)板上電后,板上PCI總線固件對PLX9054設(shè)備進行缺省配置,為設(shè)備的每個地址區(qū)域分配好資源。裝載函數(shù)在驅(qū)動中用module_init聲明,進行設(shè)備的初始化工作,調(diào)用PCI總線驅(qū)動注冊函數(shù),根據(jù)id_table定義的信息對PCI設(shè)備PLX9054進行探測識別,完成PLX9054設(shè)備驅(qū)動的PCI總線注冊,然后調(diào)用驅(qū)動注冊的probe函數(shù),完成PLX9054設(shè)備使能、PCI地址空間映射、PLX9054設(shè)備數(shù)據(jù)結(jié)構(gòu)初始化、設(shè)備注冊(注冊為字符設(shè)備)等操作。卸載函數(shù)用module_exit聲明,是裝載的逆過程,通過調(diào)用PCI總線驅(qū)動卸載函數(shù),繼而調(diào)用注冊的remove函數(shù)、注銷設(shè)備及PCI地址空間映射、釋放分配給設(shè)備的數(shù)據(jù)結(jié)構(gòu)空間等操作,完成系統(tǒng)資源釋放。
  2.1.2 設(shè)備接口函數(shù)
  設(shè)備接口函數(shù)為用戶提供與設(shè)備進行交互的不同功能接口,主要完成用戶與設(shè)備的讀、寫及設(shè)備控制訪問等功能,其數(shù)據(jù)結(jié)構(gòu)設(shè)計為:
  static const struct file_operations plx9054_fops = {
  .owner = THIS_MODULE,
  .open = plx9054_open, /*打開設(shè)備*/
  .release = plx9054_close, /*釋放設(shè)備*/
  .ioctl = plx9054_ioctl, /*IO操作*/
  .read = plx9054_read, /*讀設(shè)備*/
  };
  這個數(shù)據(jù)結(jié)構(gòu)在設(shè)備裝載過程中,作為設(shè)備注冊的參數(shù)完成與設(shè)備掛接、使用戶在系統(tǒng)調(diào)用中能訪問到上述關(guān)聯(lián)的設(shè)備接口函數(shù)。
  設(shè)備打開函數(shù)plx9054_open完成以下操作:設(shè)備私有數(shù)據(jù)結(jié)構(gòu)內(nèi)存空間分配及初始化,DMA連續(xù)物理內(nèi)存空間申請,為天氣雷達最大距離探測采集數(shù)據(jù)的大小;調(diào)用pci_map_single將分配的DMA內(nèi)存空間映射為用于DMA傳輸?shù)刂罚籇MA數(shù)據(jù)緩沖區(qū)分配(容量為2 MB),緩沖區(qū)保存每次DMA傳輸中獲取的數(shù)據(jù);調(diào)用request_irq對中斷函數(shù)p9054_interrupt進行中斷號申請;對天氣雷達工作參數(shù)進行缺省配置,啟動雷達工作。設(shè)備釋放函數(shù)PLX9054_close完成的操作與設(shè)備打開函數(shù)與PLX9054_open相反。IO操作函數(shù)PLX9054_ioctl通過sys_ioctl系統(tǒng)調(diào)用,完成用戶與設(shè)備的信息查詢、雷達工作參數(shù)配置與查詢,如驅(qū)動軟件版本號、雷達當(dāng)前工作各參數(shù)配置和查詢,主要用于對FPGA中RAM內(nèi)存空間的雷達工作參數(shù)數(shù)據(jù)訪問。由于這部分數(shù)據(jù)對訪問速度要求不高,使用IO操作能很好地滿足設(shè)計要求。讀設(shè)備函數(shù)PLX9054_read將驅(qū)動DMA數(shù)據(jù)緩沖區(qū)中的數(shù)據(jù)實時讀取到用戶空間緩沖區(qū)內(nèi),完成采集數(shù)據(jù)從設(shè)備到用戶的讀取操作。
pci總線 Linux 數(shù)據(jù)采集系統(tǒng)
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1MDD品牌三極管BC807數(shù)據(jù)手冊
  2. 3.00 MB   |  次下載  |  免費
  3. 2MDD品牌三極管BC817數(shù)據(jù)手冊
  4. 2.51 MB   |  次下載  |  免費
  5. 3MDD品牌三極管D882數(shù)據(jù)手冊
  6. 3.49 MB  |  次下載  |  免費
  7. 4MDD品牌三極管MMBT2222A數(shù)據(jù)手冊
  8. 3.26 MB  |  次下載  |  免費
  9. 5MDD品牌三極管MMBTA56數(shù)據(jù)手冊
  10. 3.09 MB  |  次下載  |  免費
  11. 6MDD品牌三極管MMBTA92數(shù)據(jù)手冊
  12. 2.32 MB  |  次下載  |  免費
  13. 7STM32G474 HRTIME PWM 丟波問題分析與解決
  14. 1.00 MB   |  次下載  |  3 積分
  15. 8新能源電動汽車高壓線束的銅鋁連接解決方案
  16. 2.71 MB   |  次下載  |  2 積分

本月

  1. 1愛華AIWA HS-J202維修手冊
  2. 3.34 MB   |  37次下載  |  免費
  3. 2NB-IoT芯片廠商的資料說明
  4. 0.31 MB   |  22次下載  |  1 積分
  5. 3PC5502負載均流控制電路數(shù)據(jù)手冊
  6. 1.63 MB   |  22次下載  |  免費
  7. 4H110主板CPU PWM芯片ISL95858HRZ-T核心供電電路圖資料
  8. 0.63 MB   |  6次下載  |  1 積分
  9. 5UWB653Pro USB口測距通信定位模塊規(guī)格書
  10. 838.47 KB  |  5次下載  |  免費
  11. 6技嘉H110主板IT8628E_BX IO電路圖資料
  12. 2.61 MB   |  4次下載  |  1 積分
  13. 7蘇泊爾DCL6907(即CHK-S007)單芯片電磁爐原理圖資料
  14. 0.04 MB   |  4次下載  |  1 積分
  15. 8蘇泊爾DCL6909(即CHK-S009)單芯片電磁爐原理圖資料
  16. 0.08 MB   |  2次下載  |  1 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935137次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
  4. 1.48MB  |  420064次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233089次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191439次下載  |  10 積分
  9. 5十天學(xué)會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183353次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81602次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73822次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65991次下載  |  10 積分