## Chapter 33 LVDS

#### 33.1 Overview

LVDS transmitter converts a CMOS signal into a low-voltage differential signal. Using a differential signal reduces the system's susceptibility to noise and EMI emissions. In addition, using a differential signal can deliver high speeds. This results in a very cost-effective solution to some of the greatest bandwidth bottlenecks in many transmission applications.

LVDS supports following features:

- Comply with the TIA/EIA-644-A LVDS standard
- Combine LVTTL IO, support LVDS/LVTTL data output
- Support reference clock frequency range from 10Mhz to 148.5Mhz
- Support LVDS RGB 30/24/18bits color data transfer
- Support VESA/JEIDA LVDS data format transfer
- Support LVDS single channel and double channel data transfer, every channel include 4 data lanes and 1 clock lane
- Support MSB mode and LSB mode data transfer
- Support APB slave bus interface
- Support low power mode

# 33.2 Block Diagram



Fig. 33-1 LVDS Block Diagram

Fig.1-1 shows the brief block diagram of the innosilicon LVDS/TTL PHY, which includes ten LVDS P2S modules and one PLL module.

PLL is responsible for multiplying the pin\_pixel\_clk by 7, which generates a 7X clock used to deserialize the parallel data.

LVDS P2S module implements the parallel to serial function and transmits the TTL data directly.

## 33.3 Function Description

#### 33.3.1 Transmitter with Two 35:5 Data Channels



Fig. 33-2 LVDS in SoC

There are two transfer channels in LVDS, every channel include 4 data lanes and 1 clock lane. LVDS can work at single channel mode or double channel mode.

The LVDS output data timing is showed as the following figure,



Fig. 33-3 LVDS output data timing

#### 33.3.2 LVDS Format

Lvdsformat converts VOP RGB interface to LVDS format data. The lvdsformat support RGB 10/8/6bits color data input. There are two lvdsformat modules in the lvds\_top.

When LVDS works at double channel mode, both the lvdsformat modules are necessary. One is for odd cycle RGB data format convert, and the other is for even cycle RGB data format convert. The frequency of LVDS output clock is half of the dclk.

When LVDS works at single channel mode, only one lvdsformat module is necessary. User can configure GRF register to select which lvdsformat converts the VOP RGB data. The frequency of LVDS output clock is equal to the dclk.

Table 33-1 is the MSB mapping relationship between the input data and output data of lvdsformat module (single channel mode). The LSB mapping relationship is opposite to MSB.

| lvds-format | Serial  | Data Rits | Serial RGB10 Bits RGB8 Bits |          |          |          |          |    | RGB6<br>bits |
|-------------|---------|-----------|-----------------------------|----------|----------|----------|----------|----|--------------|
| id          | Channel |           | format-1                    | format-2 | format-1 | format-2 | format-3 |    |              |
| lvds-format | DATA0   | DATA0[0]  | R0                          | R4       | R0       | R2       | R2       | R0 |              |
| *           |         | DATAU     | DATA0[1]                    | R1       | R5       | R1       | R3       | R3 | R1           |

Table 33-1 MSB mapping relationship (single channel mode)

|       | DATA0[2]   | R2    | R6    | R2    | R4    | R4    | R2    |
|-------|------------|-------|-------|-------|-------|-------|-------|
|       | DATA0[3]   | R3    | R7    | R3    | R5    | R5    | R3    |
|       | DATA0[4]   | R4    | R8    | R4    | R6    | R6    | R4    |
|       | DATA0[5]   | R5    | R9    | R5    | R7    | R7    | R5    |
|       | DATA0[6]   | G0    | G4    | G0    | G2    | G2    | G0    |
|       | DATA1[0]   | G1    | G5    | G1    | G3    | G3    | G1    |
|       | DATA1[1]   | G2    | G6    | G2    | G4    | G4    | G2    |
|       | DATA1[2]   | G3    | G7    | G3    | G5    | G5    | G3    |
| DATA  | 1 DATA1[3] | G4    | G8    | G4    | G6    | G6    | G4    |
|       | DATA1[4]   | G5    | G9    | G5    | G7    | G7    | G5    |
|       | DATA1[5]   | В0    | B4    | В0    | B2    | B2    | В0    |
|       | DATA1[6]   | B1    | B5    | B1    | В3    | В3    | B1    |
|       | DATA2[0]   | B2    | В6    | B2    | B4    | B4    | B2    |
|       | DATA2[1]   | В3    | В7    | В3    | B5    | B5    | В3    |
|       | DATA2[2]   | B4    | B8    | B4    | B6    | В6    | B4    |
| DATA  | 2 DATA2[3] | B5    | В9    | B5    | B7    | В7    | B5    |
|       | DATA2[4]   | HSYNC | HSYNC | HSYNC | HSYNC | HSYNC | HSYNC |
|       | DATA2[5]   | VSYNC | VSYNC | VSYNC | VSYNC | VSYNC | VSYNC |
|       | DATA2[6]   | DEN   | DEN   | DEN   | DEN   | DEN   | DEN   |
|       | DATA3[0]   | R6    | R2    | R6    | R0    | GND   | GND   |
|       | DATA3[1]   | R7    | R3    | R7    | R1    | GND   | GND   |
|       | DATA3[2]   | G6    | G2    | G6    | G0    | GND   | GND   |
| DATA  | 3 DATA3[3] | G7    | G3    | G7    | G1    | GND   | GND   |
|       | DATA3[4]   | B6    | B2    | B6    | В0    | GND   | GND   |
|       | DATA3[5]   | В7    | В3    | B7    | B1    | GND   | GND   |
|       | DATA3[6]   | GND   | GND   | GND   | GND   | GND   | GND   |
|       | DATA4[0]   | R8    | R0    | GND   | GND   | GND   | GND   |
|       | DATA4[1]   | R9    | R1    | GND   | GND   | GND   | GND   |
|       | DATA4[2]   | G8    | G0    | GND   | GND   | GND   | GND   |
| DATA  | 4 DATA4[3] | G9    | G1    | GND   | GND   | GND   | GND   |
|       | DATA4[4]   | B8    | B0    | GND   | GND   | GND   | GND   |
|       | DATA4[5]   | B9    | B1    | GND   | GND   | GND   | GND   |
|       | DATA4[6]   | GND   | GND   | GND   | GND   | GND   | GND   |
| CLKOL | JT CLKOUT  | DCLK  | DCLK  | DCLK  | DCLK  | DCLK  | DCLK  |

