High-speed data acquisition with Raspberry Pi Pico 2’s HSTX interface and HDMI to USB 3.0 video capture dongle

We previously explained the HSTX high-speed serial transmit interface of the Raspberry Pi RP2350 microcontroller was mostly useful for video outputs and display interfaces since it can only transmit, and not receive data.

But Steve Markgraf found another use case for the HSTX interface – high-speed data acquisition – combining a Raspberry Pi Pico 2 board with the DVI Sock board for Pico and one of those cheap MS2130-based HDMI to USB 3.0 video capture dongles. He managed to stream out up to 75 MB/s of real-time data from an overclocked RP2350 to a host computer with a USB 3.0 port. The Adafruit Feather RP2350 HSTX board should also work, but also not been tested.

Raspberry Pi Pico 2 high-speed data acquisition

Steve’s “hsdaoh-rp2350” data acquisition over HDMI firmware is based on the dvi_out_hstx_encoder example from Raspberry Pi using the HSTX interface for DVI output and code by Shuichi Takano implementing the HDMI data island encoding required to send HDMI info frames.

The main functionality is implemented through the libpicohsdaoh library which reads the data from a ringbuffer and streams it out via the HSTX port to the HDMI capture card. Three example applications can also be found in the apps folder in the GitHub repository for the project:

  • counter – Generates a 16-bit counter value using Raspberry Pi RP2350 PIO
  • internal_adc –  Stream the data from the internal ADC at 3.33 MS/s after some overclocking. But up to 7.9 MS/s can be achieved with additional tricks like using the USB PLL and overvolting beyond VREG_VOLTAGE_MAX,
  • external_adc – PIO program that reads the data from a 12-bit ADC connected to GP0-GP11, outputs the ADC clock on GP22, and packs the 12-bit samples to 16-bit words to achieve maximum throughput. It is designed to work with AD9226 ADC boards as shown in the photo below.

Raspberry Pi Pico 2 AD9226 ADC

The MS2130 can enable data acquisition up to 298.5 MB/s in theory, so the Raspberry Pi Pico 2 is the bottleneck here, and performance can be further improved with inexpensive FPGA boards such as the Sipeed Tang Nano 20K. Steve also builds an SDR using the same principle and some extra hardware capturing data with the open-source fosphor program. You’ll find the firmware source on GitHub for different platforms as well as the High-Speed Data Acquisition over HDMI (hsdaoh) userspace library. More technical details and an explanation of how this all works can be found in the video presentation below.

It looks pretty cool, especially since the hardware is incredibly cheap, with the Raspberry Pi Pico 2 going for $5 and the MS2130 HDMI to USB 3.0 dongle for about $5 on AliExpress (and a bit more on Amazon). That’s enough to get started, but you’ll need some extra hardware to build something useful, and for instance, the AD9226 12-bit ADC module above can be purchased for around $16.

Share this:

Support CNX Software! Donate via cryptocurrencies, become a Patron on Patreon, or purchase goods on Amazon or Aliexpress

Radxa Orion O6 Armv9 mini-ITX motherboard
Subscribe
Notify of
guest
The comment form collects your name, email and content to allow us keep track of the comments placed on the website. Please read and accept our website Terms and Privacy Policy to post a comment.
3 Comments
oldest
newest
Willy
1 month ago

I love this 🙂 Hardware used to the max! Maybe a VGA to USB capture device could capture 3 channels at once directly without the RPi. Though I think the bandwidth would not necessarily be as high.

Harry Munday
1 month ago

An intresting notes is, this is already used in a production ready development platform, for the data-transfer end of the MISRC project providing FM RF capture options and RAW baseband capture for vhs-decode and cvbs-decode projects, we already have real-time sample unpacking and FLAC compression working today based around the tang nano 20k as our FPGA.

Harry Munday
1 month ago

MISRC V1.5 with the Hasdoa workflow.

photo_2024-11-19_16-49-14
Boardcon EM3562 Rockchip RK3562 SBC with 8 analog camera inputs