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

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

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

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

ARM+FPGA架構(gòu)開發(fā)板PCIE2SCREEN示例分析與測試-米爾MYD-JX8MMA7

米爾電子 ? 2023-03-02 09:44 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本篇測評由電子發(fā)燒友的優(yōu)秀測評者“zealsoft”提供。

537bdf10-b899-11ed-ad0d-dac502259ad0.gif 本次測試內(nèi)容為米爾MYD-JX8MMA7開發(fā)板其ARM端的測試?yán)蘰cie2screen并介紹一下FPGA端程序的修改。

01.

測試?yán)蘰cie2screen
例程pcie2screen是配合MYD-JX8MMA7開發(fā)板所帶的MYIR_PCIE_5T_CMOS 工程的測試?yán)淖饔檬秋@示FPGA所連接的攝像頭所采集的視頻。運行該程序后屏幕會顯示一個標(biāo)題為demo的窗口。
538a3de4-b899-11ed-ad0d-dac502259ad0.png
使用鼠標(biāo)點擊 ready按鈕,demo 窗口會顯示連續(xù)的視頻,說明攝像頭、DDR、PCIE接口各部分正常。如果沒有接攝像頭,該程序會顯示雜亂無章的圖像。

該測試?yán)脑创a沒有包括在SDK中,可以向米爾公司的技術(shù)人員索取。該實例程序是用Qt開發(fā)的,使用了OpenGL技術(shù)。程序包括以下幾個主要的類:

  • MainWindow:QMainWindow子類,是顯示窗口的。
  • uOpenglYuv:QOpenGLWidget子類,用于顯示采集到的圖像。該類的initializeGL函數(shù)用于初始化OpenGL。paintGL函數(shù)是用于繪制圖像的,其中最核心的語句是:

glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, vW, vH, 0, GL_RGBA, GL_UNSIGNED_BYTE, pRGB);

其中的pRGB保存從FPGA讀取的數(shù)據(jù)。從這句我們可以看出該程序所要求的圖像的格式。

  • xdma_getImg:主線程類
  • xdma_programe:對RIFFA接口進行了封裝,其中的read_pack用于讀取FPGA數(shù)據(jù),被主線程循環(huán)調(diào)用。其函數(shù)定義如下:

int xdma_programe::read_pack(char *pData, int len)
{
//int buffer[1920 * 1080];
//int buffer[1024 * 768];
int buffer[1280 * 720];
int i;

if(dev_fd != NULL)
{
fpga_send(dev_fd, 0, buffer, len / 4, 0, 1, 25000);
fpga_recv(dev_fd, 0, buffer, len / 4, 25000);
memcpy(pData, (char *)buffer, len);

return len;
}
else
{
return 0;
}
}

從函數(shù)中可以看出,在每次讀數(shù)據(jù)前,該函數(shù)先向FPGA寫一次數(shù)據(jù)(數(shù)據(jù)無意義,和FPGA的狀態(tài)機有關(guān)),每次讀入一整幀的數(shù)據(jù)。

02.

FPGA端程序的修改
FPGA端的邏輯控制在chnl_tester.v中,它定義了一個狀態(tài)機,用于對數(shù)據(jù)收發(fā)進行控制。狀態(tài)機定義如下:

always @(posedge CLK or posedge RST) begin
if (RST) begin
rLen <= #1 0;
rCount <= #1 0;
rState <= #1 0;
rData <= #1 0;
vout_vs_r <= #1 0;
end
else begin
case (rState)


3'd0: begin // Wait for start of RX, save length
if (CHNL_RX) begin
rLen <= #1 CHNL_RX_LEN;
rCount <= #1 0;
rState <= #1 3'd1;
end
end


3'd1: begin // Wait for last data in RX, save value
if (CHNL_RX_DATA_VALID) begin
rData <= #1 CHNL_RX_DATA;
rCount <= #1 rCount + (C_PCI_DATA_WIDTH/32);
end
if (rCount >= rLen)begin
rState <= #1 3'd2;
end
end

3'd2: begin // Prepare for TX
if (read_valid) begin
rCount <= #1 0;
rState <= #1 3'd3;
end
end

3'd3: begin // Start TX with save length and data value
if (CHNL_TX_DATA_REN) begin
//rData <= #1 data_in;
rCount <= #1 rCount + (C_PCI_DATA_WIDTH/32);
if (rCount >= rLen)
rState <= #1 3'd4;?
end
end
3'd4: begin
if (vout_vs_r)
rState <= #1 3'd5;
else begin
vout_vs_r <= #1 1;
rState <= #1 3'd4;
rCount <= #1 0;
end
end
3'd5: begin
if (vs_flag) begin
rState <= #1 3'd0;
vout_vs_r <= #1 0;
end
else
rState <= #1 3'd5;
end
endcase
end
end

