drm/meson AmLogic Meson Video Processing Unit

VPU Handles the Global Video Processing, it includes management of the clocks gates, blocks reset lines and power domains.

What is missing :

  • Full reset of entire video processing HW blocks

  • Scaling and setup of the VPU clock

  • Bus clock gates

  • Powering up video processing HW blocks

  • Powering Up HDMI controller and PHY

Video Processing Unit

The Amlogic Meson Display controller is composed of several components that are going to be documented below:

DMC|---------------VPU (Video Processing Unit)----------------|------HHI------|
   | vd1   _______     _____________    _________________     |               |
D  |-------|      |----|            |   |                |    |   HDMI PLL    |
D  | vd2   | VIU  |    | Video Post |   | Video Encoders |<---|-----VCLK      |
R  |-------|      |----| Processing |   |                |    |               |
   | osd2  |      |    |            |---| Enci ----------|----|-----VDAC------|
R  |-------| CSC  |----| Scalers    |   | Encp ----------|----|----HDMI-TX----|
A  | osd1  |      |    | Blenders   |   | Encl ----------|----|---------------|
M  |-------|______|----|____________|   |________________|    |               |
___|__________________________________________________________|_______________|

Video Input Unit

VIU Handles the Pixel scanout and the basic Colorspace conversions We handle the following features :

  • OSD1 RGB565/RGB888/xRGB8888 scanout

  • RGB conversion to x/cb/cr

  • Progressive or Interlace buffer scanout

  • OSD1 Commit on Vsync

  • HDR OSD matrix for GXL/GXM

What is missing :

  • BGR888/xBGR8888/BGRx8888/BGRx8888 modes

  • YUV4:2:2 Y0CbY1Cr scanout

  • Conversion to YUV 4:4:4 from 4:2:2 input

  • Colorkey Alpha matching

  • Big endian scanout

  • X/Y reverse scanout

  • Global alpha setup

  • OSD2 support, would need interlace switching on vsync

  • OSD1 full scaling to support TV overscan

Video Post Processing

VPP Handles all the Post Processing after the Scanout from the VIU We handle the following post processings :

  • Postblend, Blends the OSD1 only

    We exclude OSD2, VS1, VS1 and Preblend output

  • Vertical OSD Scaler for OSD1 only, we disable vertical scaler and

    use it only for interlace scanout

  • Intermediate FIFO with default Amlogic values

What is missing :

  • Preblend for video overlay pre-scaling

  • OSD2 support for cursor framebuffer

  • Video pre-scaling before postblend

  • Full Vertical/Horizontal OSD scaling to support TV overscan

  • HDR conversion

Video Encoder

VENC Handle the pixels encoding to the output formats. We handle the following encodings :

  • CVBS Encoding via the ENCI encoder and VDAC digital to analog converter

  • TMDS/HDMI Encoding via ENCI_DIV and ENCP

  • Setup of more clock rates for HDMI modes

What is missing :

  • LCD Panel encoding via ENCL

  • TV Panel encoding via ENCT

VENC paths :

       _____   _____   ____________________
vd1---|     |-|     | | VENC     /---------|----VDAC
vd2---| VIU |-| VPP |-|-----ENCI/-ENCI_DVI-|-|
osd1--|     |-|     | | \                  | X--HDMI-TX
osd2--|_____|-|_____| |  |\-ENCP--ENCP_DVI-|-|
                      |  |                 |
                      |  \--ENCL-----------|----LVDS
                      |____________________|

The ENCI is designed for PAl or NTSC encoding and can go through the VDAC directly for CVBS encoding or through the ENCI_DVI encoder for HDMI. The ENCP is designed for Progressive encoding but can also generate 1080i interlaced pixels, and was initially designed to encode pixels for VDAC to output RGB ou YUV analog outputs. It’s output is only used through the ENCP_DVI encoder for HDMI. The ENCL LVDS encoder is not implemented.

The ENCI and ENCP encoders needs specially defined parameters for each supported mode and thus cannot be determined from standard video timings.

The ENCI end ENCP DVI encoders are more generic and can generate any timings from the pixel data generated by ENCI or ENCP, so can use the standard video timings are source for HW parameters.

Video Clocks

VCLK is the “Pixel Clock” frequency generator from a dedicated PLL. We handle the following encodings :

  • CVBS 27MHz generator via the VCLK2 to the VENCI and VDAC blocks

  • HDMI Pixel Clocks generation

What is missing :

  • Genenate Pixel clocks for 2K/4K 10bit formats

Clock generator scheme :

 __________   _________            _____
|          | |         |          |     |--ENCI
| HDMI PLL |-| PLL_DIV |--- VCLK--|     |--ENCL
|__________| |_________| \        | MUX |--ENCP
                          --VCLK2-|     |--VDAC
                                  |_____|--HDMI-TX

Final clocks can take input for either VCLK or VCLK2, but VCLK is the preferred path for HDMI clocking and VCLK2 is the preferred path for CVBS VDAC clocking.

VCLK and VCLK2 have fixed divided clocks paths for /1, /2, /4, /6 or /12.

The PLL_DIV can achieve an additional fractional dividing like 1.5, 3.5, 3.75... to generate special 2K and 4K 10bit clocks.

HDMI Video Output

HDMI Output is composed of :

  • A Synopsys DesignWare HDMI Controller IP

  • A TOP control block controlling the Clocks and PHY

  • A custom HDMI PHY in order convert video to TMDS signal

 ___________________________________
|            HDMI TOP               |<= HPD
|___________________________________|
|                  |                |
|  Synopsys HDMI   |   HDMI PHY     |=> TMDS
|    Controller    |________________|
|___________________________________|<=> DDC

The HDMI TOP block only supports HPD sensing. The Synopsys HDMI Controller interrupt is routed through the TOP Block interrupt. Communication to the TOP Block and the Synopsys HDMI Controller is done a pair of addr+read/write registers. The HDMI PHY is configured by registers in the HHI register block.

Pixel data arrives in 4:4:4 format from the VENC block and the VPU HDMI mux selects either the ENCI encoder for the 576i or 480i formats or the ENCP encoder for all the other formats including interlaced HD formats. The VENC uses a DVI encoder on top of the ENCI or ENCP encoders to generate DVI timings for the HDMI controller.

GXBB, GXL and GXM embeds the Synopsys DesignWare HDMI TX IP version 2.01a with HDCP and I2C & S/PDIF audio source interfaces.

We handle the following features :

  • HPD Rise & Fall interrupt

  • HDMI Controller Interrupt

  • HDMI PHY Init for 480i to 1080p60

  • VENC & HDMI Clock setup for 480i to 1080p60

  • VENC Mode setup for 480i to 1080p60

What is missing :

  • PHY, Clock and Mode setup for 2k && 4k modes

  • SDDC Scrambling mode for HDMI 2.0a

  • HDCP Setup

  • CEC Management