Table 33-2 is the MSB mapping relationship between the input data and output data of lvdsformat module (double channel mode). The LSB mapping relationship is opposite to MSB.

Table 33-2 MSB mapping relationship (double channel mode)

| lvds-format    | ormat Serial | Data Bits         | RGB1     | 0 Bits   |          | RGB8 Bits |          | RGB6<br>bits |
|----------------|--------------|-------------------|----------|----------|----------|-----------|----------|--------------|
| id             | Channel      | Channel Data Bits | format-1 | format-2 | format-1 | format-2  | format-3 |              |
| lude format    | Luda Carrada | DATA0[0]          | OR0      | OR4      | OR0      | OR2       | OR2      | OR0          |
| lvds-format DA | DATA0        | DATA0 DATA0[1]    | OR1      | OR5      | OR1      | OR3       | OR3      | OR1          |
|                |              | DATA0[2]          | OR2      | OR6      | OR2      | OR4       | OR4      | OR2          |

|                  |        | DATA0[3] | OR3    | OR7    | OR3    | OR5    | OR5    | OR3                                          |
|------------------|--------|----------|--------|--------|--------|--------|--------|----------------------------------------------|
|                  |        | DATA0[4] | OR4    | OR8    | OR4    | OR6    | OR6    | OR4                                          |
|                  |        | DATA0[5] | OR5    | OR9    | OR5    | OR7    | OR7    | OR5                                          |
|                  |        | DATA0[6] | OG0    | OG4    | OG0    | OG2    | OG2    | OG0                                          |
|                  |        | DATA1[0] | OG1    | OG5    | OG1    | OG3    | OG3    | OG1                                          |
|                  |        | DATA1[1] | OG2    | OG6    | OG2    | OG4    | OG4    | OG2                                          |
|                  |        | DATA1[2] | OG3    | OG7    | OG3    | OG5    | OG5    | OG3                                          |
|                  | DATA1  | DATA1[3] | OG4    | OG8    | OG4    | OG6    | OG6    | OG4                                          |
|                  |        | DATA1[4] | OG5    | OG9    | OG5    | OG7    | OG7    | OG5                                          |
|                  |        | DATA1[5] | OB0    | OB4    | OB0    | OB2    | OB2    | OB0                                          |
|                  |        | DATA1[6] | OB1    | OB5    | OB1    | OB3    | OB3    | OB1                                          |
|                  |        | DATA2[0] | OB2    | OB6    | OB2    | OB4    | OB4    | OB2                                          |
|                  |        | DATA2[1] | OB3    | OB7    | OB3    | OB5    | OB5    | OB3                                          |
|                  |        | DATA2[2] | OB4    | OB8    | OB4    | OB6    | OB6    | OB4                                          |
|                  | DATA2  | DATA2[3] | OB5    | OB9    | OB5    | OB7    | OB7    | OB5                                          |
|                  |        | DATA2[4] | HSYNC  | HSYNC  | HSYNC  | HSYNC  | HSYNC  | HSYNC                                        |
|                  |        | DATA2[5] | VSYNC  | VSYNC  | VSYNC  | VSYNC  | VSYNC  | VSYNC                                        |
|                  |        | DATA2[6] | DEN    | DEN    | DEN    | DEN    | DEN    | DEN                                          |
|                  |        | DATA3[0] | OR6    | OR2    | OR6    | OR0    | GND    | GND                                          |
|                  |        | DATA3[1] | OR7    | OR3    | OR7    | OR1    | GND    | GND                                          |
|                  |        | DATA3[2] | OG6    | OG2    | OG6    | OG0    | GND    | GND                                          |
|                  | DATA3  | DATA3[3] | OG7    | OG3    | OG7    | OG1    | GND    | GND                                          |
|                  |        | DATA3[4] | OB6    | OB2    | OB6    | OB0    | GND    | GND                                          |
|                  |        | DATA3[5] | OB7    | OB3    | OB7    | OB1    | GND    | GND                                          |
|                  |        | DATA3[6] | GND    | GND    | GND    | GND    | GND    | GND                                          |
|                  |        | DATA4[0] | OR8    | OR0    | GND    | GND    | GND    | GND                                          |
|                  |        | DATA4[1] | OR9    | OR1    | GND    | GND    | GND    | GND                                          |
|                  |        | DATA4[2] | OG8    | OG0    | GND    | GND    | GND    | GND                                          |
|                  | DATA4  | DATA4[3] | OG9    | OG1    | GND    | GND    | GND    | GND                                          |
|                  |        | DATA4[4] | OB8    | ОВ0    | GND    | GND    | GND    | GND                                          |
|                  |        | DATA4[5] | OB9    | OB1    | GND    | GND    | GND    | GND                                          |
|                  |        | DATA4[6] | GND    | GND    | GND    | GND    | GND    | GND                                          |
|                  | CLKOUT | CLKOUT   | DCLK/2 | DCLK/2 | DCLK/2 | DCLK/2 | DCLK/2 | DCLK/2                                       |
|                  |        | DATA0[0] | ER0    | ER4    | ER0    | ER2    | ER2    | ER0                                          |
|                  |        | DATA0[1] | ER1    | ER5    | ER1    | ER3    | ER3    | ER1                                          |
|                  |        | DATA0[2] | ER2    | ER6    | ER2    | ER4    | ER4    | ER2                                          |
|                  | DATA0  | DATA0[3] | ER3    | ER7    | ER3    | ER5    | ER5    | ER3                                          |
| lvds-format<br>1 |        | DATA0[4] | ER4    | ER8    | ER4    | ER6    | ER6    | ER4                                          |
|                  |        | DATA0[5] | ER5    | ER9    | ER5    | ER7    | ER7    | ER5                                          |
|                  |        | DATA0[6] | EG0    | EG4    | EG0    | EG2    | EG2    | EG0                                          |
|                  |        | DATA1[0] | EG1    | EG5    | EG1    | EG3    | EG3    | EG1                                          |
|                  |        | DATA1[1] | EG2    | EG6    | EG2    | EG4    | EG4    | EG2                                          |
|                  | DATA1  | DATA1[2] | EG3    | EG7    | EG3    | EG5    | EG5    | EG3                                          |
|                  |        | DATA1[3] | EG4    | EG8    | EG4    | EG6    | EG6    | EG4                                          |
|                  |        | DATA1[4] | EG5    | EG9    | EG5    | EG7    | EG7    | EG5                                          |
|                  |        |          |        |        |        |        |        | <u>.                                    </u> |

