• 正文
  • 相关推荐
申请入驻 产业图谱

【黑金云课堂】FPGA技术教程Linux开发:DP音频播放与VCU视频解码

17小时前
143
加入交流群
扫码加入
获取工程师必备礼包
参与热点资讯讨论

一、DP 音频播放

1. 音频基础知识

数字音频由采样率、位深、声道数三个参数定义。

参数 说明 常见值
采样率 每秒采样次数 44100Hz(CD)、48000Hz(DVD)
位深 单个采样存储位数 16bit、24bit、32bit
声道数 音频通道数量 1 (单声道)、2 (立体声)

计算公式:比特率 = 采样率 × 位深 × 声道数

示例:CD 音质 = 44100 × 16 × 2 = 1,411,200 bps ≈ 1.4 Mbps

常见音频格式

格式 类型 说明
WAV 无损 PCM 原始音频数据,文件体积大
FLAC 无损压缩 压缩率约 50%,音质无损失
MP3 有损压缩 通用音频格式,压缩率高
AAC 有损压缩 同等码率下音质优于 MP3

Linux 音频子系统分层架构

应用层
  ├── ALSA lib (libasound)        # 底层音频标准API
  ├── PulseAudio / PipeWire       # 音频服务混音器
  └── GStreamer / Qt Multimedia   # 多媒体开发框架

内核层
  ├── ALSA Core (sound/core/)     # ALSA音频内核核心
  ├── ASoC (ALSA System on Chip)  # 嵌入式片上音频框架
  └── DP Audio Driver             # DisplayPort音频驱动

硬件层
  ├── DP Controller               # DisplayPort显示控制器
  └── Audio Codec                # 音频编解码芯片

2. PetaLinux 配置(2025.2 版本)

驱动说明:PetaLinux 2025.2 中 DP 音频驱动已默认配置,无需修改内核

RootFS 必须预装组件:GStreamer 运行环境、MP3 解码插件、Qt 图形运行库

必须勾选软件包列表:

[*] packagegroup-xilinx-gstreamer
[*] packagegroup-xilinx-matchbox
[*] packagegroup-xilinx-multimedia
[*] packagegroup-opencv
[*] packagegroup-xilinx-qt
[*] populate_sdk_qt5
[*] packagegroup-xilinx-qt-extended
[*] packagegroup-core-x11

3. 命令行控制 GStreamer 音频播放管道

aplay -l 查看播放设备,

amixer设置音量,

aplay播放WAV文件。

GStreamer支持更多格式(MP3、AAC等),通过decodebin自动检测格式。

实践要点:DP音频需要DP线缆连接且显示器支持音频。常用格式为48000Hz/16bit/立体声。调试时先确认设备存在,再设置音量,最后播放测试。

二、VCU 视频解码

1. VCU 概述

1.1 VCU 基础介绍

VCU(Video Codec Unit)是Zynq UltraScale+ MPSoC EV系列内置硬件视频编解码单元,专门处理 H.264/H.265 实时编解码转码

优势:将高算力视频压缩 / 解压交给专用硬件,ARM CPU 仅负责驱动、缓冲、调度、显示输出

硬件互联:VCU 硬核通过 AXI 总线与 PS、DDR 内存交互,依赖驱动 + 固件协同工作

性能上限:支持 H.264/H.265 硬编硬解,最高 4K@60fps

2. Vivado 工程

vcu_demo 参考工程:包含 VCU IP、DP 显示控制器、AXI 互联、时钟约束

输出文件:生成硬件比特流、硬件 HDF/XSA 文件,用于 PetaLinux 导入生成设备树

配套文件:SD 卡 BOOT 分区启动镜像(BOOT.BIN、image.ub)

3. PetaLinux 工程配置要点

驱动校验:内核开启 VCU、V4L2、KMS/DRM 显示驱动

固件检查:RootFS 内置 VCU 编解码固件,开机自动加载

设备树:配置 VCU 内存地址、DP 显示控制器、CMA 预留内存

内存关键项:CMA 连续内存必须分配足够大小,否则 4K 解码会内存溢出

参考工程:Linux 应用第 24 节 Qt 界面显示工程配套 petalinux 模板

4. GStreamer 编解码实战

前置操作:关闭 X11 占用 KMS 显示

systemctl stop xserver-nodm.service
systemctl disable xserver-nodm.service

