STM32利用DCMI对并口ADC高速数据采样

一般对于高速的ADC通用解决方案是ADC+FPGA+单片机。这里可以利用STM32的并行数据接口(DCMI)对高速ADC数据进行采样。

这里采用的是STM32H7B0 + AD9226。STM32H7B0通过MCO输出时钟到AD9226然后输入到STM32 DCMI 的PIXCLK口,另留两个IO控制DCMI的VCLK和HCLK。注意这里不能使用AD9226的时钟稳定器,不然数据输出不对。

利用正弦波对AD9226的波形进行检验,可以看出AD9226数据的输出稳定周期在时钟的下降沿,所以DCMI的PIXCLK有限性设置在时钟下降沿。然后DCMI开启DMA接收。

针对如此高的速率,必须充分利用片内的DMA资源。DMA需要开启循环接收和DMA的半满中断和满中断,半满中断复制前半部分数据到外部SRAM或存储器(存储器速率要跟上),满中断复制后半部分数据。STM32H7B0有强大的MDMA可以快速复制大量数据。

注意:复制需要用定时器对数据进行预估,加入半满中断没有完成任务,满中断就来了,就发生了数据的堆叠,由于中断嵌套排队最终导致数据乱码。这种说明【1】ADC速率过快 【2】stm32时钟频率不够 【3】中断时间过长 【4】DMA 缓存过小。

这里采用 STM32H7B0 系统时钟280MHz,AD9226输入时钟25M,DMA缓存长度64k,可以保证数据的不丢失。注意中断任务不要使用printf等长时任务!

  • 3
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
STM32L4 DCMI(数据采集模块接)是STMicroelectronics(意法半导体)公司推出的一种用于图像和视频数据采集的接。该接可以连接到摄像头或其他视频采集设备,用于将采集到的数据传输到STM32L4系列微控制器。 STM32L4 DCMI具有以下特点和功能: 1. 高速传输:使用并行数据传输和时钟信号,可以实现高达60兆字节/秒的数据传输速度,以满足高帧速率的图像和视频传输需求。 2. 灵活性:支持多种采集模式,可以根据应用需求进行配置。例如,可以选择不同的像素时钟分频器和行/帧同步信号来控制图像和视频的采集方式。 3. 外设接STM32L4 DCMI可以与STM32L4系列微控制器的其他外设进行通信,如DMA(直接存储器访问控制器),以提高数据传输效率。 4. 固定模式帧同步:通过配置DCMI的相关参数,可以实现固定模式帧同步,即在每个帧的开始处自动检测并同步图像和视频数据的采集。 5. 帧缓冲区管理:DCMI支持帧缓冲区管理,可以通过DMA或中断方式进行数据传输和处理,减轻主处理器的负担。 6. 片内图像处理:某些STM32L4系列微控制器还具有片内图像处理单元(IPU),可以实现一些基本的图像处理功能(如亮度调节、色彩饱和度调节等)。 总体而言,STM32L4 DCMI是一种实用的图像和视频数据采集接,广泛应用于嵌入式系统、摄像头、监控设备、机器视觉等领域。它提供了高速传输、灵活配置、与外设接通信、帧同步和帧缓冲区管理等功能,为用户提供了方便快捷的图像和视频采集解决方案。
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值