|       | DATA1[5] | EB0   | EB4   | EB0   | EB2   | EB2   | EB0   |
|-------|----------|-------|-------|-------|-------|-------|-------|
|       | DATA1[6] | EB1   | EB5   | EB1   | EB3   | EB3   | EB1   |
|       | DATA2[0] | EB2   | EB6   | EB2   | EB4   | EB4   | EB2   |
|       | DATA2[1] | EB3   | EB7   | EB3   | EB5   | EB5   | EB3   |
|       | DATA2[2] | EB4   | EB8   | EB4   | EB6   | EB6   | EB4   |
| DATA2 | DATA2[3] | EB5   | EB9   | EB5   | EB7   | EB7   | EB5   |
|       | DATA2[4] | HSYNC | HSYNC | HSYNC | HSYNC | HSYNC | HSYNC |
|       | DATA2[5] | VSYNC | VSYNC | VSYNC | VSYNC | VSYNC | VSYNC |
|       | DATA2[6] | DEN   | DEN   | DEN   | DEN   | DEN   | DEN   |
|       | DATA3[0] | ER6   | ER2   | ER6   | ER0   | GND   | GND   |
|       | DATA3[1] | ER7   | ER3   | ER7   | ER1   | GND   | GND   |
|       | DATA3[2] | EG6   | EG2   | EG6   | EG0   | GND   | GND   |
| DATA3 | DATA3[3] | EG7   | EG3   | EG7   | EG1   | GND   | GND   |
|       | DATA3[4] | EB6   | EB2   | EB6   | EB0   | GND   | GND   |
|       | DATA3[5] | EB7   | EB3   | EB7   | EB1   | GND   | GND   |
|       | DATA3[6] | GND   | GND   | GND   | GND   | GND   | GND   |
|       | DATA4[0] | ER8   | ER0   | GND   | GND   | GND   | GND   |
|       | DATA4[1] | ER9   | ER1   | GND   | GND   | GND   | GND   |
|       | DATA4[2] | EG8   | EG0   | GND   | GND   | GND   | GND   |
| DATA4 | DATA4[3] | EG9   | EG1   | GND   | GND   | GND   | GND   |
|       | DATA4[4] | EB8   | EB0   | GND   | GND   | GND   | GND   |
|       | DATA4[5] | EB9   | EB1   | GND   | GND   | GND   | GND   |
|       | DATA4[6] | GND   | GND   | GND   | GND   | GND   | GND   |