MP4 视频解码输出 DP 显示器

gst-launch-1.0 uridecodebin uri=File:///run/media/BOOT-mmcblk1p1/h264_720P.mp4 ! queue max-size-bytes=0 ! videoconvert ! kmssink bus-id=fd4a0000.display fullscreen-overlay=1

测试画面编码生成 MP4 文件

gst-launch-1.0 -e videotestsrc num-buffers=600 pattern=ball ! \
video/x-raw,width=1280,height=720,framerate=30/1 ! \
clockoverlay time-format="%H:%M:%S" font-desc="Sans, 36" ! \
videoconvert ! video/x-raw,format=NV12 ! \
omxh264enc ! h264parse ! mp4mux ! \
filesink location=/run/media/BOOT-mmcblk1p1/test_clock_ball_720p30.mp4

数据流链路:

测试图像源 → 分辨率帧率约束 → 时间水印叠加 → 格式转 NV12 → VCU 硬件 H.264 编码 → 码流解析 → MP4 封装 → 本地文件保存

视频转码(23.97fps → 30fps)

gst-launch-1.0 -e filesrc location=/run/media/BOOT-mmcblk1p1/h264_720P.mp4 ! \
qtdemux ! h264parse ! omxh264dec low-latency=0 ! \
videorate ! video/x-raw,framerate=30/1 ! \
omxh264enc ! h264parse ! mp4mux ! \
filesink location=/run/media/BOOT-mmcblk1p1/h264_720P_30fps.mp4

USB 摄像头采集编码 + UDP 本地回环推流

接收端(解码 + DP 显示,后台运行)

gst-launch-1.0 -v udpsrc port=5000 buffer-size=10000000 \
caps="application/x-rtp,media=video,clock-rate=90000,payload=96,encoding-name=H264" ! \
queue max-size-buffers=4 leaky=downstream ! \
rtph264depay ! h264parse ! video/x-h264,alignment=nal ! \
omxh264dec low-latency=1 ! \
queue max-size-buffers=4 leaky=downstream ! \
kmssink bus-id=fd4a0000.display plane-id=33 fullscreen-overlay=1 sync=false async=false &

发送端(摄像头采集 + VCU 编码 + UDP 发送)

gst-launch-1.0 -v v4l2src device=/dev/video0 io-mode=mmap ! \
video/x-raw,format=YUY2,width=640,height=480,framerate=25/1 ! \
videoconvert ! video/x-raw,format=NV12,width=640,height=480,framerate=25/1 ! \
omxh264enc target-bitrate=2000 control-rate=low-latency gop-mode=low-delay-p \
gop-length=25 periodicity-idr=25 ! \
h264parse ! rtph264pay config-interval=1 pt=96 ! \
udpsink host=127.0.0.1 port=5000 sync=false async=false

💡 完整视频讲解可前往 ALINX 视频号进行直播回看

更多细节欢迎关注我们黑金云课堂全年免费直播课,

黑金云课堂六月直播日历 我们将在每周二、三、四,同步推进 Verilog开发、Vitis开发、Linux开发三大系列,带你从零开始,稳扎稳打掌握 FPGA 开发全流程!

系列 内容定位
Verilog开发 硬件描述语言基础、逻辑设计、仿真调试
Vitis开发 Zynq软硬件协同、外设驱动、网络协议
Linux开发 嵌入式Linux系统移植、驱动编写、应用开发

相关推荐

登录即可解锁
  • 海量技术文章
  • 设计资源下载
  • 产业链客户资源
  • 写文章/发需求
立即登录

芯驿电子自 2012 年成立以来,旗下 AUMO 与 ALINX 两大品牌,在智能车载与 FPGA 行业解决方案领域持续深耕。 ALINX 聚焦 FPGA 解决方案高端产品市场,并积极参与 FPGA 国产化应用发展。至今已推出 100 多款 FPGA SoM 模组和配套板卡,基本完成对 AMD FPGA 产品、紫光同创 FPGA 产品的全系列覆盖,产品远销海外 40 多个国家。 AUMO 专注智能车载,为自动驾驶技术开发破题。至今已推出车载仿真测试系统、视频数据采集、视频数据旁路采集分流、视频数据注入、车载摄像头、车载后视镜等产品线,满足车企和汽车产业链的车载产品开发需求。

微信公众号