-
Notifications
You must be signed in to change notification settings - Fork 118
Home
The RGBtoHDMI interface converts the "digital" RGB video signal from vintage computers like the BBC Micro or PC MDA/CGA/EGA to HDMI or DVI compatible with most modern TV/Monitors. The interface comprises a Raspberry Pi Zero and a specially designed Hat containing a small CPLD. Custom firmware on the Raspberry Pi, in conjunction with the CPLD, is able to correctly sample each of the supported video modes to give a pixel-perfect rendition and it also has low lag of around 3 milliseconds.
An addon analog interface is available for the 6 bit version of the converter to support a limited number of computers with a few levels of analog RGB / YUV output such as Amstrad CPC, Spectrum, Atom, Dragon or Tandy Color Computer, or monochrome composite output such as Apple II /IIe, UK101, Superboard II, ZX80 and ZX81. Note this interface can only distinguish a few analog levels and is not suitable for systems with many levels of RGB or YUV.
One unusual feature of the converter is optional integer scaling where one original pixel on the computer is scaled to an exact number of lcd pixels without using any interpolation filtering. This results in the low resolution output from real hardware looking as clean and sharp as sources output at the native resolution of the lcd (see the gallery for examples) although you can use filtering if you prefer.
RGBtoHDMI integer scaling output:
Typical output from other scalers that have interpolation filtering:
3 bit converter 'hat' fitted to Raspberry Pi zero:
6 bit RGBtoHDMI fitted into recommended case with optional analog interface:
RGBtoHDMI is currently a DIY project although a small manufacturing run is being investigated.
- Quick Start Guide
- Reference Guide
- Hardware Guide
- Tutorial on Adding a New Profile
- Gallery of Screencaps
For support, please use the Stardot Thread
The main challenge with this project was successfully sampling Mode 7 on the Beeb.
The difficulty here is that the pixel spacing is very uneven:
This is because of the way the Beeb generated the 6MHz clock from 2, 4 and 8MHz clocks:
The clock edges (both are used by the SAA5050) deviate from where they should be with a pure 6MHz clock, but crucially the differences repeat every 6 edges.
The CPLD on the RGBtoHDMI interface allows the pixel sampling points to varied in units of 10.4ns (1/96MHz) over a range of +/- half a pixel. In mode 7, six possible sampling points can be configured, to match the clock skew.
An automatic calibration process is used to set these sample points.
Construction (current designs)
- Bill of Materials (12-Bit Board)
- Bill of Materials (12-Bit Extender)
- Bill of Materials (Analog Board)
- Bill of Materials (TTL Buffer Boards)
- Bill of Materials (Pi Zero)
- Cables
- Assembled boards for sale
Construction (older designs)
- Bill of Materials (6/8-Bit Board)
- Bill of Materials (6-Bit Board)
- Bill of Materials (3-Bit Board)
- Bill of Materials (Atom Board)
- Assembly Notes (Atom Board)
- CPLD Programming
User Documentation