# 33.3.3 GRF Relative Register Description

GRF\_SOC\_CON6[3] (grf\_con\_lvds\_lcdc\_sel):

1'b0: lvds video source from vop0;

1'b1: lvds video source from vop1;

GRF\_SOC\_CON7[2:0] (grf\_lvds\_con\_select):

3'b000: select RGB8 bits format-1;

3'b001: select RGB8 bits format-2;

3'b010: select RGB8 bits format-3;

3'b011: select RGB6 bits format;

3'b100: select RGB10 bits format-1;

3'b101: select RGB10 bits format-2;

GRF\_SOC\_CON7[3] (grf\_lvds\_con\_msbsel):

1'b0: LSB for lvdsformat;

1'b1: MSB for lvds format;

GRF\_SOC\_CON7[4] (grf\_lvds\_con\_chasel):

1'b0: single channel mode;

1'b1: double channel mode;

GRF\_SOC\_CON7[5] (grf\_lvds\_con\_startsel):

- 1'b0: when lvds works at single channel mode, select lvdsformat 0 for RGB data convert;
- 1'b1: when lvds works at single channel mode, select lvdsformat 1 for RGB data convert;

GRF\_SOC\_CON7[6] (grf\_lvds\_con\_ttl\_en):

- 1'b0: disable lvds ttl mode;
- 1'b1: enable lvds ttl mode;

GRF\_SOC\_CON7[7] (grf\_lvds\_con\_startphase):

- 1'b0: dclk\_div2 start phase reset to 0 at beginning of hs;
- 1'b1: dclk\_div2 start phase reset to 1 at beginning of hs;



Fig. 33-4 LVDS h\_bp timing diagram

when h\_bp is odd, grf\_lvds\_con\_startphase need be configured to 1'b1; when h\_bp is even, grf\_lvds\_con\_startphase need be configured to 1'b0; GRF\_SOC\_CON7[8] (grf\_lvds\_con\_clkinv):

- 1'b0: not invert the clock to LVDS from lvds top;
- 1'b1: invert the clock to LVDS from lvds\_top;

GRF\_SOC\_CON7[9] (grf\_lvds\_con\_hs\_polarity):

- 1'b0: hsync polarity low active;
- 1'b1: hsync polarity high active;

GRF\_SOC\_CON7[10] (grf\_lvds\_con\_den\_polarity):

- 1'b0: den polarity high active;
- 1'b1: den polarity low active;

GRF\_SOC\_CON7[11] (grf\_lvds\_con\_enable\_1):

- 1'b0: LVDS channel 1 disable;
- 1'b1: LVDS channel 1 enable;

GRF\_SOC\_CON7[12] (grf\_lvds\_con\_enable\_2):

- 1'b0: LVDS channel 2 disable;
- 1'b1: LVDS channel 2 enable;

GRF\_SOC\_CON7[15] (grf\_lvds\_pwrdwn):

1'b0: LVDS not power down;

1'b1: LVDS power down;

# 33.4 Register Description

This section describes the control/status registers of the design.

# **33.4.1 Registers Summary**

| Name                    | Offset | Size | Reset<br>Value | Description   |
|-------------------------|--------|------|----------------|---------------|
| LVDS_channel0_reg0<br>0 | 0x0000 | W    | 0x000000bf     | LVDS register |
| LVDS_channel0_reg0      | 0x0004 | W    | 0x0000003f     | LVDS register |
| LVDS_channel0_reg0<br>2 | 0x0008 | W    | 0x0000007e     | LVDS register |
| LVDS_channel0_reg0<br>3 | 0x000c | W    | 0x00000046     | LVDS register |
| LVDS_channel0_reg0<br>4 | 0x0010 | W    | 0×00000000     | LVDS register |
| LVDS_channel0_reg0<br>5 | 0x0014 | W    | 0×00000000     | LVDS register |
| LVDS_config_reg0c       | 0x0030 | W    | 0x00000000     | LVDS register |
| LVDS_channel0_reg0      | 0x0034 | w    | 0x00000000     | LVDS register |
| LVDS_channel0_reg2<br>0 | 0x0080 | W    | 0x00000045     | LVDS register |
| LVDS_config_reg21       | 0x0084 | W    | 0x0000000      | LVDS register |
| LVDS_channel1_reg4<br>0 | 0x0100 | W    | 0x000000bf     | LVDS register |
| LVDS_channel1_reg4      | 0x0104 | W    | 0x0000003f     | LVDS register |
| LVDS_channel1_reg4<br>2 | 0x0108 | W    | 0x0000007e     | LVDS register |
| LVDS_channel1_reg4      | 0x010c | W    | 0x00000046     | LVDS register |
| LVDS_channel1_reg4<br>4 | 0x0110 | W    | 0x00000000     | LVDS register |
| LVDS_channel1_reg4 5    | 0x0114 | W    | 0x00000000     | LVDS register |
| LVDS_channel1_reg4      | 0x0134 | W    | 0x0000000a     | LVDS register |
| LVDS_channel1_reg6      | 0x0180 | W    | 0x00000045     | LVDS register |

