ARM+FPGA架构开发板PCIE2SCREEN示例分析与测试-米尔MYD-JX8MMA7
2023-02-23
2223
来源:米尔电子
本篇测评由电子发烧友的优秀测评者“zealsoft”提供。
本次测试内容为米尔MYD-JX8MMA7开发板其FPGA端程序的修改。
01.
测试例程pcie2screen
使用鼠标点击 ready按钮,demo 窗口会显示连续的视频,说明摄像头、DDR、PCIE接口各部分正常。如果没有接摄像头,该程序会显示杂乱无章的图像。

该测试例的源码没有包括在SDK中,可以向米尔公司的技术人员索取。该实例程序是用Qt开发的,使用了OpenGL技术。程序包括以下几个主要的类:
*MainWindow:QMainWindow子类,是显示窗口的。
*uOpenglYuv:QOpenGLWidget子类,用于显示采集到的图像。该类的initializeGL函数用于初始化OpenGL。paintGL函数是用于绘制图像的,其中最核心的语句是:
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, vW, vH, 0, GL_RGBA, GL_UNSIGNED_BYTE, pRGB);
其中的pRGB保存从FPGA读取的数据。从这句我们可以看出该程序所要求的图像的格式。
*xdma_getImg:主线程类
*xdma_programe:对RIFFA接口进行了封装,其中的read_pack用于读取FPGA数据,被主线程循环调用。其函数定义如下:
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;
}
}
02.
FPGA端程序的修改
我们手头没有摄像头进行测试,所以简单修改该程序,使程序发送蓝色渐变色带信号。
核心修改如下:
……
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
…… 引入STM32MP135F安全芯!米尔MYD-YF13X系统、安全、功能三重升级
米尔RK3506 DSMC实战,Local Bus高速互联
OpenClaw秒级上线!JishuShell适配米尔RK3576开发板
米尔RK3576 + ROS2 进阶:NPU加速MixFormerV2目标跟随与机械臂抓取实战
智造新方向 · 国产芯未来,米尔即将亮相新唐2026研讨会
当6 TOPS不再是极限:RK3576+Hailo-8,让高帧率摄像头真正“实时”
新品!从MINI到工业板:米尔T153开发板工业场景全覆盖
新品!瑞萨RZ/T2H驱控一体单芯、多轴实时控制,助力工业以太网
RK3576 + ROS2 SLAM建图与导航实战
米尔亮相德国嵌入式展2026 Embedded World