LISA DVP 驱动示例 - Ping-Pong 模式
功能说明
本示例演示如何使用 LISA DVP 驱动的 Ping-Pong 双缓冲模式实现高速连续图像捕获。
主要功能
初始化 DVP 设备并配置采集参数
使用 Ping-Pong 双缓冲模式实现零拷贝连续捕获
通过回调函数交替处理 Ping/Pong 缓冲区数据
在回调中重载对应缓冲区保持连续采集
捕获指定帧数后自动停止
硬件要求
ARCS EVB 开发板
支持 DVP 接口的摄像头模块(如 GC032A)
正确连接 DVP 信号线:
HSYNC (PAD_A 10)
VSYNC (PAD_A 11)
PCLK (PAD_A 12)
D0-D7 (PAD_A 13-20)
MCLK (PAD_A 26)
配置说明
图像参数
分辨率: 640x480
格式: YUV422 (Y0CbY1Cr)
缓冲区大小: 每个 640 × 480 × 2 = 614,400 字节
缓冲区数量: 2 个(Ping + Pong)
DVP 配置
DMA 通道: 2
数据对齐: 左对齐
VSYNC 极性: 上升沿
HSYNC 极性: 上升沿
PCLK 极性: 上升沿
MCLK 频率: 25MHz
捕获设置
捕获帧数: 20 帧
模式: Ping-Pong 模式(双缓冲区交替)
Ping-Pong 模式优势
零拷贝: 硬件 DMA 直接写入用户缓冲区,无需额外拷贝
连续捕获: 两个缓冲区交替使用,一个接收数据时另一个可以处理
无丢帧: 避免了单缓冲区模式下的帧间间隔
高吞吐: 适合高帧率连续采集场景
使用方法
1. 编译
重要提示:在编译前,请先确认您使用的开发板型号。SDK 目前支持以下开发板:
arcs_evb - ARCS EVB 评估板
arcs_mini - ARCS Mini 开发板
根据您的开发板型号,选择对应的编译命令:
在示例目录下执行编译:
# 使用 arcs_evb 开发板
./build.sh -C -DBOARD=arcs_evb
# 或使用 arcs_mini 开发板
./build.sh -C -DBOARD=arcs_mini
Note
如果在 SDK 根目录执行,需要指定示例路径:
# 使用 arcs_evb 开发板
./build.sh -C -S samples/<示例路径> -DBOARD=arcs_evb
# 或使用 arcs_mini 开发板
./build.sh -C -S samples/<示例路径> -DBOARD=arcs_mini
Note
确保已安装对应的工具链。
2. 烧录
lisa zep flash
3. 查看输出
通过串口工具(如 lisa zep monitor)查看日志输出:
==========================================
LISA DVP Driver Sample - Ping-Pong Mode
==========================================
Frame format: YUV422
Resolution: 640x480
Max frames: 20
Mode: Ping-Pong (zero-copy continuous capture)
DVP device obtained
DVP setup completed (DMA channel: 2)
DVP clockout enabled (25MHz)
DVP Ping-Pong capture started
Frame size: 640x480, buffer size: 614400 bytes
Ping buffer: 0x60xxxxxx
Pong buffer: 0x60xxxxxx
Waiting for frames (Ping-Pong mode)...
[PING] Frame 1 captured, size=614400 bytes
[PING] Frame data: XX XX XX XX XX XX XX XX
[PONG] Frame 1 captured, size=614400 bytes
[PONG] Frame data: XX XX XX XX XX XX XX XX
[PING] Frame 2 captured, size=614400 bytes
...
[PONG] Frame 10 captured, size=614400 bytes
Reached maximum capture frames, stopping...
DVP stopped successfully
==========================================
Capture completed
Ping frames: 10
Pong frames: 10
Total frames: 20
==========================================
代码说明
主要流程
初始化阶段
获取 DVP 设备
配置 DVP 参数(分辨率、格式、信号极性等)
启用时钟输出(为摄像头提供 MCLK)
捕获阶段
清空两个缓冲区
启动 Ping-Pong 模式捕获
等待帧数据接收完成
回调处理
接收
LISA_DVP_EVENT_PING_DONE或LISA_DVP_EVENT_PONG_DONE事件处理对应缓冲区的图像数据
调用
lisa_dvp_reload_pingpong()重载对应缓冲区达到指定帧数后停止捕获
Ping-Pong 工作原理
时间线:
DMA → Ping 缓冲区 ━━━━━━━┓
┃ (回调: PING_DONE)
┗━━→ 处理 Ping 数据
┗━━→ 重载 Ping 缓冲区
DMA → Pong 缓冲区 ━━━━━━━┓
┃ (回调: PONG_DONE)
┗━━→ 处理 Pong 数据
┗━━→ 重载 Pong 缓冲区
交替循环 ↻
关键函数
lisa_dvp_setup()- 初始化并配置 DVP 设备lisa_dvp_enable_clockout()- 启用时钟输出lisa_dvp_start_pingpong()- 启动 Ping-Pong 模式捕获lisa_dvp_reload_pingpong()- 重载缓冲区(在回调中调用)lisa_dvp_stop()- 停止捕获
注意事项
双缓冲区: 需要准备两个大小相同的缓冲区
缓冲区对齐: 两个缓冲区都必须 4 字节对齐
缓冲区位置: 缓冲区放在 PSRAM 中以节省 SRAM 空间
内存需求: Ping-Pong 模式需要双倍内存(2 个缓冲区)
重载时机: 必须在对应的回调中及时重载缓冲区
处理时间: 处理单帧的时间必须小于采集一帧的时间,否则会造成丢帧
回调上下文: 回调函数在中断上下文中执行,复杂处理应放到任务中
事件区分: 注意区分
PING_DONE和PONG_DONE事件,重载对应的缓冲区
适用场景
高帧率连续捕获
实时视频流处理
图像序列采集
零拷贝要求的应用
需要最小化帧间延迟的场景
性能对比
对比项 |
普通模式 |
Ping-Pong 模式 |
|---|---|---|
缓冲区数量 |
1 个 |
2 个 |
内存占用 |
较小 |
较大(2倍) |
帧间延迟 |
有间隔 |
无间隔 |
连续性 |
中断式 |
连续式 |
适用场景 |
低速/单帧 |
高速/连续 |
处理时间要求 |
宽松 |
严格 |