Notes: <u>Size</u>: **B** - Byte (8 bits) access, **HW** - Half WORD (16 bits) access, **W** -WORD (32 bits) access

# 33.4.2 Detail Register Description

LVDS\_channel0\_reg00

Address: Operational Base + offset (0x0000)

LVDS register

| Bit  | Attr | Reset Value | Description              |
|------|------|-------------|--------------------------|
| 31:8 | RO   | 0x0         | reserved                 |
|      |      |             | lvds_mode_en             |
| 7    | RW   | 0x1         | 1'b1: enable lvds mode;  |
|      |      |             | 1'b0: disable lvds mode; |
|      |      |             | ttl_mode_en              |
| 6    | RW   | 0x0         | 1'b1: enable ttl mode;   |
|      |      |             | 1'b0: disable ttl mode;  |
|      |      |             | lane_en_ck               |
| 5    | RW   | 0x1         | 1'b1: enable lane_ck;    |
|      |      |             | 1'b0: disable lane_ck;   |
|      |      |             | lane_en_4                |
| 4    | RW   | 0x1         | 1'b1: enable lane_4;     |
|      |      |             | 1'b0: disable lane_4;    |
|      |      |             | lane_en_3                |
| 3    | RW   | 0x1         | 1'b1: enable lane_3;     |
|      |      |             | 1'b0: disable lane_3;    |
|      |      |             | lane_en_2                |
| 2    | RW   | 0x1         | 1'b1: enable lane_2;     |
|      |      |             | 1'b0: disable lane_2;    |
|      |      |             | lane_en_1                |
| 1    | RW   | 0x1         | 1'b1: enable lane_1;     |
|      |      |             | 1'b0: disable lane_1;    |
|      |      |             | lane_en_0                |
| 0    | RW   | 0x1         | 1'b1: enable lane_0;     |
|      | A    | 10 .        | 1'b0: disable lane_0;    |

# LVDS\_channel0\_reg01

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                 |
|------|------|-------------|-----------------------------|
| 31:6 | RO   | 0x0         | reserved                    |
|      |      |             | biasen_ck                   |
| 5    | RW   | 0x1         | 1'b1: enable lane_ck bias;  |
|      |      |             | 1'b0: disable lane_ck bias; |
|      |      |             | biasen_4                    |
| 4    | RW   | 0x1         | 1'b1: enable lane_4 bias;   |
|      |      |             | 1'b0: disable lane_4 bias;  |
|      |      |             | biasen_3                    |
| 3    | RW   | 0x1         | 1'b1: enable lane_3 bias;   |
|      |      |             | 1'b0: disable lane_3 bias;  |

| Bit | Attr | Reset Value | Description                |
|-----|------|-------------|----------------------------|
|     |      |             | biasen_2                   |
| 2   | RW   | 0x1         | 1'b1: enable lane_2 bias;  |
|     |      |             | 1'b0: disable lane_2 bias; |
|     |      |             | biasen_1                   |
| 1   | RW   | 0x1         | 1'b1: enable lane_1 bias;  |
|     |      |             | 1'b0: disable lane_1 bias; |
|     |      |             | biasen_0                   |
| 0   | RW   | 0x1         | 1'b1: enable lane_0 bias;  |
|     |      |             | 1'b0: disable lane_0 bias; |

Address: Operational Base + offset (0x0008)

LVDS register

| Bit  | Attr   | Reset Value | Description                      |
|------|--------|-------------|----------------------------------|
| 31:7 | RO     | 0x0         | reserved                         |
|      |        |             | lane_lvds_en_ck                  |
| 6    | RW     | 0x1         | 1'b1: enable lane_ck lvds mode;  |
|      |        |             | 1'b0: disable lane_ck lvds mode; |
|      |        |             | lane_lvds_en_4                   |
| 5    | RW     | 0x1         | 1'b1: enable lane_4 lvds mode;   |
|      |        |             | 1'b0: disable lane_4 lvds mode;  |
|      |        |             | lane_lvds_en_3                   |
| 4    | RW     | 0x1         | 1'b1: enable lane_3 lvds mode;   |
|      |        |             | 1'b0: disable lane_3 lvds mode;  |
|      |        | • 6         | lane_lvds_en_2                   |
| 3    | RW     | 0x1         | 1'b1: enable lane_2 lvds mode;   |
|      |        |             | 1'b0: disable lane_2 lvds mode;  |
|      |        |             | lane_lvds_en_1                   |
| 2    | RW     | 0x1         | 1'b1: enable lane_1 lvds mode;   |
|      |        |             | 1'b0: disable lane_1 lvds mode;  |
|      |        | Y           | lane_lvds_en_0                   |
| 1    | RW     | 0x1         | 1'b1: enable lane_0 lvds mode;   |
|      | $\cup$ |             | 1'b0: disable lane_0 lvds mode;  |
| 0    | RW     | 0x0         | pll_fbdiv_8                      |
| U    | IXVV   | 0.00        | pll_fbdiv[8];                    |