我們手頭沒有攝像頭進行測試,所以簡單修改該程序,使程序發(fā)送藍色漸變色帶信號。
核心修改如下:

……
reg [31:0] rColor = 0;
……
assign CHNL_TX_DATA = (read_en)? {rColor, rColor}:64'd0;
……
3'd3: begin // Start TX with save length and data value
if (CHNL_TX_DATA_REN) begin
//rData <= #1 data_in;
// if (rCount % 5 == 4)
rColor <= #1 rColor + 1;
if(rColor >= 255)
rColor <= #1 0;
rCount <= #1 rCount + (C_PCI_DATA_WIDTH/32);
if (rCount >= rLen)
rState <= #1 3'd4;?
end
end
……



03.

測試結(jié)果
我們沒有修改ARM端的測試程序,仍然使用廠家提供的pcie2screen,只是重新燒寫FPGA程序。程序的運行效果參見視頻。

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

    關(guān)注

    1656

    文章

    22288

    瀏覽量

    630383
  • ARM
    ARM
    +關(guān)注

    關(guān)注

    135

    文章

    9499

    瀏覽量

    388801
  • 開發(fā)板
    +關(guān)注

    關(guān)注

    25

    文章

    6127

    瀏覽量

    113461
  • 米爾
    +關(guān)注

    關(guān)注

    0

    文章

    55

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    如何移植EtherCAT Igh--基于米爾RK3576開發(fā)板

    本文將介紹基于米爾電子MYD-LR3576開發(fā)板米爾基于瑞芯微RK3576開發(fā)板)的端移植E
    的頭像 發(fā)表于 09-26 08:04 ?9455次閱讀
    如何移植EtherCAT Igh--基于<b class='flag-5'>米爾</b>RK3576<b class='flag-5'>開發(fā)板</b>

    Pico2-ICE FPGA開發(fā)板的應(yīng)用示例

    FPGA 和 MCU 結(jié)合的開發(fā)板不多,而 Pico2?ICE 則把小巧、靈活和易上手完美結(jié)合。搭載 RP2350 雙核 RISC-V MCU + Lattice iCE40UP5K FPGA
    的頭像 發(fā)表于 09-06 10:02 ?660次閱讀
    Pico<b class='flag-5'>2</b>-ICE <b class='flag-5'>FPGA</b><b class='flag-5'>開發(fā)板</b>的應(yīng)用<b class='flag-5'>示例</b>

    米爾RK3506國產(chǎn)開發(fā)板測試用】1、硬件介紹、SDK開發(fā)環(huán)境和QT開發(fā)環(huán)境搭建

    ,根據(jù)開發(fā)板的IP地址設(shè)置主機,同時使用頁面的上公私鑰配置工具生成公私鑰信息并部署公鑰到開發(fā)板。 Sysroot:設(shè)置為Buildroot輸出目錄中的/myd_yr3506_emmc_br/host
    發(fā)表于 08-02 15:02

    如何部署流媒體服務(wù)實現(xiàn)監(jiān)控功能--基于米爾TI AM62x開發(fā)板

    本文將介紹基于米爾電子MYD-YM62X開發(fā)板米爾基于TIAM62開發(fā)板)的部署流媒體服務(wù)實現(xiàn)監(jiān)控功能方案的
    的頭像 發(fā)表于 07-03 08:03 ?2060次閱讀
    如何部署流媒體服務(wù)實現(xiàn)監(jiān)控功能--基于<b class='flag-5'>米爾</b>TI AM62x<b class='flag-5'>開發(fā)板</b>

    基于米爾全志T536開發(fā)板的多協(xié)議物聯(lián)網(wǎng)關(guān)的方案測試

    本文將介紹基于米爾電子MYD-LT536開發(fā)板米爾基于全志T536開發(fā)板)的多協(xié)議物聯(lián)網(wǎng)關(guān)方案的開發(fā)
    的頭像 發(fā)表于 06-19 08:03 ?1482次閱讀
    基于<b class='flag-5'>米爾</b>全志T536<b class='flag-5'>開發(fā)板</b>的多協(xié)議物聯(lián)網(wǎng)關(guān)的方案<b class='flag-5'>測試</b>

    有獎丨米爾 瑞芯微RK3562開發(fā)板免費試用新增名額!

    米爾與瑞芯微合作發(fā)布的新品基于瑞芯微RK3562應(yīng)用處理器的MYD-YR3562開發(fā)板免費試用名額增加
    的頭像 發(fā)表于 06-13 08:04 ?858次閱讀
    有獎丨<b class='flag-5'>米爾</b> 瑞芯微RK3562<b class='flag-5'>開發(fā)板</b>免費試用新增名額!

    ARM,NPU,FPGA三種核心的開發(fā)板米爾安路飛龍派開發(fā)板

    最近我發(fā)現(xiàn)一個有趣的開發(fā)板。這個開發(fā)板集合了ARM核心,NPU核心甚至還有FPGA核心。它就是米爾新出的YM90X
    的頭像 發(fā)表于 06-13 08:03 ?1367次閱讀
    有<b class='flag-5'>ARM</b>,NPU,<b class='flag-5'>FPGA</b>三種核心的<b class='flag-5'>開發(fā)板</b> — <b class='flag-5'>米爾</b>安路飛龍派<b class='flag-5'>開發(fā)板</b>

    有獎丨米爾 NXP i.MX91開發(fā)板免費試用來啦

    米爾與NXP合作發(fā)布的新品基于NXPi.MX91應(yīng)用處理器的MYD-LMX91開發(fā)板免費試用名額來啦~~米爾提供了3套價值588元的MYD-
    的頭像 發(fā)表于 06-05 08:02 ?1118次閱讀
    有獎丨<b class='flag-5'>米爾</b> NXP i.MX91<b class='flag-5'>開發(fā)板</b>免費試用來啦

    基于米爾全志T536開發(fā)板的視頻識別應(yīng)用方案

    本文將介紹基于米爾電子MYD-LT536開發(fā)板米爾基于全志T536開發(fā)板)的視頻識別應(yīng)用方案測試
    的頭像 發(fā)表于 06-05 08:01 ?1787次閱讀
    基于<b class='flag-5'>米爾</b>全志T536<b class='flag-5'>開發(fā)板</b>的視頻識別應(yīng)用方案

    米爾-STM32MP257開發(fā)板試用體驗】初次體驗米爾-STM32MP257開發(fā)板

    接口。 為了幫助開發(fā)者更好地理解與應(yīng)用STM32MP257D處理器和MYD-LD25X開發(fā)板,米爾將與ST在2025年1月7日和2025年1
    發(fā)表于 04-30 16:21

    OpenCV行人檢測應(yīng)用方案--基于米爾全志T527開發(fā)板

    本文將介紹基于米爾電子MYD-LT527開發(fā)板米爾基于全志T527開發(fā)板)的OpenCV行人檢測方案
    的頭像 發(fā)表于 04-10 08:03 ?1103次閱讀
    OpenCV行人檢測應(yīng)用方案--基于<b class='flag-5'>米爾</b>全志T527<b class='flag-5'>開發(fā)板</b>

    免費丨米爾 STM32MP257開發(fā)板有獎試用

    米爾與ST合作發(fā)布的新品基于STM32MP257應(yīng)用處理器的MYD-LD25X開發(fā)板免費試用活動來啦~~米爾提供了2塊價值488元的
    的頭像 發(fā)表于 03-20 08:05 ?886次閱讀
    免費丨<b class='flag-5'>米爾</b> STM32MP257<b class='flag-5'>開發(fā)板</b>有獎試用

    有獎丨米爾 瑞芯微YR3562開發(fā)板免費試用

    米爾與瑞芯微合作發(fā)布的新品基于瑞芯微RK3562應(yīng)用處理器的MYD-YR3562開發(fā)板免費試用活動來啦~~米爾提供了3塊價值599元的MYD
    的頭像 發(fā)表于 03-20 08:05 ?808次閱讀
    有獎丨<b class='flag-5'>米爾</b> 瑞芯微YR3562<b class='flag-5'>開發(fā)板</b>免費試用

    人臉疲勞檢測應(yīng)用-米爾基于RK3576核心/開發(fā)板

    本文將介紹基于米爾電子MYD-LR3576開發(fā)板米爾基于瑞芯微RK3576開發(fā)板)的人臉疲勞檢測方案
    的頭像 發(fā)表于 12-20 08:06 ?1363次閱讀
    人臉疲勞檢測應(yīng)用-<b class='flag-5'>米爾</b>基于RK3576核心<b class='flag-5'>板</b>/<b class='flag-5'>開發(fā)板</b>

    如何用OpenCV進行手勢識別--基于米爾全志T527開發(fā)板

    本文將介紹基于米爾電子MYD-LT527開發(fā)板米爾基于全志T527開發(fā)板)的OpenCV手勢識別方案
    的頭像 發(fā)表于 12-13 08:04 ?1767次閱讀
    如何用OpenCV進行手勢識別--基于<b class='flag-5'>米爾</b>全志T527<b class='flag-5'>開發(fā)板</b>