## LVDS\_channel0\_reg03

Address: Operational Base + offset (0x000c)

| Bit  | Attr | Reset Value | Description                         |
|------|------|-------------|-------------------------------------|
| 31:8 | RO   | 0x0         | reserved                            |
| 7:0  | RW   | 0x46        | pll_fbdiv_7_to_0<br>pll_fbdiv[7:0]; |

Address: Operational Base + offset (0x0010)

LVDS register

| Bit  | Attr | Reset Value | Description                     |
|------|------|-------------|---------------------------------|
| 31:6 | RO   | 0x0         | reserved                        |
|      |      |             | lane_ttl_en_ck                  |
| 5    | RW   | 0x0         | 1'b1: enable lane_ck ttl mode;  |
|      |      |             | 1'b0: disable lane_ck ttl mode; |
|      |      |             | lane_ttl_en_4                   |
| 4    | RW   | 0x0         | 1'b1: enable lane_4 ttl mode;   |
|      |      |             | 1'b0: disable lane_4 ttl mode;  |
|      |      |             | lane_ttl_en_3                   |
| 3    | RW   | 0x0         | 1'b1: enable lane_3 ttl mode;   |
|      |      |             | 1'b0: disable lane_3 ttl mode;  |
|      |      |             | lane_ttl_en_2                   |
| 2    | RW   | 0x0         | 1'b1: enable lane_2 ttl mode;   |
|      |      |             | 1'b0: disable lane_2 ttl mode;  |
|      |      |             | lane_ttl_en_1                   |
| 1    | RW   | 0x0         | 1'b1: enable lane_1 ttl mode;   |
|      |      |             | 1'b0: disable lane_1 ttl mode;  |
|      |      |             | lane_ttl_en_0                   |
| 0    | RW   | 0x0         | 1'b1: enable lane_0 ttl mode;   |
|      |      |             | 1'b0: disable lane_0 ttl mode;  |

# LVDS\_channel0\_reg05

Address: Operational Base + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:6 | RO   | 0x0         | reserved                                     |
|      |      |             | lane_ttl_ctr_ck                              |
| 5    | RW   | 0x0         | 1'b1: enable lane_ck ttl data transmission;  |
|      |      |             | 1'b0: disable lane_ck ttl data transmission; |
|      |      |             | lane_ttl_ctr_4                               |
| 4    | RW   | 0x0         | 1'b1: enable lane_4 ttl data transmission;   |
| 12   |      |             | 1'b0: disable lane_4 ttl data transmission;  |
|      |      |             | lane_ttl_ctr_3                               |
| 3    | RW   | 0x0         | 1'b1: enable lane_3 ttl data transmission;   |
|      |      |             | 1'b0: disable lane_3 ttl data transmission;  |
|      |      |             | lane_ttl_ctr_2                               |
| 2    | RW   | 0x0         | 1'b1: enable lane_2 ttl data transmission;   |
|      |      |             | 1'b0: disable lane_2 ttl data transmission;  |
|      |      |             | lane_ttl_ctr_1                               |
| 1    | RW   | 0x0         | 1'b1: enable lane_1 ttl data transmission;   |
|      |      |             | 1'b0: disable lane_1 ttl data transmission;  |
|      |      |             | lane_ttl_ctr_0                               |
| 0    | RW   | 0x0         | 1'b1: enable lane_0 ttl data transmission;   |
|      |      |             | 1'b0: disable lane_0 ttl data transmission;  |

## LVDS\_config\_reg0c

Address: Operational Base + offset (0x0030)

LVDS register

| Bit  | Attr | Reset Value | Description        |
|------|------|-------------|--------------------|
| 31:8 | RO   | 0x0         | reserved           |
| 7.0  | RW   | 1()x()()    | enable_pll         |
| 7:0  |      |             | 8'h00: enable pll; |

## LVDS\_channel0\_reg0d

Address: Operational Base + offset (0x0034)

LVDS register

| Bit  | Attr | Reset Value | Description       |
|------|------|-------------|-------------------|
| 31:5 | RO   | 0x0         | reserved          |
| 4.0  | DW   | 0×0>        | pll_prediv_4_to_0 |
| 4:0  | RW   | 0x0a        | pll_prediv[4:0];  |

## LVDS\_channel0\_reg20

Address: Operational Base + offset (0x0080)

LVDS register

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                  |
| 7:0  | RW   | 0x45        | msb_lsb_sel<br>8'h45: MSB;<br>8'h44: LSB; |

#### LVDS\_config\_reg21

Address: Operational Base + offset (0x0084)

LVDS register

| Bit  | Attr | Reset Value | Description        |
|------|------|-------------|--------------------|
| 31:8 | RO   | 0x0         | reserved           |
|      |      | ,           | enable_tx          |
| 7:0  | RW   | 0x00        | 8'h00: disable tx; |
|      |      |             | 8'h92: enable tx;  |

# LVDS\_channel1\_reg40

Address: Operational Base + offset (0x0100)

| Bit  | Attr | Reset Value | Description              |
|------|------|-------------|--------------------------|
| 31:8 | RO   | 0x0         | reserved                 |
|      |      |             | lvds_mode_en             |
| 7    | RW   | 0x1         | 1'b1: enable lvds mode;  |
|      |      |             | 1'b0: disable lvds mode; |

| Bit | Attr | Reset Value | Description             |
|-----|------|-------------|-------------------------|
|     |      |             | ttl_mode_en             |
| 6   | RW   | 0x0         | 1'b1: enable ttl mode;  |
|     |      |             | 1'b0: disable ttl mode; |
|     |      |             | lane_en_ck              |
| 5   | RW   | 0x1         | 1'b1: enable lane_ck;   |
|     |      |             | 1'b0: disable lane_ck;  |
|     |      |             | lane_en_4               |
| 4   | RW   | 0x1         | 1'b1: enable lane_4;    |
|     |      |             | 1'b0: disable lane_4;   |
|     |      |             | lane_en_3               |
| 3   | RW   | 0x1         | 1'b1: enable lane_3;    |
|     |      |             | 1'b0: disable lane_3;   |
|     |      |             | lane_en_2               |
| 2   | RW   | 0x1         | 1'b1: enable lane_2;    |
|     |      |             | 1'b0: disable lane_2;   |
|     |      |             | lane_en_1               |
| 1   | RW   | 0x1         | 1'b1: enable lane_1;    |
|     |      |             | 1'b0: disable lane_1;   |
|     |      |             | lane_en_0               |
| 0   | RW   | 0x1         | 1'b1: enable lane_0;    |
|     |      |             | 1'b0: disable lane_0;   |

Address: Operational Base + offset (0x0104)
LVDS register

| egister<br><b>Bit</b> | Attr | Reset Value | Description                 |
|-----------------------|------|-------------|-----------------------------|
|                       |      |             | -                           |
| 31:6                  | RO   | 0x0         | reserved                    |
|                       |      |             | biasen_ck                   |
| 5                     | RW   | 0x1         | 1'b1: enable lane_ck bias;  |
|                       |      |             | 1'b0: disable lane_ck bias; |
|                       |      | Y           | biasen_4                    |
| 4                     | RW   | 0x1         | 1'b1: enable lane_4 bias;   |
|                       |      |             | 1'b0: disable lane_4 bias;  |
|                       | ~    |             | biasen_3                    |
| 3                     | RW   | 0x1         | 1'b1: enable lane_3 bias;   |
|                       |      |             | 1'b0: disable lane_3 bias;  |
|                       |      |             | biasen_2                    |
| 2                     | RW   | 0x1         | 1'b1: enable lane_2 bias;   |
|                       |      |             | 1'b0: disable lane_2 bias;  |
|                       |      |             | biasen_1                    |
| 1                     | RW   | 0x1         | 1'b1: enable lane_1 bias;   |
|                       |      |             | 1'b0: disable lane_1 bias;  |
|                       |      |             | biasen_0                    |
| 0                     | RW   | 0x1         | 1'b1: enable lane_0 bias;   |
|                       |      |             | 1'b0: disable lane_0 bias;  |

Address: Operational Base + offset (0x0108)

LVDS register

| Bit  | Attr | Reset Value | Description                      |
|------|------|-------------|----------------------------------|
| 31:7 | RO   | 0x0         | reserved                         |
|      |      |             | lane_lvds_en_ck                  |
| 6    | RW   | 0x1         | 1'b1: enable lane_ck lvds mode;  |
|      |      |             | 1'b0: disable lane_ck lvds mode; |
|      |      |             | lane_lvds_en_4                   |
| 5    | RW   | 0x1         | 1'b1: enable lane_4 lvds mode;   |
|      |      |             | 1'b0: disable lane_4 lvds mode;  |
|      |      |             | lane_lvds_en_3                   |
| 4    | RW   | 0x1         | 1'b1: enable lane_3 lvds mode;   |
|      |      |             | 1'b0: disable lane_3 lvds mode;  |
|      |      |             | lane_lvds_en_2                   |
| 3    | RW   | 0x1         | 1'b1: enable lane_2 lvds mode;   |
|      |      |             | 1'b0: disable lane_2 lvds mode;  |
|      |      |             | lane_lvds_en_1                   |
| 2    | RW   | 0x1         | 1'b1: enable lane_1 lvds mode;   |
|      |      |             | 1'b0: disable lane_1 lvds mode;  |
|      |      |             | lane_lvds_en_0                   |
| 1    | RW   | 0x1         | 1'b1: enable lane_0 lvds mode;   |
|      |      |             | 1'b0: disable lane_0 lvds mode;  |
| 0    | DW   | 0.40        | pll_fbdiv_8                      |
| 0    | RW   | 0x0         | pll_fbdiv[8];                    |

#### LVDS\_channel1\_reg43

Address: Operational Base + offset (0x010c)

LVDS register

| Bit  | Attr | <b>Reset Value</b> | Description                         |
|------|------|--------------------|-------------------------------------|
| 31:8 | RO   | 0x0                | reserved                            |
| 7:0  | RW   | 10x46              | pll_fbdiv_7_to_0<br>pll_fbdiv[7:0]; |

## LVDS\_channel1\_reg44

Address: Operational Base + offset (0x0110)

| Bit  | Attr | Reset Value | Description                     |
|------|------|-------------|---------------------------------|
| 31:6 | RO   | 0x0         | reserved                        |
|      |      |             | lane_ttl_en_ck                  |
| 5    | RW   | 0x0         | 1'b1: enable lane_ck ttl mode;  |
|      |      |             | 1'b0: disable lane_ck ttl mode; |
|      |      |             | lane_ttl_en_4                   |
| 4    | RW   | 0x0         | 1'b1: enable lane_4 ttl mode;   |
|      |      |             | 1'b0: disable lane_4 ttl mode;  |

| Bit | Attr | Reset Value | Description                    |                             |
|-----|------|-------------|--------------------------------|-----------------------------|
|     |      |             | lane_ttl_en_3                  |                             |
| 3   | RW   | 0x0         | 1'b1: enable lane_3 ttl mode;  |                             |
|     |      |             | 1'b0: disable lane_3 ttl mode; |                             |
|     |      |             | lane_ttl_en_2                  |                             |
| 2   | RW   | 0x0         | 1'b1: enable lane_2 ttl mode;  |                             |
|     |      |             | 1'b0: disable lane_2 ttl mode; |                             |
|     |      |             | lane_ttl_en_1                  |                             |
| 1   | RW   | 0x0         | 1'b1: enable lane_1 ttl mode;  |                             |
|     |      |             | 1'b0: disable lane_1 ttl mode; |                             |
|     |      |             | lane_ttl_en_0                  | A                           |
| 0   | RW   | 0x0         | 1'b1: enable lane_0 ttl mode;  |                             |
|     |      |             | 1'b0: disable lane_0 ttl mode; | $\mathcal{O}_{\mathcal{F}}$ |

Address: Operational Base + offset (0x0114)

LVDS register

| Bit  | Attr | Reset Value | Description                                  |
|------|------|-------------|----------------------------------------------|
| 31:6 | RO   | 0x0         | reserved                                     |
|      |      |             | lane_ttl_ctr_ck                              |
| 5    | RW   | 0x0         | 1'b1: enable lane_ck ttl data transmission;  |
|      |      |             | 1'b0: disable lane_ck ttl data transmission; |
|      |      |             | lane_ttl_ctr_4                               |
| 4    | RW   | 0x0         | 1'b1: enable lane_4 ttl data transmission;   |
|      |      |             | 1'b0: disable lane_4 ttl data transmission;  |
|      |      |             | lane_ttl_ctr_3                               |
| 3    | RW   | 0x0         | 1'b1: enable lane_3 ttl data transmission;   |
|      |      |             | 1'b0: disable lane_3 ttl data transmission;  |
|      |      |             | lane_ttl_ctr_2                               |
| 2    | RW   | 0x0         | 1'b1: enable lane_2 ttl data transmission;   |
|      |      |             | 1'b0: disable lane_2 ttl data transmission;  |
|      |      | Y           | lane_ttl_ctr_1                               |
| 1    | RW   | 0x0         | 1'b1: enable lane_1 ttl data transmission;   |
|      |      |             | 1'b0: disable lane_1 ttl data transmission;  |
|      |      |             | lane_ttl_ctr_0                               |
| 0    | RW   | 0x0         | 1'b1: enable lane_0 ttl data transmission;   |
|      |      |             | 1'b0: disable lane_0 ttl data transmission;  |

## LVDS\_channel1\_reg4d

Address: Operational Base + offset (0x0134)

| Bit  | Attr | Reset Value | Description       |
|------|------|-------------|-------------------|
| 31:5 | RO   | 0x0         | reserved          |
| 4:0  | RW   | 0x0a        | pll_prediv_4_to_0 |
|      |      |             | pll_prediv[4:0];  |

Address: Operational Base + offset (0x0180)

LVDS register

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x0         | reserved    |
|      |      |             | msb_lsb_sel |
| 7:0  | RW   | 0x45        | 8'h45: MSB; |
|      |      |             | 8'h44: LSB; |

# 33.5 Interface Description

In RK3288, the LVDS video source comes from vop0 or vop1.

- GRF\_SOC\_CON6[3] == 1'b0, video source from vop0.
- GRF\_SOC\_CON6[3] == 1'b1, video source from vop1.

# 33.6 Application Notes

Following is the operation flow which describes how the software configures the registers to start lvds data transmission.

- Select the video source by GRF register;
- Select single channel mode or double channel mode by GRF register;
- Select data transfer format by GRF register;
- Enable lvds pll by LVDS registers;
- Enable lvds transfer by LVDS registers;