

# **RZ/A2M Group**

Video Display Controller and Sprite Engine Sample Driver

R01AN4475EJ0101 Rev.1.01 Dec 28, 2018

# Introduction

This document describes the functional specification of Video Display Controller (VDC) and Sprite Engine driver for a RZ/A series RZ/A2M group MCU.

# **Target Device**

RZ/A2M

# **Contents**

| 1.  | Specifications                      | 4  |
|-----|-------------------------------------|----|
| 2.  | Operation Confirmation Conditions   | 6  |
| 3.  | Reference Application Notes         | 8  |
| 4.  | Hardware Description                | 8  |
| 4.  | 1 Hardware Configuration            | 8  |
| 4.  | 2 List of Pins to Be Used           | 8  |
| 5.  | Software Description                | 9  |
| 5.  | 1 File Configuration                | 9  |
| 5.2 | 2 Enumeration Type Definitions      | 11 |
| 5.3 | 3 Common Structure Definitions      | 18 |
| 5.4 | 4 Error Codes                       | 19 |
| 5.  | 5 User Custom Parameters            | 20 |
| 5.0 | 6 Compile Switch                    | 22 |
| 5.  | 7 Restrictions                      | 22 |
| 5.8 | 8 VDC Internal Module Configuration | 23 |
| 6.  | Functions Reference                 | 24 |
| 6.  | 1 R_VDC_Initialize                  | 25 |
| 6.2 | 2 R_VDC_Terminate                   | 28 |
| 6.3 | 3 R_VDC_VideoInput                  | 29 |
| 6.4 | 4 R_VDC_SyncControl                 | 33 |
| 6.  | 5 R_VDC_DisplayOutput               | 36 |
| 6.0 | 6 R_VDC_CallbackISR                 | 41 |
| 6.  | 7 R_VDC_WriteDataControl            | 43 |
| 6.8 | 8 R_VDC_ChangeWriteProcess          | 48 |
| 6.9 | 9 R_VDC_ReadDataControl             | 50 |
| 6.  | 10 R_VDC_ChangeReadProcess          | 55 |
| 6.  | 11 R_VDC_StartProcess               | 57 |
| 6.  | 12 R_VDC_StopProcess                | 60 |
| 6.  | 13 R_VDC_ReleaseDataControl         | 61 |
| 6.  | 14 R_VDC_VideoNoiseReduction        | 62 |
| 6.  | 15 R_VDC_ImageColorMatrix           | 64 |
| 6.  | 16 R_VDC_ImageEnhancement           | 68 |
| 6.  | 17 R_VDC_ImageBlackStretch          | 73 |
| 6.  | 18 R_VDC_AlphaBlending              | 75 |
| 6.  | 19 R_VDC_AlphaBlendingRect          | 77 |
| 6.2 | 20 R_VDC_Chromakey                  | 82 |



| 6.21 | R_VDC_CLUT               | 84  |
|------|--------------------------|-----|
| 6.22 | R_VDC_DisplayCalibration | 86  |
| 6.23 | R_VDC_GammaCorrection    | 89  |
| 6.24 | R_VDC_GetISR             | 91  |
| 6.25 | R_SPEA_WindowOffset      | 92  |
| 6.26 | R_SPEA_SetWindow         | 94  |
| 6.27 | R_SPEA_WindowUpdate      | 96  |
| 6.28 | R_RLE_SetWindow          | 97  |
| 6.29 | R_RLE_WindowUpdate       | 100 |
| 7 R  | reference Documents      | 101 |

# 1. Specifications

This driver uses the VDC built in RZ/A2M group to control video input and display.

The functions that this driver supports are listed below.

**Table 1-1 VDC Driver Functions** 

| Item                            | Function                                                                                                                                                       |  |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Input video image specification | 8-bit input conforming to ITU-R BT.656 standard (27 MHz, interlace signal)                                                                                     |  |
|                                 | 8-bit input conforming to ITU-R BT.656 extended standard (27 MHz, progressive signal) *                                                                        |  |
|                                 | 8-bit input conforming to ITU-R BT.601 extended standard (27 MHz, interlace signal) *                                                                          |  |
|                                 | 8-bit input conforming to ITU-R BT.601 extended standard (54 MHz, progressive signal) *                                                                        |  |
|                                 | 16-bit input conforming to ITU-R BT.601 extended standard (13.5 MHz, interlace signal) *                                                                       |  |
|                                 | Digital pin input:<br>YCbCr422, YCbCr444, RGB888, RGB666, and RGB565 video<br>image                                                                            |  |
| Video image recording           | Storing the video image in the YCbCr422/YCbCr444/RGB565/RGB888 format at a rate of 1/1, 1/2, 1/4, or 1/8 field.                                                |  |
| Video image quality adjustment  |                                                                                                                                                                |  |
| Video image scaling/rotation    | Vertical/horizontal scaling: 1/8 to 8 times 0, 90, 180, and 270 degree rotations and horizontal mirroring                                                      |  |
| Graphics planes                 | Graphics planes: 4 planes                                                                                                                                      |  |
|                                 | Supported pixel formats: RGB565, RGB888, ARGB1555, ARGB4444, ARGB8888, RGBA5551, RGBA8888, CLUT8, CLUT4, CLUT1, YCbCr422, YCbCr444                             |  |
| Graphics functions              | Alpha blending in rectangular area (fade-in and fade-out functions are available.)                                                                             |  |
|                                 | Chroma-key                                                                                                                                                     |  |
|                                 | Alpha blending in one pixel units                                                                                                                              |  |
| Output video image size         | Video output size examples:  XGA (1024x768), SVGA (800x600), WVGA (800x480), VGA (640x480), WQVGA (480x240), QVGA landscape (320x240), QVGA portrait (240x320) |  |
| Output video image format       | Progressive video output                                                                                                                                       |  |
|                                 | RGB888 (24-bit parallel output)  PORCO (40-bit parallel output)                                                                                                |  |
|                                 | RGB666 (18-bit parallel output)  PORSES (40-bit parallel output)                                                                                               |  |
|                                 | RGB565 (16-bit parallel output)                                                                                                                                |  |
|                                 | RGB888 (8-bit serial output)                                                                                                                                   |  |
| Panel output adjustment         | Panel brightness/contrast adjustment, RGB gamma correction, dither processing, output format conversion                                                        |  |

Note: The ITU-R BT.656 and 601 standards do not include the description regarding the progressive signal. The ITU-R BT.601 standard does not include the description regarding the connection interface.



Figure 1.1 Operation check conditions

# 2. Operation Confirmation Conditions

The sample code of this application note has been confirmed to operate under the following conditions.

Table 2.1 Peripheral device used(1/2)

| Peripheral device                  | Usage                                                      |
|------------------------------------|------------------------------------------------------------|
| Microcomputer used                 | RZ/A2M                                                     |
| Operating frequency[MHz] (Note)    | CPU Clock (Ιφ) : 528MHz                                    |
|                                    | Image processing clock (Gφ) : 264MHz                       |
|                                    | Internal Bus Clock (Bφ) : 132MHz                           |
|                                    | Peripheral Clock 1 (P1φ) : 66MHz                           |
|                                    | Peripheral Clock 0 (P0φ) : 33MHz                           |
|                                    | QSPI0_SPCLK : 66MHz                                        |
|                                    | CKIO: 132MHz                                               |
| Operating voltage                  | Power supply voltage (I/O): 3.3 V                          |
|                                    | Power supply voltage                                       |
|                                    | (either 1.8V or 3.3V I/O (PVcc SPI)) : 3.3V                |
|                                    | Power supply voltage (internal): 1.2 V                     |
| Integrated development environment | e2 studio V7.3.0                                           |
| C compiler                         | "GNU Arm Embedded Tool chain 6-2017-q2-                    |
| •                                  | update"                                                    |
|                                    | compiler options(except directory path)                    |
|                                    |                                                            |
|                                    | Release:                                                   |
|                                    | -mcpu=cortex-a9 -march=armv7-a                             |
|                                    | -marm -mthumb-interwork -mlittle-endian                    |
|                                    | -mfloat-abi=hard -mfpu=neon                                |
|                                    | -mno-unaligned-access -Os -ffunction-sections              |
|                                    | -fdata-sections -Wunused -Wuninitialized -Wall             |
|                                    | -Wextra -Wmissing-declarations -Wconversion                |
|                                    | -Wpointer-arith -Wpadded -Wshadow -Wlogical-op             |
|                                    | -Waggregate-return -Wfloat-equal                           |
|                                    | <ul><li>-Wnull-dereference -Wmaybe-uninitialized</li></ul> |
|                                    | -Wstack-usage=100 -fabi-version=0                          |
|                                    | Hardware Debug:                                            |
|                                    | -mcpu=cortex-a9 -march=armv7-a -marm                       |
|                                    | -mthumb-interwork -mlittle-endian -mfloat-abi=hard         |
|                                    | -mfpu=neon -mno-unaligned-access -Og                       |
|                                    | -ffunction-sections -fdata-sections -Wunused               |
|                                    | -Wuninitialized -Wall -Wextra                              |
|                                    |                                                            |
|                                    | -Wmissing-declarations -Wconversion                        |
|                                    | -Wpointer-arith -Wpadded -Wshadow                          |
|                                    | -Wlogical-op -Waggregate-return                            |
|                                    | -Wfloat-equal -Wnull-dereference                           |
|                                    | -Wmaybe-uninitialized -g3 -Wstack-usage=100                |
|                                    | -fabi-version=0                                            |

Note: The operating frequency used in clock mode 1 (Clock input of 24MHz from EXTAL pin)

Table 2.2 Peripheral device used(2/2)

| Operation mode                                 | Boot mode 3                                                          |  |
|------------------------------------------------|----------------------------------------------------------------------|--|
|                                                | (Serial Flash boot 3.3V)                                             |  |
| Terminal software communication settings       | Communication speed: 115200bps                                       |  |
|                                                | Data length: 8 bits                                                  |  |
|                                                | Parity: None                                                         |  |
|                                                | Stop bits: 1 bit                                                     |  |
|                                                | Flow control: None                                                   |  |
| Board to be used                               | RZ/A2M CPU board RTK7921053C00000BE                                  |  |
|                                                | RZ/A2M SUB board RTK79210XXB00000BE                                  |  |
| Device (functionality to be used on the board) | Serial flash memory allocated to SPI multi-I/O bus space (channel 0) |  |
|                                                | Manufacturer : Macronix Inc.                                         |  |
|                                                | Model Name: MX25L51245GXD                                            |  |
|                                                | RL78/G1C (This device communications the host                        |  |
|                                                | PC by convert USB Communication and Serial                           |  |
|                                                | Communication.)                                                      |  |

# 3. Reference Application Notes

The application notes related to this application note are shown below.

Nothing.

# 4. Hardware Description

# 4.1 Hardware Configuration

This driver is supposed to be an evaluation board for RZ / A2M

# 4.2 List of Pins to Be Used

Table 4-1 lists the pins to be used and describes their functionalities.

Table 4-1 Pins to Be Used and Their Function

| Symbol        | I/O    | Function                          | Stream it! RZ V2.0            |
|---------------|--------|-----------------------------------|-------------------------------|
| -             |        |                                   | Board connection              |
| DV0_CLK       | Input  | External input clock 0            | NC                            |
| DV0_VSYNC     | Input  | External input Vsync 0            | NC                            |
| DV0_HSYNC     | Input  | External input Hsync 0            | NC                            |
| DV0_DATA23~0  | Input  | External input video image data 0 | NC                            |
| LCD0_CLK      | Output | Panel clock 0                     | PJ_6                          |
| LCD0_DATA23~0 | Output | Video image data 0 for panel      | PB_5-0, PA_7-0, P8_0, PF_7-0, |
|               |        |                                   | PH_2                          |
| LCD0_TCON6~0  | Output | Control signal 0 for panel        | PC_3(TCON4), PC_4(TCON3),     |
|               |        |                                   | P7_7(TCON0)                   |
| LCD0_EXTCLK   | Input  | Panel clock source 0              | PJ_6                          |
| TXCLKOUTM/P   | Output | LVDS clock output pins            | P4_7, P4_6                    |
| TXOUT2M/P     | Output | LVDS data output pins             | P6_1                          |
| TXOUT1M/P     | Output | LVDS data output pins             | P6_2                          |
| TXOUT0M/P     | Output | LVDS data output pins             | P6_3                          |

# 5. Software Description

# 5.1 File Configuration

Table 5-1, Table 5-2 lists the files that make up this driver.

**Table 5-1 VDC Driver File Configuration** 

| File Name                | Description                                                                                                                            |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| r_vdc.c                  | VDC driver API function                                                                                                                |
|                          | Source file defining the VDC driver's API functions                                                                                    |
| r_vdc.h                  | VDC driver API definitions                                                                                                             |
|                          | Header file describing the prototypes of the VDC driver API functions and the parameters that are defined as APIs                      |
| r_vdc_check_parameter.c  | VDC driver parameter check processing                                                                                                  |
|                          | Source file describing the VDC driver's parameter check processing                                                                     |
| r_vdc_check_parameter.h  | VDC driver parameter check definitions                                                                                                 |
|                          | Header file describing the prototypes of the VDC driver's parameter check functions                                                    |
| r_vdc_interrupt.c        | VDC driver interrupt related processing                                                                                                |
|                          | Source file describing the VDC interrupt related setup processing and interrupt service routines                                       |
| r_vdc_register.c         | VDC driver register setup processing                                                                                                   |
|                          | Source file describing the VDC register setup processing                                                                               |
| r_vdc_register.h         | VDC driver register setup definitions                                                                                                  |
|                          | Header file describing the prototypes of the VDC register setup processing functions and the structures of the register address tables |
| r_vdc_register_address.c | VDC driver register address table                                                                                                      |
|                          | File describing the table containing the VDC's register addresses                                                                      |
| r_vdc_shared_param.c     | VDC driver shared parameter processing                                                                                                 |
|                          | Source file describing the setup and retrieval processing for the parameters that are shared inside the VDC driver                     |
| r_vdc_shared_param.h     | VDC driver shared parameter definitions                                                                                                |
|                          | Header file describing the prototypes of VDC driver shared parameter setup/retrieval processing functions                              |
| r_vdc_user.h             | VDC driver user-defined header                                                                                                         |
|                          | Header file defining compile switches and constants that can by statically edited by the user                                          |

**Table 5-2 SPEA Driver File Configuration** 

| ファイル名                    | 説明                                                                                                                                             |  |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|
| r_spea.c                 | SPEA driver API function Source file defining the VDC driver's API functions                                                                   |  |
| r_spea.h                 | SPEA driver API definitions  Header file describing the prototypes of the VDC driver API functions and the parameters that are defined as APIs |  |
| r_spea_check_parameter.c | SPEA driver parameter check processing Source file describing the VDC driver's parameter check processing                                      |  |
| r_spea_check_parameter.h | SPEA driver parameter check definitions  Header file describing the prototypes of the VDC driver's parameter check functions                   |  |
| r_spea_register.c        | SPEA driver register setup processing Source file describing the VDC register setup processing                                                 |  |

| RZ/A2M Group              | Video Display Controller and Sprite Engine Sample Driver                                                                                                                       |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| r_spea_register.h         | SPEA driver register setup definitions  Header file describing the prototypes of the VDC register setup processing functions and the structures of the register address tables |
| r_spea_register_address.c | SPEA driver register address table File describing the table containing the SPEA's register addresses                                                                          |
| r_spea_user.h             | SPEA driver user-defined header  Header file defining compile switches and constants that can by statically edited by the user                                                 |

This driver also references the following external files.

Table 5-3 External Files Referenced by the VDC and SPEA Driver

| File Name    | Description                                |
|--------------|--------------------------------------------|
| r_typedefs.h | Basic type definition header               |
|              | Header file defining the basic types       |
| iodefine.h   | I/O definition header                      |
|              | Header file containing the I/O definitions |

# 5.2 Enumeration Type Definitions

The enumeration type definitions are given below. See 5.4 for the error codes.

### $(1) \quad vdc\_channel\_t$

} vdc\_channel\_t;

```
vdc_channel_t is an enumeration type for representing the VDC channels.
typedef enum
{
    VDC_CHANNEL_0 = 0,
    VDC_CHANNEL_NUM
```

| Enumeration constant | Value | Description        |
|----------------------|-------|--------------------|
| VDC_CHANNEL_0        | 0     | Channel 0          |
| VDC_CHANNEL_NUM      | 1     | Number of channels |

### (2) vdc\_onoff\_t

vdc\_onoff\_t is an enumeration type for representing ON or OFF.

```
typedef enum
{
    VDC_OFF = 0,
    VDC_ON = 1
} vdc_onoff_t;
```

| Enumeration constant | Value | Description |
|----------------------|-------|-------------|
| VDC_OFF              | 0     | OFF         |
| VDC_ON               | 1     | ON          |

### $(3) \quad vdc\_edge\_t$

vdc\_edge\_t is an enumeration type for representing the edge of a signal.

```
typedef enum
{
    VDC_EDGE_RISING = 0,
    VDC_EDGE_FALLING = 1
} vdc_edge_t;
```

| Enumeration constant | Value | Description  |
|----------------------|-------|--------------|
| VDC_EDGE_RISING      | 0     | Rising edge  |
| VDC_EDGE_FALLING     | 1     | Falling edge |

### $(4) \quad vdc\_sig\_pol\_t$

vdc\_sig\_pol\_t is an enumeration type for representing the polarity of a signal.

```
typedef enum
{
    VDC_SIG_POL_NOT_INVERTED = 0,
    VDC_SIG_POL_INVERTED = 1
} vdc_sig_pol_t;
```

| Enumeration constant     | Value | Description  |
|--------------------------|-------|--------------|
| VDC_SIG_POL_NOT_INVERTED | 0     | Not inverted |
| VDC_SIG_POL_INVERTED     | 1     | Inverted     |

### (5) vdc\_scaling\_type\_t

vdc\_scaling\_type\_t is an enumeration type for representing the types of scalers.

```
typedef enum
{
    VDC_SC_TYPE_SC0 = 0,
    VDC_SC_TYPE_NUM
} vdc_scaling_type_t;
```

| Enumeration constant | Value | Description            |
|----------------------|-------|------------------------|
| VDC_SC_TYPE_SC0      | 0     | Scaler 0               |
| VDC_SC_TYPE_NUM      | 1     | Number of scaler types |

### (6) vdc\_graphics\_type\_t

vdc\_graphics\_type\_t is an enumeration type for representing the types of graphics.

```
typedef enum
{
    VDC_GR_TYPE_GR0 = 0,
    VDC_GR_TYPE_GR2,
    VDC_GR_TYPE_GR3,
    VDC_GR_TYPE_NUM
} vdc_graphics_type_t;
```

| Enumeration constant | Value | Description        |
|----------------------|-------|--------------------|
| VDC_GR_TYPE_GR0      | 0     | Graphics 0         |
| VDC_GR_TYPE_GR2      | 1     | Graphics 2         |
| VDC_GR_TYPE_GR3      | 2     | Graphics 3         |
| VDC_GR_TYPE_NUM      | 3     | Number of graphics |

### (7) vdc\_layer\_id\_t

vdc\_layer\_id\_t is an enumeration type for representing the layer ID.

| Enumeration constant | Value | Description               |
|----------------------|-------|---------------------------|
| VDC_LAYER_ID_ALL     | -1    | All layers                |
| VDC_LAYER_ID_0_WR    | 0     | Write process for layer 0 |
| VDC_LAYER_ID_0_RD    | 1     | Read process for layer 0  |
| VDC_LAYER_ID_2_RD    | 2     | Read process for layer 2  |
| VDC_LAYER_ID_3_RD    | 3     | Read process for layer 3  |
| VDC_LAYER_ID_NUM     | 4     | Number of layer IDs       |

The VDC has three layers (graphics 0 (layer 0), graphics 2 (layer 2), and graphics 3 (layer 3)). Of the VDC's internal blocks, scaler 0 corresponds to graphics 0, and the two image synthesizer blocks correspond to graphics 2 and graphics 3, respectively.

The scaler can be divided into the former stage for writing the input data and the latter stage for reading data from memory (see A in Figure 5-1). The former stage of the scaler performs scale-down and rotation processing on the input image data and writes the results into memory. The latter stage of the scaler performs scale-up processing on the data that is read from memory. Different layer IDs, which are defined in the enumeration type vdc\_layer\_id\_t, are assigned to the memory write processing and read processing for the same layer.

The image data read from memory and the image data from the lower layer can be blended in the image synthesizer (see B in Figure 5-1).



Figure 5-1 Memory Write/Read Processing

The results of image synthesis among layers look like as shown in Figure 5-2. Layer 0 is the bottom layer and layer 3 is the top layer.



Figure 5-2 Layers and Image Synthesis

### (8) vdc\_int\_type\_t

```
vdc_int_type_t is an enumeration type for representing the types of VDC interrupts.
```

```
typedef enum
{
    VDC_INT_TYPE_SO_VI_VSYNC = 0,
    VDC_INT_TYPE_SO_LO_VSYNC,
    VDC_INT_TYPE_SO_VSYNCERR,
    VDC_INT_TYPE_VLINE,
    VDC_INT_TYPE_VLINE,
    VDC_INT_TYPE_IV1_VBUFERR,
    VDC_INT_TYPE_IV3_VBUFERR,
    VDC_INT_TYPE_IV5_VBUFERR,
    VDC_INT_TYPE_IV6_VBUFERR,
    VDC_INT_TYPE_SO_WLINE,
    VDC_INT_TYPE_NUM
} vdc_int_type_t;
```

| Enumeration constant     | Value | Description                                                                     |
|--------------------------|-------|---------------------------------------------------------------------------------|
| VDC_INT_TYPE_S0_VI_VSYNC | 0     | Vsync signal input to scaler 0                                                  |
| VDC_INT_TYPE_S0_LO_VSYNC | 1     | Vsync signal output from scaler 0                                               |
| VDC_INT_TYPE_S0_VSYNCERR | 2     | Missing Vsync signal for scaler 0                                               |
| VDC_INT_TYPE_VLINE       | 3     | Specified line signal for panel output in graphics 3                            |
| VDC_INT_TYPE_S0_VFIELD   | 4     | Field end signal for recording function in scaler 0                             |
| VDC_INT_TYPE_IV1_VBUFERR | 5     | Frame buffer write overflow signal for scaler 0                                 |
| VDC_INT_TYPE_IV3_VBUFERR | 6     | Frame buffer read underflow signal for graphics 0                               |
| VDC_INT_TYPE_IV5_VBUFERR | 7     | Frame buffer read underflow signal for graphics 2                               |
| VDC_INT_TYPE_IV6_VBUFERR | 8     | Frame buffer read underflow signal for graphics 3                               |
| VDC_INT_TYPE_S0_WLINE    | 9     | Write specification line signal input to scaling-down control block in scaler 0 |
| VDC_INT_TYPE_NUM         | 10    | Number of VDC interrupt types                                                   |

### $(9) \quad vdc\_gr\_disp\_sel\_t$

vdc\_gr\_disp\_sel\_t is an enumeration type for representing the graphics display modes.

```
typedef enum
{
    VDC_DISPSEL_IGNORED = -1,
    VDC_DISPSEL_BACK = 0,
    VDC_DISPSEL_LOWER = 1,
    VDC_DISPSEL_CURRENT = 2,
    VDC_DISPSEL_BLEND = 3,
    VDC_DISPSEL_NUM = 4
} vdc_gr_disp_sel_t;
```

| Enumeration constant | Value | Description                                                  |
|----------------------|-------|--------------------------------------------------------------|
| VDC_DISPSEL_IGNORED  | -1    | Ignored, no change made                                      |
| VDC_DISPSEL_BACK     | 0     | Background color display                                     |
| VDC_DISPSEL_LOWER    | 1     | Lower-layer graphics display                                 |
| VDC_DISPSEL_CURRENT  | 2     | Current graphics display                                     |
| VDC_DISPSEL_BLEND    | 3     | Blended display of lower-layer graphics and current graphics |

| VDC_DISPSEL_NUM | 4 | Number of graphics display modes |
|-----------------|---|----------------------------------|

### (10) $vdc_imgimprv_id_t$

vdc\_imgimprv\_id\_t is an enumeration type for representing the image quality improvers.

```
typedef enum
{
    VDC_IMG_IMPRV_0 = 0,
    VDC_IMG_IMPRV_NUM
} vdc_imgimprv_id_t;
```

| Enumeration constant | Value | Description                       |
|----------------------|-------|-----------------------------------|
| VDC_IMG_IMPRV_0      | 0     | Image quality improver 0          |
| VDC_IMG_IMPRV_NUM    | 1     | Number of image quality improvers |

### (11) spea\_onoff\_t

spea\_onoff\_t is an enumeration type for representing ON or OFF. It is used to set ON / OFF of SPEA's Window.

```
typedef enum
{
    SPEA_OFF = 0,
    SPEA_ON = 1
} spea_onoff_t;
```

| Enumeration constant | Value | Description |
|----------------------|-------|-------------|
| SPEA_OFF             | 0     | OFF         |
| SPEA_ON              | 1     | ON          |

### (12) $rle\_onoff\_t$

rle\_onoff\_t is an enumeration type for representing ON or OFF. It is used to set ON / OFF of RLE function.

```
typedef enum
{
    RLE_OFF = 0,
    RLE_ON = 1
} rle_onoff_t;
```

| Enumeration constant | Value | Description |
|----------------------|-------|-------------|
| RLE_OFF              | 0     | OFF         |
| RLE_ON               | 1     | ON          |

### (13) **spea\_window\_id\_t**

spea\_window\_id\_t is an enumerated type representing SPEA's Window ID. A maximum of 15 windows can be created per SPEA layer.

```
typedef enum
    WINDOW_00 = 0,
    WINDOW_01,
   WINDOW_02,
   WINDOW_03,
   WINDOW_04,
   WINDOW_05,
   WINDOW_06,
   WINDOW_07,
   WINDOW_08,
   WINDOW_09,
   WINDOW_10,
   WINDOW_11,
   WINDOW_12,
   WINDOW_13,
   WINDOW_14,
   WINDOW_15,
   WINDOW_NUM
} spea_window_id_t;
```

| Enumeration constant | Value | Description                    |
|----------------------|-------|--------------------------------|
| WINDOW_00            | 0     | SPEA Ø Window ID (Lower layer) |
| WINDOW_01            | 1     | SPEA Ø Window ID               |
| WINDOW_02            | 2     | SPEA Ø Window ID               |
| WINDOW_03            | 3     | SPEA Ø Window ID               |
| WINDOW_04            | 4     | SPEA Ø Window ID               |
| WINDOW_05            | 5     | SPEA Ø Window ID               |
| WINDOW_06            | 6     | SPEA Ø Window ID               |
| WINDOW_07            | 7     | SPEA Ø Window ID               |
| WINDOW_08            | 8     | SPEA Ø Window ID               |
| WINDOW_09            | 9     | SPEA Ø Window ID               |
| WINDOW_10            | 10    | SPEA Ø Window ID               |
| WINDOW_11            | 11    | SPEA Ø Window ID               |
| WINDOW_12            | 12    | SPEA Ø Window ID               |
| WINDOW_13            | 13    | SPEA Ø Window ID               |
| WINDOW_14            | 14    | SPEA Ø Window ID               |
| WINDOW_15            | 15    | SPEA Ø Window ID (Top layer)   |

# 5.3 Common Structure Definitions

### (1) vdc\_period\_rect\_t

vdc\_period\_rect\_t is a structure for representing the horizontal/vertical timing of the VDC signals.

```
typedef struct
{
    uint16_t    vs;
    uint16_t    vw;
    uint16_t    hs;
    uint16_t    hw;
} vdc_period_rect_t;
```

# Type Member Name uint16\_t vs uint16\_t vw uint16\_t uint16\_t t wint16\_t t wint16\_t t wint16\_t t hs Uertical signal start position from the reference signal (lines) Vertical signal width (lines) Vertical signal width (lines) Horizontal signal start position from the reference signal (clock cycles) Horizontal signal width (clock cycles) hw

The horizontal/vertical timings in the vdc\_period\_rect\_t structure are represented as a rectangle area as shown in Figure 5-3.



Figure 5-3 Rectangle Representing the Horizontal and Vertical Timings

# 5.4 Error Codes

Table 5-4 shows a list of error codes of the VDC driver.

Table 5-4 List of VDC Driver Error Codes

| Error Code                 | Value | Description (Error Type)                                                                                                                |
|----------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------|
| VDC_OK                     | 0     | Normal termination                                                                                                                      |
| VDC_ERR_PARAM_CHANNEL      | 1     | Invalid channel error (parameter error) An illegal channel is specified.                                                                |
| VDC_ERR_PARAM_LAYER_ID     | 2     | Invalid layer ID error (parameter error) An illegal layer ID is specified.                                                              |
| VDC_ERR_PARAM_NULL         | 3     | NULL specification error (parameter error)  NULL is specified for a required parameter.                                                 |
| VDC_ERR_PARAM_BIT_WIDTH    | 4     | Bit width error (parameter error)  A value exceeding the possible bit width is specified.                                               |
| VDC_ERR_PARAM_UNDEFINED    | 5     | Undefined parameter error (parameter error)  A value that is not defined in the specification is specified.                             |
| VDC_ERR_PARAM_EXCEED_RANGE | 6     | Out-of-value-range error (parameter error)  The specified parameter value is beyond the value range defined in the specification.       |
| VDC_ERR_PARAM_CONDITION    | 7     | Unauthorized condition error (parameter error)  A parameter is specified under conditions that are not authorized by the specification. |
| VDC_ERR_IF_CONDITION       | 8     | Interface condition error (interface error) An API function is called under unauthorized conditions.                                    |
| VDC_ERR_RESOURCE_CLK       | 9     | Clock resource error (resource error)  No panel clock is set up.                                                                        |
| VDC_ERR_RESOURCE_VSYNC     | 10    | Vertical sync signal resource error (resource error) No vertical sync signal is set up.                                                 |
| VDC_ERR_RESOURCE_INPUT     | 11    | Input signal resource error (resource error)  No video image input is set up.                                                           |
| VDC_ERR_RESOURCE_OUTPUT    | 12    | Output resource error (resource error)  No display output is set up.                                                                    |
| VDC_ERR_RESOURCE_LVDS_CLK  | 13    | LVDS clock resource error (resource error) No LVDS clock is set up                                                                      |
| VDC_ERR_RESOURCE_LAYER     | 14    | Layer resource error (resource error)  The specified layer is under unavailable conditions.                                             |
| VDC_ERR_NUM                | 15    | VDC driver error code number                                                                                                            |

Table 5-5 shows a list of error codes of the VDC driver.

Table 5-5 List of SPEA Driver Error Codes

| Error Code              | Value | Description (Error Type)                                                                                                                |
|-------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------|
| SPEA_OK                 | 0     | Normal termination                                                                                                                      |
| SPEA_ERR_PARAM_LAYER_ID | 1     | Invalid layer ID error (parameter error) An illegal layer ID is specified.                                                              |
| SPEA_ERR_PARAM_NULL     | 2     | NULL specification error (parameter error)  NULL is specified for a required parameter.                                                 |
| SPEA_ERR_PARAM          | 3     | Unauthorized condition error (parameter error)  A parameter is specified under conditions that are not authorized by the specification. |

### 5.5 User Custom Parameters

Parameters that can statically be changed by the user are defined in "r\_vdc\_user.h" for this driver.

### (1) Enumeration type vdc\_colcnv\_rgb\_ycbcr\_t

vdc\_colcnv\_rgb\_ycbcr\_t is an enumeration type for representing the color matrix values. It is referenced by the VDC driver when converting GBR signals to YCbCr signals. The default values are the standard values that are described in the hardware manual.

```
typedef enum
{
    VDC_COLORCONV_Y_R = (77u),
    VDC_COLORCONV_Y_G = (150u),
    VDC_COLORCONV_Y_B = (29u),
    VDC_COLORCONV_CB_R = (2005u),
    VDC_COLORCONV_CB_G = (1963u),
    VDC_COLORCONV_CB_B = (128u),
    VDC_COLORCONV_CR_R = (128u),
    VDC_COLORCONV_CR_G = (1941u),
    VDC_COLORCONV_CR_B = (2027u)
} vdc_colorv_rgb_ycbcr_t;
```

| Enumeration constant | Value | Description                                                |
|----------------------|-------|------------------------------------------------------------|
| VDC_COLORCONV_Y_R    | 77u   | Cr/R Signal Gain Adjustment for Y/G Signal Output(0.299)   |
| VDC_COLORCONV_Y_G    | 150u  | Y/G Signal Gain Adjustment for Y/G Signal Output(0.587)    |
| VDC_COLORCONV_Y_B    | 29u   | Cb/B Signal Gain Adjustment for Y/G Signal Output(0.114)   |
| VDC_COLORCONV_CB_R   | 2005u | Cr/R Signal Gain Adjustment for Cb/B Signal Output(-0.169) |
| VDC_COLORCONV_CB_G   | 1963u | Y/G Signal Gain Adjustment for Cb/B Signal Output(-0.331)  |
| VDC_COLORCONV_CB_B   | 128u  | Cb/B Signal Gain Adjustment for Cb/B Signal Output(0.500)  |
| VDC_COLORCONV_CR_R   | 128u  | Cr/R Signal Gain Adjustment for Cr/R Signal Output(0.500)  |
| VDC_COLORCONV_CR_G   | 1941u | Y/G Signal Gain Adjustment for Cr/R Signal Output(-0.419)  |
| VDC_COLORCONV_CR_B   | 2027u | Cb/B Signal Gain Adjustment for Cr/R Signal Output(-0.081) |

Note: The values are represented by 2's complement of the 11-bit values.

 $(-1024 \sim +1023[LSB], 256[LSB] = 1.0[time])$ 



### (2) Enumeration type vdc\_colcnv\_ycbcr\_rgb\_t

vdc\_colcnv\_ycbcr\_rgb\_t is an enumeration type for representing the color matrix values. It is referenced by the VDC driver when converting YCbCr signals to GBR signals. The default values are the standard values that are described in the hardware manual.

```
typedef enum
{
    VDC_COLORCONV_G_Y = (256u),
    VDC_COLORCONV_G_CB = (1960u),
    VDC_COLORCONV_B_CR = (1865u),
    VDC_COLORCONV_B_Y = (256u),
    VDC_COLORCONV_B_CB = (454u),
    VDC_COLORCONV_B_CR = (0u),
    VDC_COLORCONV_R_Y = (256u),
    VDC_COLORCONV_R_CB = (0u),
    VDC_COLORCONV_R_CB = (0u),
    VDC_COLORCONV_R_CR = (359u)
} vdc_colcnv_ycbcr_rgb_t;
```

| Enumeration constant | Value | Description                                               |
|----------------------|-------|-----------------------------------------------------------|
| VDC_COLORCONV_G_Y    | 256u  | Cr/R Signal Gain Adjustment for Y/G Signal Output(1.000)  |
| VDC_COLORCONV_G_CB   | 1960u | Y/G Signal Gain Adjustment for Y/G Signal Output(-0.344)  |
| VDC_COLORCONV_G_CR   | 1865u | Cb/B Signal Gain Adjustment for Y/G Signal Output(-0.714) |
| VDC_COLORCONV_B_Y    | 256u  | Cr/R Signal Gain Adjustment for Cb/B Signal Output(1.000) |
| VDC_COLORCONV_B_CB   | 454u  | Y/G Signal Gain Adjustment for Cb/B Signal Output(1.772)  |
| VDC_COLORCONV_B_CR   | 0u    | Cb/B Signal Gain Adjustment for Cb/B Signal Output(0.000) |
| VDC_COLORCONV_R_Y    | 256u  | Cr/R Signal Gain Adjustment for Cr/R Signal Output(1.000) |
| VDC_COLORCONV_R_CB   | 0u    | Y/G Signal Gain Adjustment for Cr/R Signal Output(0.000)  |
| VDC_COLORCONV_R_CR   | 359u  | Cb/B Signal Gain Adjustment for Cr/R Signal Output(1.402) |

Note: The values are represented by 2's complement of the 11-bit values.

 $(-1024 \sim +1023[LSB], 256[LSB] = 1.0[time])$ 

### (3) Constant definitions

The constants are described below.

| Constant                  | Value | Description                                                                                                                                                                                                     |
|---------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VDC_COLORCONV_DC_OFFSET   | 128u  | Offset (DC) adjustment values for the Y/G, B, R signals in a color matrix Unsigned (0 (-128) to 255 (+127), 128[LSB] = 0) Referenced by the VDC driver when setting up the color matrix.                        |
| VDC_COLORCONV_1TIMES_GAIN | 256u  | 1.0[time] gain value for the color matrix -1024 to +1023[LSB], 256[LSB] = 1.0[time] Referenced by the VDC driver when converting YCbCr signals to YCbCr signals and when converting GBR signals to GBR signals. |
| VDC_GAM_GAIN_ADJ_NUM      | 32u   | The number of the gamma correction gain coefficient for each signal                                                                                                                                             |
| VDC_GAM_START_TH_NUM      | 31u   | The number of the gamma correction start threshold for each signal                                                                                                                                              |

### 5.6 Compile Switch

The following compile switch is defined in "r\_vdc\_user.h" for this driver.

### **Table 5-6 Compile Switch**

| Compile Switch         | Description                                                                                                                                                                                                                                               |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R_VDC_CHECK_PARAMETERS | Enabling this definition causes the parameter check of the VDC driver API functions when they are called. If an error is found as the result of the parameter check, an error code indicating a parameter error is returned. See 5.4 for the error codes. |

### 5.7 Restrictions

### (1) Reserved words

The prefixes listed below are appended to the symbols such as function and variable names to be used for this driver to distinguish the driver program from other programs. Do not use in your program any names that begin with the following symbols, regardless of whether they are in upper or lower case:

- R\_VDC
- VDC
- R\_SPEA
- SPEA

### (2) Register update

Any updates on the settings of most of the VDC registers are reflected on the rising edge of the vertical sync signal. Consequently, a time equivalent to up to 1 cycle of the vertical sync signal will be taken for the setting of a value to be reflected.

### (3) Reentrancy

The APIs of this driver are not reentrant. The driver is likely to behave in an unexpected manner if one of its APIs is called by two or more tasks or interrupt processing routines asynchronously. Great care must be exercised with respect to the calling program of this driver and the call timing.

### (4) Register accesses

This driver does not provide the user with any means of accessing all of the VDC registers. Some VDC registers are automatically set up by the driver itself.

# 5.8 VDC Internal Module Configuration

Figure 5-4 shows the internal modules of the VDC and shows data flow.



Figure 5-4 VDC Internal Module Configuration

The VDC in the RZ/A2M is made up of 6 blocks.

- 1. Input Controller:
  - Subjects the signals to synchronization adjustment and adjusts the input image signals.
- 2. Scaler 0: Graphics 0
  - Scaling and rotation of the input video image
- 3. Image Quality Improver 0:
  - Image quality improvement, color conversion through color matrix function
- 4. Image Synthesizer: Graphics 2, graphics 3
  - Synthesis of graphics planes
- 5. Output Controller:
  - Output image adjustment, output format conversion, control signal output for TFT-LCD panel
- 6. System Controller:
  - Interrupt control, panel clock control

# 6. Functions Reference

The API functions of the VDC driver are listed in Table 6-1.

**Table 6-1 List of API Functions** 

| Function name             | Section | Outline                                          |
|---------------------------|---------|--------------------------------------------------|
| R_VDC_Initialize          | 6.1     | VDC driver initialization                        |
| R_VDC_Terminate           | 6.2     | VDC driver termination                           |
| R_VDC_VideoInput          | 6.3     | Video input setup                                |
| R_VDC_SyncControl         | 6.4     | Synchronization control setup                    |
| R_VDC_DisplayOutput       | 6.5     | Display output setup                             |
| R_VDC_CallbackISR         | 6.6     | Interrupt callback setup                         |
| R_VDC_WriteDataControl    | 6.7     | Data write control processing                    |
| R_VDC_ChangeWriteProcess  | 6.8     | Data write change processing                     |
| R_VDC_ReadDataControl     | 6.9     | Data read control processing                     |
| R_VDC_ChangeReadProcess   | 6.10    | Data read change processing                      |
| R_VDC_StartProcess        | 6.11    | Data write/read start processing                 |
| R_VDC_StopProcess         | 6.12    | Data write/read stop processing                  |
| R_VDC_ReleaseDataControl  | 6.13    | Data write/read control release processing       |
| R_VDC_VideoNoiseReduction | 6.14    | Noise reduction setup                            |
| R_VDC_ImageColorMatrix    | 6.15    | Color matrix setup                               |
| R_VDC_ImageEnhancement    | 6.16    | Image enhancement processing                     |
| R_VDC_ImageBlackStretch   | 6.17    | Black stretch setup                              |
| R_VDC_AlphaBlending       | 6.18    | Alpha blending setup                             |
| R_VDC_AlphaBlendingRect   | 6.19    | Rectangle alpha blending setup                   |
| R_VDC_Chromakey           | 6.20    | Chroma key setup                                 |
| R_VDC_CLUT                | 6.21    | CLUT setup                                       |
| R_VDC_DisplayCalibration  | 6.22    | Display calibration processing                   |
| R_VDC_GammaCorrection     | 6.23    | Gamma correction setup                           |
| R_VDC_GetISR              | 6.24    | Interrupt service routine acquisition processing |

The API functions of the SPEA driver are listed in Table 6-2.

Table 6-2 List of API Functions

| Section | Outline                                     |
|---------|---------------------------------------------|
| 6.25    | Setting the coordinate offset of the window |
| 6.26    | Setting Window Parameters                   |
| 6.27    | Window parameter update request             |
| 6.28    | Setting the RLE parameter                   |
| 6.29    | RLE parameter update request                |
|         | 6.25<br>6.26<br>6.27<br>6.28                |

### 6.1 **R\_VDC\_Initialize**

| Synopsis     | VDC driver initialization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Declaration  | vdc_error_t R_VDC_Initialize(     const vdc_channel_t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         — VDC_CHANNEL_0: Channel 0         Specify channel 0 in this driver.</li> <li>vdc_init_t * param: Initialization parameter</li> <li>void (* init_func)(uint32_t): Pointer to a user-defined function         Specify the user-implemented function that is to be executed together with the VDC         driver initialization processing. Within the API function R_VDC_Initialize, this function         is called before the VDC registers are set up. user_num is used as the argument when         the function is called. Specify '0' when this function is not required.</li> <li>uint32_t user_num: User defined number         Specify the argument to be passed to the user-defined function init_func. This         parameter is ignored if '0' is specified as the user-defined function.</li> </ul> |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

### Details

### (1) **Function**

This function initializes the VDC driver and performs the following associated processing:

- Initializes the VDC driver's internal variables.
- Calls the user-defined function specified in init\_func.
- Sets up and enables the VDC's panel clock.
- Disables all the VDC interrupts.

### Use conditions

The following steps of processing need to be performed before the VDC driver is started:

- Supply of a clock to the VDC modules
- Setup of VDC-related interrupts (interrupt service routine, interrupt priority)
- Setup of VDC-related I/O ports
- Environment-specific setup necessary for the LCD panel and video input

Execute the above-listed steps except for setup of I/O ports for the LCD panel output before calling this function or implement a function that performs the above-listed steps and specify it in init\_func as a user-defined function.

### (3) Parameter details

The members of the vdc\_init\_t structure is described below.

```
typedef struct
  vdc_panel_clksel_t panel_icksel;
  vdc_panel_clk_dcdr_t panel_dcdr;
  } vdc_init_t;
```

| Type<br>Member Name  | Description                                                                                      |
|----------------------|--------------------------------------------------------------------------------------------------|
| vdc_panel_clksel_t   | Panel clock select                                                                               |
| panel_icksel         | <ul> <li>VDC_PANEL_ICKSEL_IMG_DV:<br/>Frequency-divided video image clock (DV_CLK)</li> </ul>    |
|                      | <ul> <li>VDC_PANEL_ICKSEL_EXT_0:<br/>Frequency-divided external clock 0 (LCD0_EXTCLK)</li> </ul> |
|                      | <ul> <li>VDC_PANEL_ICKSEL_PERI:<br/>Frequency-divided peripheral clock 1 (P1φ)</li> </ul>        |
| vdc_panel_clk_dcdr_t | Clock frequency division ratio                                                                   |
| panel_dcdr           | <ul><li>VDC_PANEL_CLKDIV_1_1: 1/1</li></ul>                                                      |
|                      | <ul><li>VDC_PANEL_CLKDIV_1_2: 1/2</li></ul>                                                      |
|                      | <ul><li>VDC_PANEL_CLKDIV_1_3: 1/3</li></ul>                                                      |
|                      | <ul><li>VDC_PANEL_CLKDIV_1_4: 1/4</li></ul>                                                      |
|                      | <ul><li>VDC_PANEL_CLKDIV_1_5: 1/5</li></ul>                                                      |
|                      | <ul><li>VDC_PANEL_CLKDIV_1_6: 1/6</li></ul>                                                      |
|                      | <ul><li>VDC_PANEL_CLKDIV_1_7: 1/7</li></ul>                                                      |
|                      | <ul><li>VDC_PANEL_CLKDIV_1_8: 1/8</li></ul>                                                      |
|                      | <ul><li>VDC_PANEL_CLKDIV_1_9: 1/9</li></ul>                                                      |
|                      | <ul> <li>VDC_PANEL_CLKDIV_1_12: 1/12</li> </ul>                                                  |
|                      | <ul> <li>VDC_PANEL_CLKDIV_1_16: 1/16</li> </ul>                                                  |
|                      | <ul> <li>VDC_PANEL_CLKDIV_1_24: 1/24</li> </ul>                                                  |
|                      | <ul> <li>VDC_PANEL_CLKDIV_1_32: 1/32</li> </ul>                                                  |
| const vdc_lvds_t *   | LVDS-related parameter                                                                           |
| lvds                 | Specify NULL if this parameter is not required.                                                  |

The members of the vdc\_lvds\_t structure is described below.

```
typedef struct
{
    vdc_lvds_in_clk_sel_t lvds_in_clk_sel;
    vdc_lvds_ndiv_t lvds_idiv_set; /* Not use */
    uint16_t lvdspll_tst; /* Not use */
    vdc_lvds_ndiv_t lvds_odiv_set;
    vdc_channel_t lvds_vdc_sel;
    uint16_t lvdspll_fd;
    uint16_t lvdspll_rd;
    vdc_lvds_pll_nod_t lvdspll_od; /* Not use */
} vdc_lvds_t;
```

# Туре

### Description

| Member Name           | Description                                                                        |
|-----------------------|------------------------------------------------------------------------------------|
| vdc_lvds_in_clk_sel_t | Clock input to frequency divider 1                                                 |
| lvds_in_clk_sel       | <ul> <li>VDC_LVDS_INCLK_SEL_DV_0: DV0_CLK0</li> </ul>                              |
|                       | <ul> <li>VDC_LVDS_INCLK_SEL_EXT_0: LCD0_EXTCLK</li> </ul>                          |
|                       | <ul> <li>VDC_LVDS_INCLK_SEL_PERI: P1φ</li> </ul>                                   |
| vdc_lvds_ndiv_t       | Frequency dividing value (NIDIV) for frequency divider 1(Not use)                  |
| lvds_idiv_set         | <ul><li>VDC_LVDS_NDIV_1: NIDIV = 1</li></ul>                                       |
|                       | <ul><li>VDC_LVDS_NDIV_2: NIDIV = 2</li></ul>                                       |
|                       | <ul> <li>VDC_LVDS_NDIV_4: NIDIV = 4</li> </ul>                                     |
| uint16_t              | Internal parameter setting for LVDS PLL (Not use)                                  |
| lvdspll_tst           |                                                                                    |
| vdc_lvds_ndiv_t       | Frequency dividing value (NODIV) for frequency divider 2                           |
| lvds_odiv_set         | <ul><li>VDC_LVDS_NDIV_1: NODIV = 1</li></ul>                                       |
|                       | <ul><li>VDC_LVDS_NDIV_2: NODIV = 2</li></ul>                                       |
|                       | <ul> <li>VDC_LVDS_NDIV_4: NODIV = 4</li> </ul>                                     |
| vdc_channel_t         | Channel select in video display controller 5 whose data is to be                   |
| lvds_vdc_sel          | output through                                                                     |
|                       | VDC_CHANNEL_0                                                                      |
| uint16_t              | Frequency dividing value (NFD) for the feedback frequency in the                   |
| lvdspll_fd            | LVDS PLL                                                                           |
|                       | $NRD =  vdspll_fd + 1$                                                             |
|                       | NFD = Ivdspll_fd (22 ~ 62)                                                         |
| uint16_t              | Frequency dividing value (NRD) for the input frequency in the                      |
| lvdspll_rd            | LVDS PLL                                                                           |
|                       | $NRD =  vdspll_rd + 1 $                                                            |
| To be a second        | lvdspll_rd (0 ~ 7)                                                                 |
| vdc_lvds_pll_nod_t    | Frequency dividing value (NOD) for the output frequency in the LVDS PLL(Not use)   |
| lvdspll_od            | <ul> <li>VDC LVDS PLL NOD 1: NOD = 1</li> </ul>                                    |
|                       |                                                                                    |
|                       | <ul> <li>VDC_LVDS_PLL_NOD_2: NOD = 2</li> <li>VDC_LVDS_PLL_NOD_4: NOD_4</li> </ul> |
|                       | • VDC_LVDS_PLL_NOD_4: NOD = 4                                                      |
|                       | <ul><li>VDC_LVDS_PLL_NOD_8: NOD = 8</li></ul>                                      |

# 6.2 R\_VDC\_Terminate

| Synopsis     | VDC driver termination                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Declaration  | vdc_error_t R_VDC_Terminate(     const vdc_channel_t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         — VDC_CHANNEL_0: Channel 0         Specify channel 0 in this driver.</li> <li>void (* quit_func)(uint32_t): Pointer to a user-defined function         Specify the user-implemented function that is to be executed together with the VDC         driver termination processing. Within the API function R_VDC_Terminate, this function         is called after the VDC registers are set up. user_num is used as the argument when         the function is called. Specify '0' when this function is not required.</li> <li>uint32_t user_num: User defined number         Specify the argument to be passed to the user-defined function quit_func. This         parameter is ignored if '0' is specified as the user-defined function.</li> </ul> |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

### Details

### (1) Function

This function terminates the VDC driver and performs the following associated processing:

- Disables all the VDC interrupts.
- Disables the VDC panel clock.
- Calls the user-defined function specified in quit\_func.

### (2) Use conditions

There are no particular conditions with respect to the call of this function.

# 6.3 R\_VDC\_VideoInput

| Synopsis     | Video input setup                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Declaration  | vdc_error_t R_VDC_VideoInput( const vdc_channel_t ch, const vdc_input_t * const param);                                                                                                                                                                                                                                                                                                                                                              |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         <ul> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> </ul> </li> <li>vdc_input_t * param: Video input setup parameter         <ul> <li>Do not specify NULL.</li> </ul> </li> </ul>                                                                                                                                                                                           |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_PARAM_EXCEED_RANGE: Out-of-value-range error</li> <li>VDC_ERR_PARAM_CONDITION: Unauthorized condition error</li> </ul> |

### Details

### (1) Function

This function performs the following processing on the video input:

- Sets up the phase timing of the input signals.
- Performs delay control on the sync signal for the video inputs.
- Sets up the parameters for the external input video signals.

### (2) Use conditions

There are no particular conditions with respect to the call of this function.

### (3) Parameter details

The members of the vdc\_input\_t structure is described below.

| Type<br>Member Name      | Description                                                                                                         |
|--------------------------|---------------------------------------------------------------------------------------------------------------------|
| vdc_input_sel_t          | Input select                                                                                                        |
| inp_sel                  | <ul><li>VDC_INPUT_SEL_EXT (1):</li></ul>                                                                            |
|                          | Signals supplied via the external input pins                                                                        |
|                          | Specify VDC_INPUT_SEL_EXT.                                                                                          |
| uint16_t                 | Vsync signal 1/2fH phase timing                                                                                     |
| inp_fh50                 | 0x0000 to 0x03FF                                                                                                    |
|                          | 1/2 clock cycle of the horizontal cycle should be set.                                                              |
| uint16_t                 | Vsync signal 1/4fH phase timing                                                                                     |
| inp_fh25                 | 0x0000 to 0x03FF                                                                                                    |
|                          | 1/4 clock cycle of the horizontal cycle should be set.                                                              |
| const vdc_sync_delay_t * | Sync signal delay adjustment parameter                                                                              |
| dly                      | The setting is not changed if NULL is specified. If this                                                            |
|                          | parameter has never been set up after a hardware reset,<br>the initial value that is defined in the hardware manual |
|                          | remains valid. See the description about the structure for                                                          |
|                          | the initial value.                                                                                                  |
| const vdc_ext_in_sig_t * | External input signal parameter                                                                                     |
| ext_sig                  | Do not specify NULL.                                                                                                |

The members of the  $vdc\_sync\_delay\_t$  structure is described below.

```
typedef struct
{
    uint16_t inp_vs_dly_l;
    uint16_t inp_fld_dly;
    uint16_t inp_vs_dly;
    uint16_t inp_hs_dly;
} vdc_sync_delay_t;
```

| Type<br>Member Name | Initial Value | Description                                         |
|---------------------|---------------|-----------------------------------------------------|
| uint16_t            | 0             | Number of lines for delaying vsync signal and field |
| inp_vs_dly_l        |               | differentiation signal                              |
|                     |               | 0 to 7 [lines]                                      |
| uint16_t            | 0             | Field differentiation signal delay amount           |
| inp_fld_dly         |               | 0 to 254 [clock cycles]                             |
| uint16_t            | 0             | Vsync signal delay amount                           |
| inp_vs_dly          |               | 0 to 254 [clock cycles]                             |
| uint16_t            | 0             | Hsync signal delay amount                           |
| inp_hs_dly          |               | 0 to 254 [clock cycles]                             |

The members of the vdc\_ext\_in\_sig\_t structure is described below.

```
typedef struct
    vdc_extin_format_t inp_format;
    vdc_edge_t
                             inp_pxd_edge;
                     inp_vs_edge;
inp_hs_edge;
inp_endian_on;
inp_swap_on;
inp_vs_inv;
inp_hs :--
    vdc_edge_t
    vdc_edge_t
    vdc_onoff_t
    vdc_onoff_t
    vdc_sig_pol_t
    vdc_sig_pol_t
    vdc_extin_ref_hsync_t inp_h_edge_sel;
    vdc_extin_input_line_t inp_f525_625;
                           inp_h_pos;
    vdc_extin_h_pos_t
} vdc_ext_in_sig_t;
```

| Туре        | Description |
|-------------|-------------|
| Member Name | Description |

| Member Name        |                                                                        |
|--------------------|------------------------------------------------------------------------|
| vdc_extin_format_t | External input format select                                           |
| inp_format         | <ul><li>VDC_EXTIN_FORMAT_RGB888 (0): RGB888</li></ul>                  |
|                    | <ul><li>VDC_EXTIN_FORMAT_RGB666 (1): RGB666</li></ul>                  |
|                    | <ul><li>VDC_EXTIN_FORMAT_RGB565 (2): RGB565</li></ul>                  |
|                    | <ul> <li>VDC_EXTIN_FORMAT_BT656 (3): BT6556</li> </ul>                 |
|                    | <ul> <li>VDC_EXTIN_FORMAT_BT601 (4): BT6501</li> </ul>                 |
|                    | <ul><li>VDC_EXTIN_FORMAT_YCBCR422 (5): YCbCr422</li></ul>              |
|                    | <ul> <li>VDC_EXTIN_FORMAT_YCBCR444 (6): YCbCr444</li> </ul>            |
| vdc_edge_t         | Clock edge select for capturing external input video image             |
| inp_pxd_edge       | signals DV_DATA23 to DV_DATA0                                          |
|                    | <ul> <li>VDC_EDGE_RISING: Rising edge</li> </ul>                       |
|                    | <ul> <li>VDC_EDGE_FALLING: Falling edge</li> </ul>                     |
| vdc_edge_t         | Clock edge select for capturing external input Vsync signals           |
| inp_vs_edge        | DV_VSYNC                                                               |
|                    | <ul> <li>VDC_EDGE_RISING: Rising edge</li> </ul>                       |
|                    | <ul> <li>VDC_EDGE_FALLING: Falling edge</li> </ul>                     |
| vdc_edge_t         | Clock edge select for capturing external input Hsync signals           |
| inp_hs_edge        | DV_HSYNC                                                               |
|                    | <ul> <li>VDC_EDGE_RISING: Rising edge</li> </ul>                       |
|                    | <ul> <li>VDC_EDGE_FALLING: Falling edge</li> </ul>                     |
| vdc_onoff_t        | External input bit endian change on/off control                        |
| inp_endian_on      | <ul><li>VDC_OFF</li></ul>                                              |
|                    | VDC_ON                                                                 |
| vdc_onoff_t        | External input B/R signal swap on/off control                          |
| inp_swap_on        | <ul><li>VDC_OFF</li></ul>                                              |
|                    | VDC_ON                                                                 |
| vdc_sig_pol_t      | External input Vsync signal DV_VSYNC inversion control                 |
| inp_vs_inv         | <ul><li>VDC_SIG_POL_NOT_INVERTED:</li></ul>                            |
|                    | Not inverted (positive polarity)                                       |
|                    | <ul> <li>VDC_SIG_POL_INVERTED: Inverted (negative polarity)</li> </ul> |
| vdc_sig_pol_t      | External input Hsync signal DV_HSYNC inversion control                 |
| inp_hs_inv         | <ul><li>VDC_SIG_POL_NOT_INVERTED:</li></ul>                            |
|                    | Not inverted (positive polarity)                                       |
|                    | <ul> <li>VDC_SIG_POL_INVERTED: Inverted (negative polarity)</li> </ul> |

| RZ/A2M Group | Video Display Controlle | er and Sprite Engine Sample Driver |
|--------------|-------------------------|------------------------------------|
|              |                         |                                    |

| vdc_extin_ref_hsync_t  | Reference select for external input BT656 Hsync signal |
|------------------------|--------------------------------------------------------|
| inp_h_edge_sel         | <ul><li>VDC_EXTIN_REF_H_EAV (0): EAV</li></ul>         |
|                        | <ul><li>VDC_EXTIN_REF_H_SAV (1): SAV</li></ul>         |
| vdc_extin_input_line_t | Number of lines for BT656 external input               |
| inp_f525_625           | <ul> <li>VDC_EXTIN_LINE_525 (0): 525 lines</li> </ul>  |
|                        | <ul> <li>VDC_EXTIN_LINE_625 (1): 625 lines</li> </ul>  |
| vdc_extin_h_pos_t      | Y/Cb/Y/Cr data string start timing to Hsync reference  |
| inp_h_pos              | <ul><li>VDC_EXTIN_H_POS_CBYCRY (0):</li></ul>          |
|                        | Cb/Y/Cr/Y (BT656/601), Cb/Cr (YCbCr422)                |
|                        | <ul><li>VDC_EXTIN_H_POS_YCRYCB (1):</li></ul>          |
|                        | Y/Cr/Y/Cb (BT656/601), inhibited (YCbCr422)            |
|                        | <ul><li>VDC_EXTIN_H_POS_CRYCBY (2):</li></ul>          |
|                        | Cr/Y/Cb/Y (BT656/601), inhibited (YCbCr422)            |
|                        | <ul><li>VDC_EXTIN_H_POS_YCBYCR (3):</li></ul>          |
|                        | Y/Cb/Y/Cr (BT656/601), Cr/Cb (YCbCr422)                |
|                        |                                                        |

The function returns an unauthorized condition error (VDC\_ERR\_PARAM\_CONDITION) if the data string start timing to Hsync reference (inp\_h\_pos) is set to VDC\_EXTIN\_H\_POS\_YCRYCB or VDC\_EXTIN\_H\_POS\_CRYCBY when YCbCr422 is selected as the external input format (inp\_format).

# 6.4 R\_VDC\_SyncControl

| Synopsis     | Synchronization control setup                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Declaration  | vdc_error_t R_VDC_SyncControl(                                                                                                                                                                                                                                                                                                                                                                                               |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel</li> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> <li>vdc_sync_ctrl_t * param: Synchronization control parameter</li> <li>Do not specify NULL.</li> </ul>                                                                                                                                                                                                 |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_EXCEED_RANGE: Out-of-value-range error</li> <li>VDC_ERR_RESOURCE_CLK: Clock resource error</li> <li>VDC_ERR_RESOURCE_INPUT: Input signal resource error</li> </ul> |

### Details

### (1) Function

This function performs the following synchronization control processing:

- Selects the vertical sync signal.
- Sets up the period of the sync signal.
- Sets up the delay of the vertical sync signal.
- Sets up the full-screen enable signal.
- Sets up the compensation for the vertical sync signal.

The settings established by this function remain valid until a hardware reset occurs or they are overwritten by this function with other settings.

### (2) Use conditions

Before this function is used, the panel clock needs to have been set up. The function returns a clock resource error (VDC\_ERR\_RESOURCE\_CLK) if the panel clock is not set up.

When selecting the external input Vsync signal as the Vsync signal output select to be specified in this function, it is necessary to enable the video input by calling the function R\_VDC\_VideoInput before using this function. The function returns an input signal resource error (VDC\_ERR\_RESOURCE\_INPUT) if the video input is disabled.

### (3) Parameter details

The members of the vdc\_sync\_ctrl\_t structure is described below.

# Type Description

| Member Name               | ·                                                                                                                                                                    |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| vdc_onoff_t               | Vsync signal output select (free-running Vsync signal)                                                                                                               |
| res_vs_sel                | <ul> <li>VDC_OFF: External input Vsync signal</li> </ul>                                                                                                             |
|                           | <ul> <li>VDC_ON: Internally generated free-running Vsync signal</li> </ul>                                                                                           |
| vdc_res_vs_in_sel_t       | Horizontal/vertical sync signal output and full-screen enable                                                                                                        |
| res_vs_in_sel             | signal select                                                                                                                                                        |
|                           | <ul> <li>VDC_RES_VS_IN_SEL_SC0 (0): Scaler 0 outputs<br/>Specify VDC_RES_VS_IN_SEL_SC0.</li> </ul>                                                                   |
| uint16_t                  | Free-running Vsync period setting                                                                                                                                    |
| res_fv                    | Free-running Vsync period = (res_fv + 1) x horizontal period [usec]                                                                                                  |
|                           | 0x0000 to 0x07FF                                                                                                                                                     |
| uint16_t                  | Hsync period setting                                                                                                                                                 |
| res_fh                    | Hsync period [usec] = (res_fh + 1) / pixel clock frequency [MHz]                                                                                                     |
|                           | 0x0000 to 0x07FF                                                                                                                                                     |
| uint16_t                  | Vsync signal delay control                                                                                                                                           |
| res_vsdly                 | Adjusts the Vsync signal delay in the output Hsync period units.                                                                                                     |
|                           | 0 to 255                                                                                                                                                             |
| vdc_period_rect_t         | Full-screen enable signal                                                                                                                                            |
| res_f                     | See 5.3(1) for the structure.                                                                                                                                        |
|                           | res_f.vs should be 4 lines or more and res_f.vs + res_f.vw shold be equal to or less than 2039 lines.                                                                |
|                           | res_f.hs should be 16 clock cycles or more and res_f.hs + res_f.hw should be equal to or less than 2015 clock cycles.                                                |
|                           | See also Figure 6-1 and its explanation for these settings.                                                                                                          |
| const vdc_vsync_cpmpe_t * | Vsync signal compensation parameter                                                                                                                                  |
| vsync_cpmpe               | Specifying NULL turns off the repeated Vsync signal masking control and the compensation of missing Vsync signals.                                                   |
|                           | If the compensation of missing Vsync signals is set to OFF, the missing-sync compensating pulse output wait time is set to its maximum value (0xFFFF) by the driver. |

Figure 6-1 shows the valid period of the full-screen enable and the output image. The 16 clock cycles before and after the Hsync signal and the 4 lines before and after the Vsync signal are not included in the valid period of the image.



Figure 6-1 Full Screen Enable Settings

vdc\_vsync\_cpmpe\_t structure is described below.

```
typedef struct
{
    uint16_t res_vmask;
    uint16_t res_vlack;
} vdc_vsync_cpmpe_t;
```

| Member Name | Description                                                           |
|-------------|-----------------------------------------------------------------------|
| uint16_t    | Repeated Vsync signal masking period                                  |
| res_vmask   | Masking period [usec] = res_vmask x 128 / pixel clock frequency [MHz] |
| uint16_t    | Missing-sync compensating pulse output wait time                      |
| res_vlack   | Wait time [usec] = res_vlack x 128 / pixel clock frequency [MHz]      |

# 6.5 R\_VDC\_DisplayOutput

| Synopsis     | Display output setup                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| Declaration  | vdc_error_t R_VDC_DisplayOutput(                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         <ul> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> </ul> </li> <li>vdc_output_t * param: Display output configuration parameter         <ul> <li>Do not specify NULL.</li> </ul> </li> </ul>                                                                                                                                                                                                                                          |  |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_PARAM_CONDITION: Unauthorized condition error</li> <li>VDC_ERR_RESOURCE_CLK: Clock resource error</li> <li>VDC_ERR_RESOURCE_VSYNC: Vertical sync signal resource error</li> </ul> |  |

### Details

### (1) **Function**

This function performs the following processing on the display output:

- Sets up the timing signals for driving the LCD panel.
- Sets up the phase, data sequence, and format of the LCD panel output data.
- Sets up the background color.

The settings established by this function remain valid until a hardware reset occurs or they are overwritten by this function with other settings.

### (2) Use conditions

Before this function is used, the panel clock and sync signals need to have been set up. The function returns a clock resource error (VDC\_ERR\_RESOURCE\_CLK) if the panel clock is not set up and a vertical sync signal resource error (VDC\_ERR\_RESOURCE\_VSYNC) if no sync signal is set up.

### (3) Parameter details

The members of the vdc\_output\_t structure is described below.

```
typedef struct
   uint16_t
                                    tcon_half;
   uint16_t
                                    tcon_offset;
   const vdc_lcd_tcon_timing_t * outctrl[VDC_LCD_TCONSIG_NUM];
   vdc_edge_t
                                   outcnt_lcd_edge;
   vdc\_onoff\_t
                                   out_endian_on;
   vdc_onoff_t
                                   out_swap_on;
   vdc_lcd_outformat_t
                                  out_format;
                                 out_frq_sel;
   vdc_lcd_clkfreqsel_t
   vdc_lcd_scan_t
                                 out_dir_sel;
   vdc_lcd_clkphase_t
                                  out_phase;
                                   bg_color;
   uint32_t
} vdc_output_t;
```

| Туре        | Description |
|-------------|-------------|
| Member Name | Description |

| Member Name                   | Description                                                                                                                                                |  |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| uint16_t                      | 1/2fH timing                                                                                                                                               |  |
| tcon_half                     | Specifies the clock count from the rising edge of the Hsync signal as the counting timing of horizontal counter.  0x0000 to 0x07FF                         |  |
| uint16_t                      | Offset Hsync signal timing                                                                                                                                 |  |
| tcon_offset                   | Sets the clock cycle count from the rising edge of the Hsync signal.  0x0000 to 0x07FF                                                                     |  |
| const vdc_lcd_tcon_timing_t * | LCD TCON timing signal parameter                                                                                                                           |  |
| outctrl[VDC_LCD_TCONSIG_NUM]  | Specify NULL for any signals that are not to be used.                                                                                                      |  |
| vdc_edge_t                    | Output phase control of LCD_DATA23 to LCD_DATA0 pin                                                                                                        |  |
| outcnt_lcd_edge               | VDC_EDGE_RISING:                                                                                                                                           |  |
|                               | Output at the rising edge of LCD_CLK pin.                                                                                                                  |  |
|                               | VDC_EDGE_FALLING:                                                                                                                                          |  |
|                               | Output at the falling edge of LCD_CLK pin.                                                                                                                 |  |
| vdc_onoff_t                   | Bit endian change on/off control                                                                                                                           |  |
| out_endian_on                 | <ul><li>VDC_OFF</li></ul>                                                                                                                                  |  |
|                               | • VDC_ON                                                                                                                                                   |  |
| vdc_onoff_t                   | B/R signal swap on/off control                                                                                                                             |  |
| out_swap_on                   | VDC_OFF                                                                                                                                                    |  |
|                               | • VDC_ON                                                                                                                                                   |  |
| vdc_lcd_outformat_t           | Output format select                                                                                                                                       |  |
| out_format                    | VDC_LCD_OUTFORMAT_RGB888 (0): RGB888                                                                                                                       |  |
|                               | VDC_LCD_OUTFORMAT_RGB666 (1): RGB666      VDC_LCD_OUTFORMAT_RGB666 (2): RGB666                                                                             |  |
|                               | VDC_LCD_OUTFORMAT_RGB565 (2): RGB565  VDC_LCD_OUTFORMAT_RGB565 (2): RGB565                                                                                 |  |
|                               | <ul> <li>VDC_LCD_OUTFORMAT_SERIAL_RGB (3):<br/>Serial RGB</li> </ul>                                                                                       |  |
| vdc_lcd_clkfreqsel_t          | Clock frequency control                                                                                                                                    |  |
| out_frq_sel                   | <ul> <li>VDC_LCD_PARALLEL_CLKFRQ_1 (0):<br/>100% speed (parallel RGB)</li> </ul>                                                                           |  |
|                               | <ul> <li>VDC_LCD_SERIAL_CLKFRQ_3 (1):<br/>Triple speed (serial RGB)</li> </ul>                                                                             |  |
|                               | <ul> <li>VDC_LCD_SERIAL_CLKFRQ_4 (2):<br/>Quadruple speed (serial RGB)</li> </ul>                                                                          |  |
|                               | This parameter is referenced only when out_format is set to VDC_LCD_OUTFORMAT_SERIAL_RGB. In this case, setting this parameter to 100% speed is inhibited. |  |

| vdc_lcd_scan_t<br>out_dir_sel   | Scan direction select  VDC_LCD_SERIAL_SCAN_FORWARD (0): Forward scan  VDC_LCD_SERIAL_SCAN_REVERSE (1): Reverse scan                                                                                                                                                                                                                                                                                                                             |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 | This parameter is referenced only when out_format is set to VDC_LCD_OUTFORMAT_SERIAL_RGB.                                                                                                                                                                                                                                                                                                                                                       |
| vdc_lcd_clkphase_t<br>out_phase | Clock phase adjustment during serial RGB output  VDC_LCD_SERIAL_CLKPHASE_0 (0): 0 [clocks]  VDC_LCD_SERIAL_CLKPHASE_1 (1): 1 [clocks]  VDC_LCD_SERIAL_CLKPHASE_2 (2): 2 [clocks]  VDC_LCD_SERIAL_CLKPHASE_3 (3): 3 [clocks]  This parameter is referenced only when out_format is set to VDC_LCD_OUTFORMAT_SERIAL_RGB. It is inhibited to set this parameter to VDC_LCD_SERIAL_CLKPHASE_3 when out_frq_sel is set to VDC_LCD_SERIAL_CLKPHASE_3. |
| uint32_t                        | Background Color                                                                                                                                                                                                                                                                                                                                                                                                                                |
| bg_color                        | Specify in the RGB888 format (LSB justified).                                                                                                                                                                                                                                                                                                                                                                                                   |

vdc\_lcd\_tcon\_sigsel\_t is an enumeration type for representing the timing signals (LCD TCON) for driving the LCD panel.

```
typedef enum
{
    VDC_LCD_TCONSIG_STVA_VS = 0,
    VDC_LCD_TCONSIG_STVB_VE,
    VDC_LCD_TCONSIG_STH_SP_HS,
    VDC_LCD_TCONSIG_STB_LP_HE,
    VDC_LCD_TCONSIG_CPV_GCK,
    VDC_LCD_TCONSIG_POLA,
    VDC_LCD_TCONSIG_POLB,
    VDC_LCD_TCONSIG_DE,
    VDC_LCD_TCONSIG_NUM
} vdc_lcd_tcon_sigsel_t;
```

| Enumeration constant      | Value | Description                                         |
|---------------------------|-------|-----------------------------------------------------|
| VDC_LCD_TCONSIG_STVA_VS   | 0     | Gate start signal, Vsync signal (STVA/VS)           |
| VDC_LCD_TCONSIG_STVB_VE   | 1     | Gate start signal, vertical enable signal (STVB/VE) |
| VDC_LCD_TCONSIG_STH_SP_HS | 2     | Source start signal, Hsync signal (STH/SP/HS)       |
| VDC_LCD_TCONSIG_STB_LP_HE | 3     | Source strobe signal, horizontal enable signal      |
|                           |       | (STB/LP/HE)                                         |
| VDC_LCD_TCONSIG_CPV_GCK   | 4     | Gate clock signal (CPV/GCK)                         |
| VDC_LCD_TCONSIG_POLA      | 5     | VCOM voltage polarity control signal (POLA)         |
| VDC_LCD_TCONSIG_POLB      | 6     | VCOM voltage polarity control signal (POLB)         |
| VDC_LCD_TCONSIG_DE        | 7     | Data enable signal (DE)                             |
| VDC_LCD_TCONSIG_NUM       | 8     | Number of LCD panel drive signal types              |

The members of the vdc\_lcd\_tcon\_timing\_t structure is described below.

# Type Description

| tcon_hsvs from the rising edge of the reference signal. 0x0000 to 0x07FF [clock cycles, 1/2fH cycles] Set a value of 1 or greater if tcon_md is set to a value other than VDC_LCD_TCON_POLMD_NORMAL when using the POLA/POLB signal.  uint16_t tcon_hwvw  Pulse width (second changing timing) Outputs a pulse of the duration of the value of tcon_hwvw 0x0000 to 0x07FF [clock cycles, 1/2fH cycles]  vdc_lcd_tcon_polmode_t POLA/POLB signal generation mode select tcon_md  POLA/POLB signal generation mode select  VDC_LCD_TCON_POLMD_NORMAL (0): Normal mode Generates the signal whose polarity is inverted every horizontal period.  VDC_LCD_TCON_POLMD_1X1REV (1): 1x1 reverse mode Generates the signal whose polarity is inverted every horizontal period.  VDC_LCD_TCON_POLMD_1X2REV (2): 1x2 reverse mode Generates the signal whose polarity is inverted in the first horizontal period and is subsequently inverted every two horizontal periods.  VDC_LCD_TCON_POLMD_2X2REV (3): 2x2 reverse mode                                                                                                                                                                                                             | Member Name  | 2 0 0 0 1 p 1 0 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tcon_hwvw  Outputs a pulse of the duration of the value of tcon_hwvw 0x0000 to 0x07FF [clock cycles, 1/2fH cycles]  vdc_lcd_tcon_polmode_t  tcon_md  POLA/POLB signal generation mode select  • VDC_LCD_TCON_POLMD_NORMAL (0): Normal mode Generates the signal whose polarity is inverted every horizontal period.  • VDC_LCD_TCON_POLMD_1X1REV (1): 1x1 reverse mode Generates the signal whose polarity is inverted every horizontal period.  • VDC_LCD_TCON_POLMD_1X2REV (2): 1x2 reverse mode Generates the signal whose polarity is inverted every horizontal period and is subsequently inverted every two horizontal periods.  • VDC_LCD_TCON_POLMD_2X2REV (3): 2x2 reverse mode Generates the signal whose polarity is inverted every two horizontal periods.  • VDC_LCD_TCON_POLMD_2X2REV (3): 2x2 reverse mode Generates the signal whose polarity is inverted every two horizontal periods.  • VDC_LCD_TCON_REFSEL_HSYNC (0): Hsync signal reference  • VDC_LCD_TCON_REFSEL_OFFSET_H (1): Offset Hsync signal reference  vdc_sig_pol_t tcon_inv  • VDC_SIG_POL_NOT_INVERTED Not inverted (positive polarity)  • VDC_SIG_POL_INVERTED: Inverted (negative polarity)  vdc_lcd_tcon_pin_t  LCD_TCON_output pin select | tcon_hsvs    | Starts pulse output after the time specified by the value of tcon_hsvs from the rising edge of the reference signal.  0x0000 to 0x07FF [clock cycles, 1/2fH cycles]  Set a value of 1 or greater if tcon_md is set to a value other than VDC_LCD_TCON_POLMD_NORMAL when using the POLA/POLB signal.                                                                                                                                                                                                                                                                                                                                                             |
| tcon_md  • VDC_LCD_TCON_POLMD_NORMAL (0): Normal mode Generates the signal whose polarity is inverted every horizontal period.  • VDC_LCD_TCON_POLMD_1X1REV (1): 1x1 reverse mode Generates the signal whose polarity is inverted every horizontal period.  • VDC_LCD_TCON_POLMD_1X2REV (2): 1x2 reverse mode Generates the signal whose polarity is inverted in the first horizontal period and is subsequently inverted every two horizontal periods.  • VDC_LCD_TCON_POLMD_2X2REV (3): 2x2 reverse mode Generates the signal whose polarity is inverted every two horizontal periods.  • VDC_LCD_TCON_POLMD_2X2REV (3): 2x2 reverse mode Generates the signal whose polarity is inverted every two horizontal periods.  • VDC_LCD_TCON_REFSEL_HSYNC (0): Hsync signal reference • VDC_LCD_TCON_REFSEL_HSYNC (0): Hsync signal reference • VDC_LCD_TCON_REFSEL_OFFSET_H (1): Offset Hsync signal reference  vdc_sig_pol_t  vdc_sig_pol_t Polarity inversion control of signal • VDC_SIG_POL_NOT_INVERTED Not inverted (positive polarity) • VDC_SIG_POL_INVERTED: Inverted (negative polarity)  vdc_lcd_tcon_pin_t  LCD TCON output pin select                                                                               | <del>_</del> | Outputs a pulse of the duration of the value of tcon_hwvw.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| tcon_hs_sel  • VDC_LCD_TCON_REFSEL_HSYNC (0): Hsync signal reference  • VDC_LCD_TCON_REFSEL_OFFSET_H (1): Offset Hsync signal reference  vdc_sig_pol_t tcon_inv  • VDC_SIG_POL_NOT_INVERTED Not inverted (positive polarity) • VDC_SIG_POL_INVERTED: Inverted (negative polarity)  vdc_lcd_tcon_pin_t  LCD TCON output pin select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -            | <ul> <li>VDC_LCD_TCON_POLMD_NORMAL (0):         Normal mode         Generates the signal whose polarity is inverted every horizontal period.</li> <li>VDC_LCD_TCON_POLMD_1X1REV (1):         1x1 reverse mode         Generates the signal whose polarity is inverted every horizontal period.</li> <li>VDC_LCD_TCON_POLMD_1X2REV (2):         1x2 reverse mode         Generates the signal whose polarity is inverted in the first horizontal period and is subsequently inverted every two horizontal periods.</li> <li>VDC_LCD_TCON_POLMD_2X2REV (3):         2x2 reverse mode         Generates the signal whose polarity is inverted every two</li> </ul> |
| tcon_inv  • VDC_SIG_POL_NOT_INVERTED Not inverted (positive polarity)  • VDC_SIG_POL_INVERTED: Inverted (negative polarity)  vdc_lcd_tcon_pin_t  LCD TCON output pin select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |              | <ul> <li>VDC_LCD_TCON_REFSEL_HSYNC (0):<br/>Hsync signal reference</li> <li>VDC_LCD_TCON_REFSEL_OFFSET_H (1):</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| , ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | • .          | <ul> <li>VDC_SIG_POL_NOT_INVERTED<br/>Not inverted (positive polarity)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •            | · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

|             | <ul> <li>VDC_LCD_TCON_PIN_0 (0): LCD_TCON0 output.</li> </ul> |
|-------------|---------------------------------------------------------------|
|             | <ul> <li>VDC_LCD_TCON_PIN_1 (1): LCD_TCON1 output.</li> </ul> |
|             | <ul> <li>VDC_LCD_TCON_PIN_2 (2): LCD_TCON2 output.</li> </ul> |
|             | <ul> <li>VDC_LCD_TCON_PIN_3 (3): LCD_TCON3 output.</li> </ul> |
|             | <ul> <li>VDC_LCD_TCON_PIN_4 (4): LCD_TCON4 output.</li> </ul> |
|             | <ul> <li>VDC_LCD_TCON_PIN_5 (5): LCD_TCON5 output.</li> </ul> |
|             | <ul> <li>VDC_LCD_TCON_PIN_6 (6): LCD_TCON6 output.</li> </ul> |
| vdc_edge_t  | Output phase control of the signal                            |
| outcnt_edge | <ul><li>VDC_EDGE_RISING:</li></ul>                            |
|             | Output at the rising edge of LCD_CLK pin.                     |
|             | <ul><li>VDC_EDGE_FALLING:</li></ul>                           |
|             | Output at the falling edge of LCD_CLK pin.                    |

Different members of the vdc\_lcd\_tcon\_timing\_t structure are referenced depending on the type of the LCD panel drive signals that are to be set up. The table below summarizes the members that are valid or invalid when the respective signals are set up. Invalid members are not referenced.

Table 6-3 Valid Parameters for the LCD Panel Drive Signals

| LCD Panel       | vdc_lcd_tcc | vdc_lcd_tcon_timing_t Structure Member |         |             |          |          |             |
|-----------------|-------------|----------------------------------------|---------|-------------|----------|----------|-------------|
| Drive<br>Signal | tcon_hsvs   | tcon_hwvw                              | tcon_md | tcon_hs_sel | tcon_inv | tcon_pin | outcnt_edge |
| STVA/VS         | valid       | valid                                  | -       | -           | valid    | valid    | valid       |
| STVB/VE         | valid       | valid                                  | -       | -           | valid    | valid    | valid       |
| STH/SP/HS       | valid       | valid                                  | -       | valid       | valid    | valid    | valid       |
| STB/LP/HE       | valid       | valid                                  | -       | valid       | valid    | valid    | valid       |
| CPV/GCK         | valid       | valid                                  | -       | valid       | valid    | valid    | valid       |
| POLA            | valid       | valid                                  | valid   | valid       | valid    | valid    | valid       |
| POLB            | valid       | valid                                  | valid   | valid       | valid    | valid    | valid       |
| DE              | -           | -                                      | -       | -           | valid    | valid    | valid       |

Note: 'valid' denotes a valid member whose value is referenced.

<sup>&#</sup>x27;-' denotes an invalid member whose value is not referenced.

# 6.6 R\_VDC\_CallbackISR

| Synopsis     | Interrupt callback setup                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Declaration  | vdc_error_t R_VDC_CallbackISR( const vdc_channel_t ch, const vdc_int_t * const param);                                                                                                                                                                                                                                                                                                                                                           |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         — VDC_CHANNEL_0: Channel 0         Specify channel 0 in this driver.</li> <li>vdc_int_t * param: Interrupt callback setup parameter         Do not specify NULL.</li> </ul>                                                                                                                                                                                                                           |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_RESOURCE_CLK: Clock resource error</li> <li>VDC_ERR_RESOURCE_VSYNC: Vertical sync signal resource error</li> </ul> |

## Details

#### (1) Function

This function performs the following VDC interrupt processing:

- Enables the interrupt when the pointer to the corresponding interrupt callback function is specified.
- Registers the specified interrupt callback function.
- Disables the interrupt when the pointer to the corresponding interrupt callback function is not specified.

With this driver, all of the VDC interrupts are disabled and the registered entries of the callback functions are removed during R\_VDC\_Initialize and R\_VDC\_Terminate. The setting of an existing interrupt can also be overwritten by applying this function R\_VDC\_CallbackISR to that interrupt.

#### (2) Use conditions

Before this function is used, the panel clock and sync signals need to have been set up. The function returns a clock resource error (VDC\_ERR\_RESOURCE\_CLK) if the panel clock is not set up and a vertical sync signal resource error (VDC\_ERR\_RESOURCE\_VSYNC) if no sync signal is set up.



#### (3) Parameter details

The members of the vdc\_int\_t structure is described below.

# Туре

# **Description**

| Member Name                  | Description                                                                                                                                                                                |  |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| vdc_int_type_t               | VDC interrupt type                                                                                                                                                                         |  |
| type                         | See 5.2(8) for details.                                                                                                                                                                    |  |
| void                         | Interrupt callback function pointer                                                                                                                                                        |  |
| (* callback)(vdc_int_type_t) | Specify the pointer to the interrupt callback function associated with the interrupt that is specified in type. The callback function needs to be implemented by the user.                 |  |
|                              | The interrupt processing of the interrupt for which a callback function is specified becomes enabled. If a '0' is specified in callback, the interrupt specified in type becomes disabled. |  |
| uint16_t                     | Line interrupt set                                                                                                                                                                         |  |
| line_num                     | An interrupt signal is output when the line position of the image matches the value of line_num.                                                                                           |  |
|                              | This parameter is valid only when one of the following line interrupts is specified in type:                                                                                               |  |
|                              | — VDC_INT_TYPE_VLINE                                                                                                                                                                       |  |
|                              | VDC_INT_TYPE_S0_WLINE                                                                                                                                                                      |  |

# 6.7 R\_VDC\_WriteDataControl

| Synopsis     | Data write control processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Declaration  | vdc_error_t R_VDC_WriteDataControl(     const vdc_channel_t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         — VDC_CHANNEL_0: Channel 0         Specify channel 0 in this driver.</li> <li>vdc_layer_id_t layer_id: Layer ID         — VDC_LAYER_ID_0_WR: Layer 0 write processing         Specify layer 0 write processing in this driver.</li> <li>vdc_write_t * param: Data write control parameter         Do not specify NULL.</li> </ul>                                                                                                                                                                                     |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_PARAM_EXCEED_RANGE: Out-of-value-range error</li> <li>VDC_ERR_RESOURCE_INPUT: Input signal resource error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul> |

## Details

#### (1) **Function**

This function performs the following data write control processing:

- Sets up the input image area to be captured.
- Makes input image scaling-down and rotation control settings.
- Makes frame buffer write control settings.

#### (2) Use conditions

Before using this function, it is necessary to enable a video input by calling the function R\_VDC\_VideoInput. If no video input is enabled, the function returns an input signal resource error (VDC\_ERR\_RESOURCE\_INPUT).

This function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) if the layer that is specified in layer\_id is found enabled already when this function is used. The enabled layer can be disabled by calling the function R\_VDC\_ReleaseDataControl.

Control of the vertical scale-down processing is mutually exclusive with the control of the vertical scale-up processing. Normal operation of the driver operation is not guaranteed if vertical scale-down and vertical scale-up are specified at the same time. The setup of vertical scale-up processing is accomplished by the functions R\_VDC\_ReadDataControl and R\_VDC\_ChangeReadProcess.



#### (3) Parameter details

The members of the vdc\_write\_t structure is described below

```
typedef struct
       vdc_scalingdown_rot_t scalingdown_rot;
      vdc_scalingdown_rot_tscalingdown_rot_tvdc_wr_rd_swa_tres_wrswa;vdc_res_md_tres_md;vdc_bst_md_tres_bst_md;vdc_res_inter_tres_inter;vdc_res_fs_rate_tres_fs_rate;vdc_res_fld_sel_tres_fld_sel;vdc_onoff_tres_dth_on;
                                               res_dth_on;
      vdc_onoff_t
      void
                                                * base;
      uint32_t
                                                  ln_off;
      uint32_t
                                                 flm_num;
      uint32_t
                                                 flm_off;
      void
                                             * btm_base;
} vdc_write_t;
```

| ı yp <del>e</del> |      |
|-------------------|------|
| Member            | Name |

Typo

#### Description

| wember name           |                                                                                                                   |
|-----------------------|-------------------------------------------------------------------------------------------------------------------|
| vdc_scalingdown_rot_t | Scaling-down and rotation parameter                                                                               |
| scalingdown_rot       |                                                                                                                   |
| vdc_wr_rd_swa_t       | 8-bit, 16-bit, or 32-bit swap setting                                                                             |
| res_wrswa             | <ul> <li>VDC_WR_RD_WRSWA_NON (0): 1-2-3-4-5-6-7-8</li> <li>Not swapped</li> </ul>                                 |
|                       | <ul> <li>VDC_WR_RD_WRSWA_8BIT (1): 2-1-4-3-6-5-8-7</li> <li>Swapped in 8-bit units</li> </ul>                     |
|                       | <ul> <li>VDC_WR_RD_WRSWA_16BIT (2): 3-4-1-2-7-8-5-6</li> <li>Swapped in 16-bit units</li> </ul>                   |
|                       | <ul> <li>VDC_WR_RD_WRSWA_16_8BIT (3): 4-3-2-1-8-7-6-5</li> <li>Swapped in 16-bit units + 8-bit units</li> </ul>   |
|                       | <ul> <li>VDC_WR_RD_WRSWA_32BIT (4): 5-6-7-8-1-2-3-4</li> <li>Swapped in 32-bit units</li> </ul>                   |
|                       | <ul> <li>VDC_WR_RD_WRSWA_32_8BIT (5): 6-5-8-7-2-1-4-3</li> <li>Swapped in 32-bit units + 8-bit units</li> </ul>   |
|                       | <ul> <li>VDC_WR_RD_WRSWA_32_16BIT (6): 7-8-5-6-3-4-1-2</li> <li>Swapped in 32-bit units + 16-bit units</li> </ul> |
|                       | <ul> <li>VDC_WR_RD_WRSWA_32_16_8BIT (7):<br/>8-7-6-5-4-3-2-1</li> </ul>                                           |
|                       | Swapped in 32-bit units + 16-bit units + 8-bit units                                                              |
| vdc_res_md_t          | Frame buffer video-signal writing format                                                                          |
| res_md                | <ul><li>VDC_RES_MD_YCBCR422 (0): YCbCr422</li></ul>                                                               |
|                       | <ul> <li>VDC_RES_MD_RGB565 (1): RGB565</li> </ul>                                                                 |
|                       | <ul> <li>VDC_RES_MD_RGB888 (2): RGB888</li> </ul>                                                                 |
|                       | <ul> <li>VDC_RES_MD_YCBCR444 (3): YCbCr444</li> </ul>                                                             |
| vdc_bst_md_t          | Transfer burst length for frame buffer writing                                                                    |
| res_bst_md            | <ul> <li>VDC_BST_MD_32BYTE (0): 32-byte transfer (4 bursts)</li> </ul>                                            |
| _ <del>_</del>        | <ul> <li>VDC_BST_MD_128BYTE (1):</li> </ul>                                                                       |
|                       | 128-byte transfer (16 bursts)                                                                                     |
| vdc_res_inter_t       | Field operating mode select                                                                                       |
| res inter             | VDC RES INTER PROGRESSIVE (0):                                                                                    |
|                       | Progressive                                                                                                       |

| RZ/RZIVI GIOUP      | video Display Controller and Opine Engine Cample Driver                                          |
|---------------------|--------------------------------------------------------------------------------------------------|
|                     | VDC_RES_INTER_INTERLACE (1): Interlace                                                           |
| vdc_res_fs_rate_t   | Writing rate                                                                                     |
| res_fs_rate         | <ul> <li>VDC_RES_FS_RATE_PER1 (0): 1/1 an input signal</li> </ul>                                |
|                     | <ul> <li>VDC RES FS RATE PER2 (1): 1/2 an input signal</li> </ul>                                |
|                     | <ul> <li>VDC_RES_FS_RATE_PER4 (2): 1/4 an input signal</li> </ul>                                |
|                     | VDC_RES_FS_RATE_PER8 (3): 1/8 an input signal                                                    |
| vdc_res_fld_sel_t   | Write field select                                                                               |
| res_fld_sel         | This parameter is valid only when res_fs_rate is set to a value other than VDC_RES_FS_RATE_PER1. |
|                     | <ul> <li>VDC_RES_FLD_SEL_TOP (0): Top field</li> </ul>                                           |
|                     | <ul> <li>VDC_RES_FLD_SEL_BOTTOM (1): Bottom field</li> </ul>                                     |
| vdc_onoff_t         | Dither correction on/off                                                                         |
| res_dth_on          | <ul> <li>VDC_OFF: Rounded off</li> </ul>                                                         |
|                     | <ul> <li>VDC_ON: 2x2 dither pattern</li> </ul>                                                   |
| void *              | Frame buffer base address                                                                        |
| base                | Do not specify NULL.                                                                             |
|                     | When the value specified in res_bst_md is:                                                       |
|                     | <ul> <li>VDC_BST_MD_32BYTE</li> </ul>                                                            |
|                     | Specify an address that is aligned to 32 bytes.                                                  |
|                     | <ul> <li>VDC_BST_MD_128BYTE</li> </ul>                                                           |
|                     | Specify an address that is aligned to 128 byte.                                                  |
| uint32_t            | Frame buffer line offset address                                                                 |
| In_off              | 0x0000 to 0x7FFF                                                                                 |
| 111_011             | When the value specified in res_bst_md is:                                                       |
|                     | <ul> <li>VDC_BST_MD_32BYTE</li> </ul>                                                            |
|                     | Specify a multiple of 32.                                                                        |
|                     | <ul> <li>VDC BST MD 128BYTE</li> </ul>                                                           |
|                     | Specify a multiple of 128.                                                                       |
| uint20 t            | Number of frames of buffer to be written to                                                      |
| uint32_t<br>flm_num | 0x0000 to 0x03FF                                                                                 |
| IIIII_IIdiII        | Number of frames defined by flm_num + 1 is used.                                                 |
|                     | Specify 2 frames ('1') or more for rotation processing.                                          |
| uint32_t            | Frame buffer frame offset address                                                                |
| flm_off             | 0x00000000 to 0x007FFFFF                                                                         |
| 1111_011            | This parameter is invalid when the number of frames is 1                                         |
|                     | (flm_num is set to '0').                                                                         |
|                     | When the value specified in res_bst_md is:                                                       |
|                     | <ul> <li>VDC_BST_MD_32BYTE</li> </ul>                                                            |
|                     | Specify a multiple of 32.                                                                        |
|                     | <ul> <li>VDC_BST_MD_128BYTE</li> </ul>                                                           |
|                     | Specify a multiple of 128.                                                                       |
| void *              | Frame buffer base address for bottom                                                             |
|                     | Specify NULL if not required.                                                                    |
| btm_base            | When the value specified in res_bst_md is:                                                       |
|                     | ·                                                                                                |
|                     | VDC_BST_MD_32BYTE     Specify an address that is aligned to 32 bytes.                            |
|                     | Specify an address that is aligned to 32 bytes.                                                  |
|                     | VDC_BST_MD_128BYTE     Specify on address that is aligned to 128 bytes.                          |
|                     | Specify an address that is aligned to 128 bytes.                                                 |

The members of the vdc\_scalingdown\_rot\_t structure is described below.

```
typedef struct
{
    vdc_period_rect_t res;
    vdc_onoff_t res_pfil_sel;
    uint16_t res_out_vw;
    uint16_t res_out_hw;
    vdc_onoff_t adj_sel;
    vdc_wr_md_t res_ds_wr_md;
} vdc_scalingdown_rot_t;
```

# Type Member Name

#### **Description**

| Member Name                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| vdc_period_rect_t<br>res    | Image area to be captured  See 5.3(1) for the vdc_period_rect_t structure.  res.vs should be 4 lines or more and res.vs + res.vw shold be equal to or less than 2039 lines.  res.hs should be 16 clock cycles or more and res.hs + res.hw should be equal to or less than 2015 clock cycles.  The actual vertical position setting for video signal capturing is res.vs + 1.                                                                                                                                       |
| vdc_onoff_t<br>res_pfil_sel | Prefilter mode select for brightness signals  VDC_OFF  VDC_ON                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| uint16_t<br>res_out_vw      | Number of valid lines in vertical direction output by scaling-<br>down control block (lines)<br>0x0000 to 0x07FF<br>Specify a value that is aligned in 4-line units and equal to<br>or smaller than the res.vw value.                                                                                                                                                                                                                                                                                              |
| uint16_t<br>res_out_hw      | Number of valid horizontal pixels output by scaling-down control block (video-image clock cycles) 0x0000 to 0x07FF Specify a value that is aligned in 4-pixel units and equal to or smaller than the res.hw value.                                                                                                                                                                                                                                                                                                 |
| vdc_onoff_t<br>adj_sel      | Handling for lack of last-input line Specifies whether to take countermeasures for decreasing the influence by the lack of last-input line in scale-down processing.  • VDC_OFF  • VDC_ON                                                                                                                                                                                                                                                                                                                          |
| vdc_wr_md_t<br>res_ds_wr_md | <ul> <li>Frame buffer writing mode for image processing</li> <li>VDC_WR_MD_NORMAL (0): Normal</li> <li>VDC_WR_MD_MIRROR (1): Horizontal mirroring</li> <li>VDC_WR_MD_ROT_90DEG (2): 90-degree rotation</li> <li>VDC_WR_MD_ROT_180DEG (3): 180-degree rotation</li> <li>VDC_WR_MD_ROT_270DEG (4): 270-degree rotation</li> <li>Setting this parameter to 90-degree, 180-degree, or 270-degree rotation is valid only when frame buffer videosignal writing format (res_md) is set to YCbCr422 or RGB565.</li> </ul> |

Figure 6-2 shows the relationship between the settings of the frame buffer related parameters and the memory allocation.



Figure 6-2 Frame Buffer Related Parameter Settings and Memory Allocation

The width and height of the image in the frame buffer (width and height in Figure 6-2) are the number of valid horizontal pixels (res\_out\_hw) and the number of valid lines in vertical direction (res\_out\_vw) output by scaling-down control block, respectively. But when the frame buffer writing mode for image processing (res\_ds\_wr\_md) is set to 90-degree rotation or 270-degree rotation, the width and height of the image are res\_out\_vw and res\_out\_hw, respectively.

# 6.8 R\_VDC\_ChangeWriteProcess

| Synopsis     | Data write change processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| Declaration  | vdc_error_t R_VDC_ChangeWriteProcess(                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel  — VDC_CHANNEL_0: Channel 0 Specify channel 0 in this driver.</li> <li>vdc_layer_id_t layer_id: Layer ID  — VDC_LAYER_ID_0_WR: Layer 0 write processing Specify layer 0 write processing in this driver.</li> <li>vdc_write_chg_t * param: Data write change parameter Do not specify NULL.</li> </ul>                                                                                                                                                           |  |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_PARAM_EXCEED_RANGE: Out-of-value-range error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul> |  |

#### Details

#### (1) Function

This function takes the following data write control actions during data write processing:

- Changes the input image area to be captured.
- Makes changes with respect to scaling-down and rotation control of the input image.

#### (2) Use conditions

This function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) unless the layer specified in layer\_id of this function meets the following conditions:

- The specified layer is enabled.
- The specified layer is running.

A layer is enabled by calling the function R\_VDC\_WriteDataControl. A layer that is in the stopped state can be started by calling the function R\_VDC\_StartProcess.

Control of the vertical scale-down processing is mutually exclusive with the control of the vertical scale-up processing. Normal operation of the driver operation is not guaranteed if vertical scale-down and vertical scale-up are specified at the same time. The setup of vertical scale-up processing is accomplished by the functions R\_VDC\_ReadDataControl and R\_VDC\_ChangeReadProcess.



#### (3) Parameter details

The members of the vdc\_write\_chg\_t structure is described below.

```
typedef struct
{
    vdc_scalingdown_rot_t scalingdown_rot;
} vdc_write_chg_t;
```

#### Type Member Name

#### **Description**

| vdc_scalingdown_rot_t |
|-----------------------|
| scalingdown_rot       |

Scaling-down and rotation parameter See 6.7(3) for details.

This function can be used to change the rotation control mode during data write processing. The size of the frame buffer that is required for the data write may be altered of the rotation angle is changed by 90 or 270 degrees from the current angle.



Figure 6-3 Rotation Processing and Frame Buffer Size

Figure 6-3 shows two cases of processing in which the frame buffer size is altered as the result of rotating the input image by 90 degrees. Before the rotation, the width (hw) and height (vw) of the frame buffer that is necessary for data write processing are set to (res\_out\_hw) and (res\_out\_vw), respectively. Since these size values change as the result of the 90-degree rotation, data is likely to be written into an unexpected area. To avoid this situation, it is necessary to reserve a larger frame buffer in advance ((a) and (b) in the figure).

# 6.9 R\_VDC\_ReadDataControl

| Synopsis     | Data read control processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Declaration  | vdc_error_t R_VDC_ReadDataControl(                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         — VDC_CHANNEL_0: Channel 0         Specify channel 0 in this driver.</li> <li>vdc_layer_id_t layer_id: Layer ID         — VDC_LAYER_ID_0_RD: Layer 0 read processing         — VDC_LAYER_ID_2_RD: Layer 2 read processing         — VDC_LAYER_ID_3_RD: Layer 3 read processing</li> <li>vdc_read_t * param: Data read control parameter         Do not specify NULL.</li> </ul>                                                                                                                                                             |  |
| Return value | <ul> <li>vdc_error_t: Error code         <ul> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_PARAM_EXCEED_RANGE: Out-of-value-range error</li> <li>VDC_ERR_PARAM_CONDITION: Unauthorized condition error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul> </li> </ul> |  |

#### Details

#### (1) **Function**

This function performs the following data read control processing:

- Sets up the display area for graphics images.
- Makes image scale-up control settings (layer 0 only).
- Makes frame buffer read control settings.

#### (2) Use conditions

This function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) if the layer specified in layer\_id is found enabled already when this function is used. The enabled layer can be disabled by calling the function R\_VDC\_ReleaseDataControl.

Control of the vertical scale-up processing is mutually exclusive with the control of the vertical scale-down processing. Normal operation of the driver operation is not guaranteed if vertical scale-down and vertical scale-up are specified at the same time. The setup of vertical scale-down processing is accomplished by the functions R\_VDC\_WriteDataControl and R\_VDC\_ChangeWriteProcess.



## (3) Parameter details

vdc\_read\_t structure is described below.

| Туре        | Description |
|-------------|-------------|
| Member Name | Description |

| Member Name                 |                                                                                                                                                          |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| vdc_gr_ln_off_dir_t         | Line offset address direction of the frame buffer                                                                                                        |
| gr_ln_off_dir               | <ul><li>VDC_GR_LN_OFF_DIR_INC (0):</li></ul>                                                                                                             |
|                             | Increments the address by the line offset address.                                                                                                       |
|                             | <ul><li>VDC_GR_LN_OFF_DIR_DEC (1):</li></ul>                                                                                                             |
|                             | Decrements the address by the line offset address.                                                                                                       |
| vdc_gr_flm_sel_t            | Frame buffer address setting signal                                                                                                                      |
| gr_flm_sel                  | <ul><li>VDC_GR_FLM_SEL_SCALE_DOWN (0):</li></ul>                                                                                                         |
|                             | Links to scaling-down process.                                                                                                                           |
|                             | <ul> <li>VDC_GR_FLM_SEL_FLM_NUM (1): Selects frame 0.</li> </ul>                                                                                         |
|                             | <ul><li>VDC_GR_FLM_SEL_POINTER_BUFF (3):</li></ul>                                                                                                       |
|                             | Links to pointer buffer.                                                                                                                                 |
| vdc_onoff_t                 | Frame buffer number for distortion correction                                                                                                            |
| gr_imr_flm_inv              | This parameter is not referred in this driver.                                                                                                           |
|                             | Specify VDC_OFF.                                                                                                                                         |
| vdc_bst_md_t                | Frame buffer burst transfer mode                                                                                                                         |
| gr_bst_md                   | <ul> <li>VDC_BST_MD_32BYTE (0): 32-byte transfer</li> </ul>                                                                                              |
|                             | <ul> <li>VDC_BST_MD_128BYTE (1): 128-byte transfer</li> </ul>                                                                                            |
| void *                      | Frame buffer base address                                                                                                                                |
| gr_base                     | Do not specify NULL if gr_flm_sel is set to a value other than VDC_GR_FLM_SEL_POINTER_BUFF.                                                              |
| uint32_t                    | Frame buffer line offset address                                                                                                                         |
| gr_ln_off                   | 0x0000 to 0x7FFF                                                                                                                                         |
|                             | When the value specified in gr_bst_md is:                                                                                                                |
|                             | <ul> <li>VDC_BST_MD_32BYTE</li> </ul>                                                                                                                    |
|                             | Specify a multiple of 32.                                                                                                                                |
|                             | <ul> <li>VDC_BST_MD_128BYTE</li> </ul>                                                                                                                   |
|                             | Specify a multiple of 128.                                                                                                                               |
| const vdc_width_read_fb_t * | Size of the frame buffer to be read                                                                                                                      |
| width_read_fb               | If NULL is specified, the size values of the frame buffer are assumed to be equal to the graphics display area width (gr_grc.hw) and height (gr_grc.vw). |
| vdc_onoff_t                 | Folding handling                                                                                                                                         |
|                             | -                                                                                                                                                        |

adj\_sel

| INZ/AZIVI GIOUP           | video Display Controller and Sprite Engine Sample Driver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | Specifies whether to take countermeasures for decreasing the influence by folding pixels in scale-up processing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                           | VDC_OFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                           | VDC_ON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| vdc_gr_format_t           | Format of the frame buffer read signal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| gr_format                 | <ul> <li>VDC_GR_FORMAT_RGB565 (0): RGB565</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                           | <ul> <li>VDC_GR_FORMAT_RGB888 (1): RGB888</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                           | <ul> <li>VDC_GR_FORMAT_ARGB1555 (2): ARGB1555</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                           | <ul> <li>VDC_GR_FORMAT_ARGB4444 (3): ARGB4444</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                           | <ul> <li>VDC_GR_FORMAT_ARGB8888 (4): ARGB8888</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                           | VDC_GR_FORMAT_CLUT8 (5): CLUT8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                           | VDC_GR_FORMAT_CLUT4 (6): CLUT4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                           | VDC_GR_FORMAT_CLUT1 (7): CLUT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                           | VDC_GR_FORMAT_YCBCR422 (8): YCbCr422 *      VDC_GR_FORMAT_YCBCR422 (8): YCbCr422 *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                           | VDC_GR_FORMAT_YCBCR444 (9): YCbCr444 *     VDC_GR_FORMAT_ROBALLET (42): ROBALLET (42): ROBA |
|                           | <ul> <li>VDC_GR_FORMAT_RGBA5551 (10): RGBA5551</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                           | VDC_GR_FORMAT_RGBA8888 (11): RGBA8888                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| vdc_gr_ycc_swap_t         | Swapping of data read from buffer in the YCbCr422 format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| gr_ycc_swap               | This parameter is valid only when gr_format is set to VDC_GR_FORMAT_YCBCR422.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                           | <ul><li>VDC_GR_YCCSWAP_CBY0CRY1 (0): CbY0/Cr/Y1</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                           | <ul><li>VDC_GR_YCCSWAP_Y0CBY1CR (1): Y0/Cb/Y1/Cr</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                           | <ul><li>VDC_GR_YCCSWAP_CRY0CBY1 (2): Cr/Y0/Cb/Y1</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                           | <ul><li>VDC_GR_YCCSWAP_Y0CRY1CB (3): Y0/Cr/Y1/Cb</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                           | <ul> <li>VDC_GR_YCCSWAP_Y1CRY0CB (4): Y1/Cr/Y0/Cb</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                           | <ul> <li>VDC_GR_YCCSWAP_CRY1CBY0 (5): Cr/Y1/Cb/Y0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                           | <ul> <li>VDC_GR_YCCSWAP_Y1CBY0CR (6): Y1/Cb/Y0/Cr</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                           | VDC_GR_YCCSWAP_CBY1CRY0 (7): Cb/Y1/Cr/Y0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| vdc_wr_rd_swa_t           | 8-bit, 16-bit, or 32-bit swap setting                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| gr_rdswa                  | <ul> <li>VDC_WR_RD_WRSWA_NON (0): 1-2-3-4-5-6-7-8</li> <li>No swap</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                           | <ul> <li>VDC_WR_RD_WRSWA_8BIT (1): 2-1-4-3-6-5-8-7</li> <li>8-bit swap</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                           | <ul> <li>VDC_WR_RD_WRSWA_16BIT (2): 3-4-1-2-7-8-5-6</li> <li>16-bit swap</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                           | <ul> <li>VDC_WR_RD_WRSWA_16_8BIT (3): 4-3-2-1-8-7-6-5</li> <li>16-bit + 8-bit swap</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                           | <ul> <li>VDC_WR_RD_WRSWA_32BIT (4): 5-6-7-8-1-2-3-4</li> <li>32-bit swap</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                           | <ul> <li>VDC_WR_RD_WRSWA_32_8BIT (5): 6-5-8-7-2-1-4-3</li> <li>32-bit + 8-bit swap</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                           | <ul> <li>VDC_WR_RD_WRSWA_32_16BIT (6): 7-8-5-6-3-4-1-2</li> <li>32-bit + 16-bit swap</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                           | <ul> <li>VDC_WR_RD_WRSWA_32_16_8BIT (7):<br/>8-7-6-5-4-3-2-1</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                           | 32-bit + 16-bit + 8-bit swap                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| vdc_period_rect_t         | Graphics display area                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| gr_grc                    | See 5.3(1) for the vdc_period_rect_t structure.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                           | gr_grc.vs should be 4 lines or more and gr_grc.vs + gr_grc.vw shold be equal to or less than 2039 lines.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                           | gr_grc.hs should be 16 clock cycles or more and gr_grc.hs + gr_grc.hw should be equal to or less than 2015 clock cycles.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Jaka, VChC=400 and VChC=4 | IAA can be enecified only for graphics 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

Note: YCbCr422 and YCbCr444 can be specified only for graphics 0.

The legitimate parameter values for the frame buffer address setting signal (gr\_flm\_sel) differ from layer to layer. See Table 6-4 for legitimate parameter values for the layers.

Table 6-4 Legitimate Frame Buffer Address Setting Signal Parameter Values

| Layer ID          | Legitimate Value            |
|-------------------|-----------------------------|
| VDC_LAYER_ID_0_RD | VDC_GR_FLM_SEL_SCALE_DOWN   |
|                   | VDC_GR_FLM_SEL_FLM_NUM      |
|                   | VDC_GR_FLM_SEL_POINTER_BUFF |
| VDC_LAYER_ID_2_RD | VDC_GR_FLM_SEL_FLM_NUM      |
| VDC_LAYER_ID_3_RD | VDC_GR_FLM_SEL_FLM_NUM      |

The members of the vdc\_width\_read\_fb\_t structure is described below.

# Type Description

| uint16_t | Number of lines in a frame (lines)            |   |
|----------|-----------------------------------------------|---|
| in_vw    | 0x0000 to 0x07FF                              |   |
| uint16_t | Width of the horizontal valid period (pixels) | , |
| in_hw    | 0x0000 to 0x07FF                              |   |

Figure 6-4 shows the relationship between the parameter settings for the frame buffer to be used during data read processing and the memory allocation.



Figure 6-4 Read Processing Frame Buffer Related Parameter Settings and Memory Allocation

The value of the frame buffer base address (gr\_base) need be changed according to the setting of the line offset address direction of the frame buffer (gr\_ln\_off\_dir).

- When gr\_ln\_off\_dir is set to VDC\_GR\_LN\_OFF\_DIR\_INC Data is read sequentially starting at the beginning of the frame buffer. Specify in gr\_base the start address of the frame buffer (Figure 6-4, (a)).
- When gr\_ln\_off\_dir is set to VDC\_GR\_LN\_OFF\_DIR\_DEC Data is read from the last line of the frame buffer. Specify in gr\_base the address of the last line in the frame buffer (Figure 6-4, (b)).

# 6.10 R\_VDC\_ChangeReadProcess

| Synopsis     | Data read change processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| Declaration  | vdc_error_t R_VDC_ChangeReadProcess( const vdc_channel_t ch, const vdc_layer_id_t layer_id, const vdc_read_chg_t * const param);                                                                                                                                                                                                                                                                                                                                                                                        |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         <ul> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> </ul> </li> <li>vdc_layer_id_t layer_id: Layer ID             <ul> <li>VDC_LAYER_ID_0_RD: Layer 0 read processing</li> <li>VDC_LAYER_ID_2_RD: Layer 2 read processing</li> <li>VDC_LAYER_ID_3_RD: Layer 3 read processing</li> </ul> </li> <li>vdc_read_chg_t * param: Data read change parameter Do not specify NULL.</li> </ul>                                                          |  |
| Return value | <ul> <li>vdc_error_t: Error code         <ul> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_PARAM_EXCEED_RANGE: Out-of-value-range error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul> </li> </ul> |  |

## Details

#### (1) **Function**

This function takes the following data read control actions during data read processing:

- Changes the frame buffer base address.
- Changes the frame buffer read size (image scale-up control, layer 0 only).
- Changes the display area for graphics images.
- Changes the graphics display mode.

#### (2) Use conditions

This function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) unless the layer specified in layer\_id of this function meets the following conditions:

- The specified layer is enabled.
- The specified layer is running.

A layer is enabled by calling the function R\_VDC\_ReadDataControl. A layer that is in the stopped state can be started by calling the function R\_VDC\_StartProcess.

Control of the vertical scale-up processing is mutually exclusive with the control of the vertical scale-down processing. Normal operation of the driver operation is not guaranteed if vertical scale-down and vertical scale-up are specified at the same time. The setup of vertical scale-down processing is accomplished by the functions R\_VDC\_WriteDataControl and R\_VDC\_ChangeWriteProcess.

#### (3) Parameter details

The members of the vdc\_read\_chg\_t structure is described below.

# Type Description

| MEHIDEI Maille              |                                                              |
|-----------------------------|--------------------------------------------------------------|
| void *                      | Frame buffer base address                                    |
| gr_base                     | Specify NULL when this parameter value is not to be changed. |
| const vdc_width_read_fb_t * | Size of the frame buffer to be read                          |
| width_read_fb               | See 6.9(3) for the vdc_width_read_fb_t structure.            |
|                             | Specify NULL when this parameter value is not to be changed. |
| const vdc_period_rect_t *   | Graphics display area                                        |
| gr_grc                      | See 5.3(1) for the vdc_period_rect_t structure.              |
|                             | Specify NULL when this parameter value is not to be changed. |
| const vdc_gr_disp_sel_t *   | Graphics display mode                                        |
| gr_disp_sel                 | See 5.2(9) and 6.11(3) for details.                          |
|                             | Specify NULL when this parameter value is not to be changed. |

The values of the parameters in the vdc\_read\_chg\_t structure are not changed if NULL is specified for the parameters. The parameters in gr\_base, width\_read\_fb and gr\_grc retain the values that have been set up by the function R\_VDC\_ReadDataControl. The parameter in gr\_disp\_sel retains the value that has been set up by the function R\_VDC\_StartProcess.

# 6.11 R\_VDC\_StartProcess

| Synopsis     | Data write/read start processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| Declaration  | vdc_error_t R_VDC_StartProcess(     const vdc_channel_t                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         — VDC_CHANNEL_0: Channel 0         Specify channel 0 in this driver.</li> <li>vdc_layer_id_t layer_id: Layer ID         — VDC_LAYER_ID_ALL: All enabled layers         — VDC_LAYER_ID_0_WR: Layer 0 write processing         — VDC_LAYER_ID_0_RD: Layer 0 read processing         — VDC_LAYER_ID_2_RD: Layer 2 read processing         — VDC_LAYER_ID_3_RD: Layer 3 read processing</li> <li>vdc_start_t * param: Data write/read start parameter         Do not specify NULL.</li> </ul> |  |  |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul>                                                                                                                                                  |  |  |

# Details

#### (1) **Function**

This function performs layer start processing. If the layer ID specified in layer\_id is VDC\_LAYER\_ID\_ALL, the function starts all the layers that are in the stopped state and also enabled. If the layer ID is not VDC\_LAYER\_ID\_ALL, the function starts only the specified layer.

When performing start processing for write, the function starts a write to the frame buffer. When performing start processing for read, the function starts a read from the frame buffer and sets the graphics display mode to the specified values for each layer.

#### (2) Use conditions

No particular use conditions are imposed if layer\_id is found to be set to VDC\_LAYER\_ID\_ALL when the function is used. In the other cases, the conditions listed below apply. If these conditions are not met, the function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER).

- The specified layer is enabled.
- The specified layer is stopped.

Layers involved in write processing are enabled by calling the function R\_VDC\_WriteDataControl and layers involved in read processing are enabled by calling the function R\_VDC\_ReadDataControl. Layers that are running can be stopped by calling the function R\_VDC\_StopProcess.

#### (3) Parameter details

The members of the vdc\_start\_t structure is described below.

# Туре

# Member Name

#### **Description**

```
const vdc_gr_disp_sel_t *

gr_disp_sel

See 5.2(9) and the following description for details.

Specify NULL when this parameter value is not to be changed.

This setting pertains to the graphics (read processing).

This setting is invalid if a layer for write processing is specified in layer_id.
```

See the sample settings given below for the setup of gr disp sel.

When specifying VDC\_LAYER\_ID\_ALL in layer\_id
 Specify the graphics display settings for all the graphics (layers for read processing).
 Specify VDC\_DISPSEL\_IGNORED for layers that need no change.

```
1
        vdc_error_t
2
        vdc_gr_disp_sel_t
                                gr_disp_sel[VDC_GR_TYPE_NUM];
3
        vdc_start_t
                                start;
4
5
        gr_disp_sel[VDC_GR_TYPE_GR0] = VDC_DISPSEL_IGNORED;
6
        gr_disp_sel[VDC_GR_TYPE_GR2] = VDC_DISPSEL_CURRENT;
7
        gr_disp_sel[VDC_GR_TYPE_GR3] = VDC_DISPSEL_BLEND;
8
9
        start.gr_disp_sel
                                       = gr_disp_sel;
10
11
        error = R_VDC_StartProcess(VDC_CHANNEL_0, VDC_LAYER_ID_ALL, &start);
```

2. When specifying a single layer in layer\_id

Specify the graphics display mode only for the specified graphics (layer for read processing). Given below are example settings for graphics 2 (read process for layer 2).

```
1
        vdc_error_t
                                error;
2
        vdc_gr_disp_sel_t
                                gr_disp_sel;
3
        vdc_start_t
                                start;
4
5
        gr_disp_sel
                             = VDC_DISPSEL_CURRENT;
6
7
        start.gr_disp_sel
                             = &gr_disp_sel;
8
9
        error = R_VDC_StartProcess(VDC_CHANNEL_0, VDC_LAYER_ID_2_RD, &start);
```

The graphics display mode for the layers are initialized by the driver when calling the function R\_VDC\_DisplayOutput, R\_VDC\_ReadDataControl, and R\_VDC\_StopProcess. If they are not changed through the function R\_VDC\_StartProcess, the initial values that are set up by the driver are retained. Table 6-5 shows the initial values of the graphics display mode for the layers.

**Table 6-5 Graphics Display Mode Initial Values** 

| Layer ID          | Initial Value     | Description                            |
|-------------------|-------------------|----------------------------------------|
| VDC_LAYER_ID_0_RD | VDC_DISPSEL_BACK  | Displays background color if not used. |
| VDC_LAYER_ID_2_RD | VDC_DISPSEL_LOWER | Displays the lower layers if not used. |
| VDC_LAYER_ID_3_RD | VDC_DISPSEL_LOWER | Displays the lower layers if not used. |

For the graphics display mode, VDC\_DISPSEL\_BACK is specified to display background color, and VDC\_DIPSEL\_CURRENT is specified to display the graphics. Other values are specified depending on the layer and its purpose of use.

Table 6-6 Graphics Display Mode and Uses

| Layer ID            | Value             | Use                                                                      |
|---------------------|-------------------|--------------------------------------------------------------------------|
| VDC_LAYER_ID_0_RD   | VDC_DISPSEL_LOWER | Displays the input video image.                                          |
|                     |                   | Displays the enlarged graphics.                                          |
|                     | VDC_DISPSEL_BLEND | Displays the graphics processed by the                                   |
|                     |                   | chroma-key.                                                              |
| VDC_LAYER_ID_2_RD / | VDC_DISPSEL_LOWER | Displays the lower-layer graphics.                                       |
| VDC_LAYER_ID_3_RD   | VDC_DISPSEL_BLEND | Displays the blended image of lower-layer graphics and current graphics. |

# 6.12 R\_VDC\_StopProcess

| Synopsis     | Data write/read stop processing                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Declaration  | vdc_error_t R_VDC_StopProcess( const vdc_channel_t ch, const vdc_layer_id_t layer_id);                                                                                                                                                                                                                                                                                                                                                                                           |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         <ul> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> </ul> </li> <li>vdc_layer_id_t layer_id: Layer ID             <ul> <li>VDC_LAYER_ID_ALL: All enabled layers</li> <li>VDC_LAYER_ID_0_WR: Layer 0 write processing</li> <li>VDC_LAYER_ID_0_RD: Layer 0 read processing</li> <li>VDC_LAYER_ID_2_RD: Layer 2 read processing</li> <li>VDC_LAYER_ID_3_RD: Layer 3 read processing</li> </ul> </li> </ul> |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul>                                                                                                                                                                                                                              |

#### Details

#### (1) **Function**

This function performs layer stop processing. If the layer ID specified in layer\_id is VDC\_LAYER\_ID\_ALL, the function stops all the layers that are enabled and running. If the layer ID is not VDC\_LAYER\_ID\_ALL, the function stops only the specified layer.

When performing stop processing for write, the function stops the write to the frame buffer. When performing stop processing for read, the function stops the read from the frame buffer and resets the graphics display mode to the initial values for each of the layers. See Table 6-5 for the initial values of the graphics display mode.

#### (2) Use conditions

No particular use conditions are imposed if layer\_id is found to be set to VDC\_LAYER\_ID\_ALL when the function is used. In the other cases, the conditions listed below apply. If these conditions are not met, the function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER).

- The specified layer is enabled.
- The specified layer is running.

Layers involved in write processing are enabled by calling the function  $R_VDC_W$ riteDataControl and layers involved in read processing are enabled by calling the function  $R_VDC_R$ eadDataControl. Layers that are in the stopped state can be started by calling the function  $R_VDC_R$ eadDataControl.



# 6.13 R\_VDC\_ReleaseDataControl

| Synopsis     | Data write/read control release processing                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| Declaration  | vdc_error_t R_VDC_ReleaseDataControl( const vdc_channel_t ch, const vdc_layer_id_t layer_id);                                                                                                                                                                                                                                                                                                                                        |  |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel</li> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> <li>vdc_layer_id_t layer_id: Layer ID</li> <li>VDC_LAYER_ID_ALL: All enabled layers</li> <li>VDC_LAYER_ID_0_WR: Layer 0 write processing</li> <li>VDC_LAYER_ID_0_RD: Layer 0 read processing</li> <li>VDC_LAYER_ID_2_RD: Layer 2 read processing</li> <li>VDC_LAYER_ID_3_RD: Layer 3 read processing</li> </ul> |  |  |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul>                                                                                                                                                                                  |  |  |

#### Details

#### (1) Function

This function performs the following processing:

• Disables the specified layer.

If the layer ID specified in layer\_id is VDC\_LAYER\_ID\_ALL, the function disables all the layers that are not running and also enabled. If the layer ID is not VDC\_LAYER\_ID\_ALL, the function disables only the specified layers.

# (2) Use conditions

No particular use conditions are imposed if layer\_id is found to be set to VDC\_LAYER\_ID\_ALL when the function is used. In the other cases, the conditions listed below apply. If these conditions are not met, the function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER).

- The specified layer is enabled.
- The specified layer is stopped.

Layers involved in write processing are enabled by calling the function  $R_VDC_W$ riteDataControl and layers involved in read processing are enabled by calling the function  $R_VDC_R$ eadDataControl. Layers that are running can be stopped by calling the function  $R_VDC_S$ topProcess.



# 6.14 R\_VDC\_VideoNoiseReduction

| Synopsis     | Noise reduction setup                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                           |  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                           |  |
| Declaration  | vdc_error_t R_VDC_VideoNoiseReduction(                                                                                                                                                                                                                                                                                                                                                   | ch,<br>nr1d_on,<br>* const param);                                                                        |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         VDC_CHANNEL_0: Channel 0         Specify channel 0 in this driver.     </li> <li>vdc_onoff_t nr1d_on: Noise reduction ON/O</li> <li>vdc_noise_reduction_t * param: Noise reduction on the setting is not changed if NULL is specific up after a hardware reset, the initial value the remains valid. See the description about the</li> </ul> | etion setup parameter<br>ed. If this parameter has never been set<br>at is defined in the hardware manual |  |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channe</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit wid</li> <li>VDC_ERR_PARAM_UNDEFINED: Under VDC_ERR_RESOURCE_INPUT: Input serior</li> </ul>                                                                                                                                            | dth error<br>efined parameter specification error                                                         |  |

#### Details

#### (1) Function

This function performs the following noise reduction processing:

- Turns on and off noise reduction processing.
- Sets up the noise reduction parameters for the Y/G, Cb/B, and Cr/R signals.

The setup of noise reduction parameters and noise reduction ON/OFF control can be made separately. Once set up noise reduction parameters remain valid until a hardware reset occurs or they are overwritten by this function with other settings.

#### (2) Use conditions

Before this function is used, it is necessary to enable a video input by calling the function R\_VDC\_VideoInput. If no video input is enabled, the function returns an input signal resource error (VDC\_ERR\_RESOURCE\_INPUT).



#### (3) Parameter details

The members of the vdc\_noise\_reduction\_t are described below.

```
typedef struct
{
    vdc_nr_param_t     y;
    vdc_nr_param_t     cb;
    vdc_nr_param_t     cr;
} vdc_noise_reduction_t;
```

# Type Member Name vdc\_nr\_param\_t y vdc\_nr\_param\_t cb Vdc\_nr\_param\_t Cr/R signal noise reduction parameter Cr/R signal noise reduction parameter

The members of the vdc\_nr\_param\_t structure is described below.

| Type<br>Member Name | Initial Value | Description                                                |  |
|---------------------|---------------|------------------------------------------------------------|--|
| vdc_nr_tap_t        | 0             | TAP select                                                 |  |
| nr1d_tap            |               | <ul> <li>VDC_NR_TAPSEL_1 (0): Adjacent pixel</li> </ul>    |  |
|                     |               | <ul> <li>VDC_NR_TAPSEL_2 (1): 2 adjacent pixels</li> </ul> |  |
|                     |               | <ul> <li>VDC_NR_TAPSEL_3 (2): 3 adjacent pixels</li> </ul> |  |
|                     |               | <ul> <li>VDC_NR_TAPSEL_4 (3): 4 adjacent pixels</li> </ul> |  |
| uint32_t            | 8             | Maximum value of coring (absolute value)                   |  |
| nr1d_th             |               | 0x0000 to 0x007F                                           |  |
| vdc_nr_gain_t       | 3             | Noise reduction gain adjustment                            |  |
| nr1d_gain           |               | <ul> <li>VDC_NR_GAIN_1_2 (0): 1/2</li> </ul>               |  |
|                     |               | <ul> <li>VDC_NR_GAIN_1_4 (1): 1/4</li> </ul>               |  |
|                     |               | <ul> <li>VDC_NR_GAIN_1_8 (2): 1/8</li> </ul>               |  |
|                     |               | <ul> <li>VDC_NR_GAIN_1_16 (3): 1/16</li> </ul>             |  |

# 6.15 R\_VDC\_ImageColorMatrix

| Synopsis     | Color matrix setup                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Declaration  | vdc_error_t R_VDC_ImageColorMatrix(                                                                                                                                                                                                                                                                                                                                                                                                          |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel</li> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> <li>vdc_color_matrix_t * param: Color matrix setup parameter</li> <li>Do not specify NULL.</li> </ul>                                                                                                                                                                                                                   |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_PARAM_CONDITION: Unauthorized condition error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul> |

#### Details

## (1) **Function**

This function sets up the specified color matrix. The VDC incorporated into the RZ/A1L has two color matrixes (see Figure 6-5).

The color matrixes automatically set up by the VDC driver according to the color format to be used. Consequently, this function need not be used except when there is a need to change color matrix values dynamically. The automatic setup of the color matrixes by the VDC driver proceeds as follows:

- When the function R\_VDC\_WriteDataControl is called
  - The driver determines the necessary color conversion from the input format of the video image and the frame buffer video-signal writing format that is designated by the function R\_VDC\_WriteDataControl and sets it up in the color matrix in the input controller.
- When the function R\_VDC\_ReadDataControl is called for layer 0 read processing
  - The driver determines the necessary color conversion from the format of the frame buffer read signal designated by the function R\_VDC\_ReadDataControl and sets it up in the color matrix in image quality improver 0.

See 5.5 for the values of the color matrixes that are automatically set up by the VDC driver.



Figure 6-5 Color Matrixes

#### (2) Use conditions

When this function is to be used to make settings for the color matrix in the input controller, the write process for layer 0 needs to be enabled. The write process for layer 0 is enabled by calling the function R\_VDC\_WriteDataControl.

When this function is to be used to make settings for the color matrix in the image quality improver 0, the read process for layer 0 needs to be enabled. The read process for layer 0 is enabled by calling the function R\_VDC\_ReadDataControl.

The function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) if it is called when the layers associated with the color matrix are disabled.

#### (3) Parameter details

The members of the vdc\_color\_matrix\_t structure is described below.

```
typedef struct
{
    vdc_colormtx_module_t module;
    vdc_colormtx_mode_t mtx_mode;
    uint16_t offset[VDC_COLORMTX_OFFST_NUM];
    uint16_t gain[VDC_COLORMTX_GAIN_NUM];
} vdc_color_matrix_t;
```

# Type

# Description

| Member Name                    | Description                                                          |  |  |
|--------------------------------|----------------------------------------------------------------------|--|--|
| vdc_colormtx_module_t          | Color matrix module                                                  |  |  |
| module                         | <ul> <li>VDC_COLORMTX_IMGCNT (0): Input controller</li> </ul>        |  |  |
|                                | <ul> <li>VDC_COLORMTX_ADJ_0 (1): Image quality improver 0</li> </ul> |  |  |
| vdc_colormtx_mode_t            | Operating mode                                                       |  |  |
| mtx_mode                       | <ul> <li>VDC_COLORMTX_GBR_GBR: GBR → GBR</li> </ul>                  |  |  |
|                                | <ul> <li>VDC_COLORMTX_GBR_YCBCR: GBR → YCbCr *</li> </ul>            |  |  |
|                                | <ul> <li>VDC_COLORMTX_YCBCR_GBR: YCbCr → GBR</li> </ul>              |  |  |
|                                | <ul><li>VDC_COLORMTX_YCBCR_YCBCR:</li></ul>                          |  |  |
|                                | YCbCr → YCbCr *                                                      |  |  |
| uint16_t                       | Offset (DC) adjustment of Y/G, B, and R signal                       |  |  |
| offset[VDC_COLORMTX_OFFST_NUM] | 0x0000 (-128) to 0x0080 (0) to 0x00FF (+127)                         |  |  |
| uint16_t                       | GG, GB, GR, BG, BB, BR, RG, RB, and RR signal gain                   |  |  |
| gain[VDC_COLORMTX_GAIN_NUM]    | adjustment                                                           |  |  |
|                                | Signed (2's complement)                                              |  |  |
|                                | -1024 to +1023[LSB], 256[LSB] = 1.0[times]                           |  |  |

Note: The operating mode in which conversion to YCbCr is performed is made available only when the input controller (VDC\_COLORMTX\_IMGCNT) is specified in module.

vdc\_colormtx\_offset\_t is an enumeration type for representing the color matrix offset.

```
typedef enum
{
    VDC_COLORMTX_OFFST_YG = 0,
    VDC_COLORMTX_OFFST_B,
    VDC_COLORMTX_OFFST_R,
    VDC_COLORMTX_OFFST_NUM
} vdc_colormtx_offset_t;
```

| Enumeration Constant Value |   | Description                              |
|----------------------------|---|------------------------------------------|
| VDC_COLORMTX_OFFST_YG 0    |   | Offset (DC) adjustment of Y/G signal     |
| VDC_COLORMTX_OFFST_B       | 1 | Offset (DC) adjustment of B signal       |
| VDC_COLORMTX_OFFST_R       | 2 | Offset (DC) adjustment of R signal       |
| VDC_COLORMTX_OFFST_NUM     | 3 | Number of color matrix offset parameters |

vdc\_colormtx\_gain\_t is an enumeration type for representing the color matrix gain.

```
typedef enum
{
    VDC_COLORMTX_GAIN_GG = 0,
    VDC_COLORMTX_GAIN_GB,
    VDC_COLORMTX_GAIN_GR,
    VDC_COLORMTX_GAIN_BG,
    VDC_COLORMTX_GAIN_BB,
    VDC_COLORMTX_GAIN_BR,
    VDC_COLORMTX_GAIN_RG,
    VDC_COLORMTX_GAIN_RB,
    VDC_COLORMTX_GAIN_RB,
    VDC_COLORMTX_GAIN_RR,
    VDC_COLORMTX_GAIN_NUM
} vdc_colormtx_gain_t;
```

| Enumeration constant   | Value | Description                                        |
|------------------------|-------|----------------------------------------------------|
| VDC_COLORMTX_GAIN_GG 0 |       | Y/G signal gain adjustment for Y/G signal output   |
| VDC_COLORMTX_GAIN_GB   | 1     | Cb/B signal gain adjustment for Y/G signal output  |
| VDC_COLORMTX_GAIN_GR   | 2     | Cr/R signal gain adjustment for Y/G signal output  |
| VDC_COLORMTX_GAIN_BG   | 3     | Y/G signal gain adjustment for Cb/B signal output  |
| VDC_COLORMTX_GAIN_BB   | 4     | Cb/B signal gain adjustment for Cb/B signal output |
| VDC_COLORMTX_GAIN_BR 5 |       | Cr/R signal gain adjustment for Cb/B signal output |
| VDC_COLORMTX_GAIN_RG   | 6     | Y/G signal gain adjustment for Cr/R signal output  |
| VDC_COLORMTX_GAIN_RB   | 7     | Cb/B signal gain adjustment for Cr/R signal output |
| VDC_COLORMTX_GAIN_RR   | 8     | Cr/R signal gain adjustment for Cr/R signal output |
| VDC_COLORMTX_GAIN_NUM  | 9     | Number of color matrix gain parameters             |

# 6.16 R\_VDC\_ImageEnhancement

Synopsis Image enhancement processing Header r\_vdc.h Declaration vdc error t R VDC ImageEnhancement( const vdc\_channel\_t ch, const vdc\_imgimprv\_id\_t imgimprv\_id, const vdc onoff t shp h on, const vdc\_enhance\_sharp\_t \* const sharp\_param, const vdc\_onoff\_t lti\_h\_on, \* const lti\_param, const vdc enhance Iti t const vdc\_period\_rect\_t \* const enh\_area); Arguments vdc\_channel\_t ch: Channel — VDC CHANNEL 0: Channel 0 Specify channel 0 in this driver. vdc imgimprv id t imgimprv id: Image quality improver ID VDC IMG IMPRV 0: Image quality improver 0 Specify image quality improver 0 in this driver. vdc\_onoff\_t shp\_h\_on: Sharpness ON/OFF setting vdc enhance sharp t \* sharp param: Sharpness setup parameter The setting is not changed if NULL is specified. vdc onoff t lti h on: LTI ON/OFF setting vdc\_enhance\_lti\_t \* lti\_param: LTI setup parameter The setting is not changed if NULL is specified. vdc period rect t \* enh area: Enhancer-enabled area setup parameter The setting is not changed if NULL is specified. If parameters described above have never been set up after a hardware reset, the initial values that are defined in the hardware manual remain valid. See the description about the structure for the initial value. Return value vdc\_error\_t: Error code — VDC OK: Normal termination — VDC\_ERR\_PARAM\_CHANNEL: Channel invalid error — VDC\_ERR\_PARAM\_BIT\_WIDTH: Bit width error — VDC\_ERR\_PARAM\_UNDEFINED: Undefined parameter specification error — VDC ERR PARAM EXCEED RANGE: Out-of-value-range error — VDC ERR IF CONDITION: Interface condition error — VDC\_ERR\_RESOURCE\_LAYER: Layer resource error

#### Details

#### Function (1)

This function performs the following image quality improvement processing:

- Turns on and off sharpness processing.
- Sets up the sharpness parameter.
- Turns on and off LTI processing.
- Sets up the LTI parameter.
- Sets up the enhancer-enabled area to be subjected to sharpness and LTI processing.

The setup of parameters and ON/OFF control for sharpness and LTI processing can be made separately. The parameters that are once set up remain valid until a hardware reset occurs or they are overwritten by this function with other settings.

#### Use conditions (2)

When this function is to be used, the read process for layer 0 needs to be enabled. The read process for layer 0 is enabled by calling the function R\_VDC\_ReadDataControl for layer 0. The function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) if the read process for layer 0 is disabled.

This processing is inhibited if the color format (format of the frame buffer read signal) of the layer 0 is set to the format other than YCbCr422 and YCbCr444. In such a case, the function returns an interface condition error (VDC\_ERR\_IF\_CONDITION).

#### Parameter details

vdc\_enhance\_sharp\_t structure is described below.

```
typedef struct
    vdc_onoff_t
                           shp_h2_lpf_sel;
    vdc_sharpness_ctrl_t
                           hrz_sharp[VDC_IMGENH_SHARP_NUM];
} vdc_enhance_sharp_t;
```

| Nember Name            | Initial Value | Description                                         |
|------------------------|---------------|-----------------------------------------------------|
| vdc_onoff_t            | VDC_OFF       | LPF selection for folding prevention before H2 edge |
| shp_h2_lpf_sel         | (0)           | detection                                           |
|                        |               | <ul> <li>VDC_OFF: LPF not selected</li> </ul>       |
|                        |               | <ul> <li>VDC_ON: LPF selected</li> </ul>            |
| vdc_sharpness_ctrl_t   | -             | Sharpness control parameter                         |
| hrz_sharp              |               | Horizontal sharpness (H1, H2, H3)                   |
| [VDC_IMGENH_SHARP_NUM] |               |                                                     |

vdc\_img\_enh\_sh\_t is an enumeration type for representing the sharpness band.

```
typedef enum
    VDC_IMGENH_SHARP_H1 = 0,
    VDC_IMGENH_SHARP_H2,
   VDC_IMGENH_SHARP_H3,
    VDC_IMGENH_SHARP_NUM
} vdc_img_enh_sh_t;
```

| Enumeration constant | Value | Description                          |
|----------------------|-------|--------------------------------------|
| VDC_IMGENH_SHARP_H1  | 0     | Horizontal sharpness (H1)            |
| VDC_IMGENH_SHARP_H2  | 1     | Horizontal sharpness (H2)            |
| VDC_IMGENH_SHARP_H3  | 2     | Horizontal sharpness (H3)            |
| VDC_IMGENH_SHARP_NUM | 3     | Number of horizontal sharpness bands |

The members of the vdc\_sharpness\_ctrl\_t structure is described below.

```
typedef struct
        uint8_t shp_clip_o;
uint8_t shp_clip_u;
uint8_t shp_gain_o;
uint8_t shp_gain_u;
uint8_t shp_core;
} vdc_sharpness_ctrl_t;
```

| Type<br>Member Name | Initial Value | Description                                                    |
|---------------------|---------------|----------------------------------------------------------------|
| uint8_t             | 0             | Sharpness correction value clipping (on the overshoot side)    |
| shp_clip_o          |               | 0x0000 to 0x00FF                                               |
| uint8_t             | 0             | Sharpness correction value clipping (on the undershoot side)   |
| shp_clip_u          |               | 0x0000 to 0x00FF                                               |
| uint8_t             | 0             | Sharpness edge amplitude value gain (on the overshoot side)    |
| shp_gain_o          |               | 0x0000 (0 time) to 0x0040 (1 time) to 0x00FF (approx. 4 times) |
| uint8_t             | 0             | Sharpness edge amplitude value gain (on the undershoot         |
| shp_gain_u          |               | side)                                                          |
|                     |               | 0x0000 (0 time) to 0x0040 (1 time) to 0x00FF (approx. 4 times) |
| uint8_t             | 0             | Active sharpness range                                         |
| shp_core            |               | 0x0000 to 0x007F                                               |

The members of the vdc\_enhance\_lti\_t structure is described below.

#### Type Initial Value Description **Member Name** VDC\_OFF vdc\_onoff\_t LPF selection for folding prevention before H2 edge detection lti\_h2\_lpf\_sel (0) VDC\_OFF: LPF not selected VDC\_ON: LPF selected vdc\_lti\_mdfil\_sel\_t 0 Median filter reference pixel select lti\_h4\_median\_tap\_sel • VDC\_LTI\_MDFIL\_SEL\_ADJ2 (0): Second adjacent pixel selected as reference VDC\_LTI\_MDFIL\_SEL\_ADJ1 (1): Adjacent pixel selected as reference vdc\_lti\_ctrl\_t LTI control parameter Horizontal LTI (H2, H4) lti[VDC\_IMGENH\_LTI\_NUM]

vdc\_img\_enh\_lti\_t is an enumeration type for representing the LTI band.

```
typedef enum
{
    VDC_IMGENH_LTI1 = 0,
    VDC_IMGENH_LTI2,
    VDC_IMGENH_LTI_NUM
} vdc_img_enh_lti_t;
```

| Enumeration constant | Value | Description                             |
|----------------------|-------|-----------------------------------------|
| VDC_IMGENH_LTI1      | 0     | Horizontal LTI (H2)                     |
|                      |       | Second adjacent pixel used as reference |
| VDC_IMGENH_LTI2      | 1     | Horizontal LTI (H4)                     |
|                      |       | Fourth adjacent pixel used as reference |
| VDC_IMGENH_LTI_NUM   | 2     | Number of LTI bands.                    |

The members of the vdc\_lti\_ctrl\_t structure is described below.

```
typedef struct
{
    uint8_t    lti_inc_zero;
    uint8_t    lti_gain;
    uint8_t    lti_core;
} vdc_lti_ctrl_t;
```

#### **Type** Initial Value Description **Member Name** 10 Median filter LTI correction threshold uint8\_t 0x0000 to 0x00FF lti\_inc\_zero 0 LTI edge amplitude value gain uint8\_t 0x0000 (0 time) to 0x0040 (1 time) to 0x00FF (approx. 4 lti\_gain times) uint8\_t 0 LTI coring 0x0000 to 0x00FF lti\_core

See also 5.3(1) for the vdc\_period\_rect\_t structure.

| Type<br>Member Name | Initial Value | Description                                                 |
|---------------------|---------------|-------------------------------------------------------------|
| uint16_t            | 0             | Start position of vertical valid image area in enhancer-    |
| VS                  |               | enabled area (lines)                                        |
|                     |               | Set to 2 or greater lines.                                  |
| uint16_t            | 0             | Width of vertical valid image area in enhancer-enabled area |
| VW                  |               | (lines)                                                     |
| uint16_t            | 0             | Start position of horizontal valid image area in enhancer-  |
| hs                  |               | enabled area (clock cycles)                                 |
|                     |               | Set to 4 or greater clocks.                                 |
| uint16_t            | 0             | Width of horizontal valid image area in enhancer-enabled    |
| hw                  |               | area (clock cycles)                                         |

## 6.17 R\_VDC\_ImageBlackStretch

| Synopsis     | Black stretch setup                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| Declaration  | vdc_error_t R_VDC_ImageBlackStretch(                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         — VDC_CHANNEL_0: Channel 0         Specify channel 0 in this driver.</li> <li>vdc_imgimprv_id_t imgimprv_id: Image quality improver ID         — VDC_IMG_IMPRV_0: Image quality improver 0         Specify image quality improver 0 in this driver.</li> <li>vdc_onoff_t bkstr_on: Black stretch ON/OFF setting</li> <li>vdc_black_t * param: Black stretch setup parameter         The setting is not changed if NULL is specified. If this parameter has never been set up after a hardware reset, the initial value that is defined in the hardware manual remains valid. See the description about the structure for the initial value.</li> </ul> |  |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_PARAM_EXCEED_RANGE: Out-of-value-range error</li> <li>VDC_ERR_IF_CONDITION: Interface condition error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul>                                                                                                                                                                                                                                                    |  |

## Details

## (1) **Function**

This function performs the following black stretch processing for the specified image quality improver:

- Turns on and off black stretch processing.
- Sets up the black stretch parameters.

The setup of parameters and ON/OFF control of the black stretch processing can be made separately. The settings once established by this function remain valid until a hardware reset occurs or they are overwritten by this function with other settings.

#### (2) Use conditions

When this function is to be used, the read process for layer 0 needs to be enabled. The read process for layer 0 is enabled by calling the function R\_VDC\_ReadDataControl for layer 0. The function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) if the read process for layer 0 is disabled.

This processing is inhibited if the color format (format of the frame buffer read signal) of the layer 0 is set to the format other than YCbCr422 and YCbCr444. In such a case, the function returns an interface condition error (VDC\_ERR\_IF\_CONDITION).

## (3) Parameter details

vdc\_black\_t structure is described below.

| Type<br>Member Name | Initial Value | Description                      |  |
|---------------------|---------------|----------------------------------|--|
| uint16_t            | 0             | Black stretch start point        |  |
| bkstr_st            |               | 0 (low) to 15 (high)             |  |
| uint16_t            | 0             | Black stretch depth              |  |
| bkstr_d             |               | 0 (shallow) to 15 (deep)         |  |
| uint16_t            | 0             | Black stretch time constant (T1) |  |
| bkstr_t1            |               | 0 (small) to 31 (large)          |  |
| uint16_t            | 0             | Black stretch time constant (T2) |  |
| bkstr_t2            |               | 0 (small) to 30 (large)          |  |

## 6.18 R\_VDC\_AlphaBlending

| Synopsis     | Alpha blending setup                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Declaration  | vdc_error_t R_VDC_AlphaBlending(const vdc_channel_tch,const vdc_layer_id_tlayer_id,const vdc_alpha_blending_t* const param);                                                                                                                                                                                                                                                                                         |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         <ul> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> </ul> </li> <li>vdc_layer_id_t layer_id: Layer ID             <ul> <li>VDC_LAYER_ID_2_RD: Layer 2 read processing</li> <li>VDC_LAYER_ID_3_RD: Layer 3 read processing</li> </ul> </li> <li>vdc_alpha_blending_t * param: Alpha blending setup parameter Do not specify NULL.</li> </ul> |  |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul>                                                                                                            |  |

### Details

#### (1) Function

This function performs the following processing for alpha blending except for rectangle alpha blending:

- Sets up the alpha value of the ARGB1555/RGBA5551 formats.
- Make settings for premultiplication processing at alpha blending in one-pixel.

This function can set up the alpha value of ARGB1555/RGBA5551 for layer 2 and 3 read processes. The alpha value ARGB1555/RGBA5551 which is used for layer 0 read process is automatically set to '255 (= 1.0, nontransparent)' by the driver.

#### (2) Use conditions

When this function is to be used, the layer specified in layer\_id needs to be enabled. The layer is enabled by calling and executing the function R\_VDC\_ReadDataControl on that layer. The function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) if the layer specified in layer\_id is found disabled.

#### (3) Parameter details

The members of the vdc\_alpha\_blending\_t structure is described below.

## Type Description

| mombo: mamo                  |                                                             |
|------------------------------|-------------------------------------------------------------|
| const vdc_alpha_argb1555_t * | Alpha signal of the ARGB1555/RGBA5551 formats               |
| alpha_1bit                   | The setting is not changed if NULL is specified.            |
| const vdc_alpha_pixel_t *    | Premultiplication processing at alpha blending in one-pixel |
| alpha_pixel                  | The setting is not changed if NULL is specified.            |

If the parameters alpha\_1bit and alpha\_pixel have never been set up after a hardware reset, their initial values that are defined in the hardware manual remain valid. See the description about the structures for the initial values.

The members of the vdc\_alpha\_argb1555\_t structure is described below.

```
typedef struct
{
    uint8_t gr_a0;
    uint8_t gr_a1;
} vdc_alpha_argb1555_t;
```

# Type Initial Value Description

| uint8_t | 0 | Alpha signal when alpha is set to '0' |  |
|---------|---|---------------------------------------|--|
| gr_a0   |   | 0 to 255                              |  |
| uint8_t | 0 | Alpha signal when alpha is set to '1' |  |
| _gr_a1  |   | 0 to 255                              |  |

The members of the vdc\_alpha\_pixel\_t structure is described below.

```
typedef struct.
{
    vdc_onoff_t gr_acalc_md;
} vdc_alpha_pixel_t;
```

| Туре        |                |             |
|-------------|----------------|-------------|
| . )   0     | AuleV leitial  | Description |
| Mambar Nama | iiiiliai vaiue | Description |

| Member Name |         | •                                                           |
|-------------|---------|-------------------------------------------------------------|
| vdc_onoff_t | VDC_OFF | Premultiplication processing at alpha blending in one-pixel |
| gr_acalc_md | (0)     | units                                                       |
|             |         | <ul><li>VDC_OFF</li></ul>                                   |
|             |         | VDC ON                                                      |

## 6.19 R\_VDC\_AlphaBlendingRect

| Synopsis     | Rectangle alpha blending setup                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Declaration  | vdc_error_t R_VDC_AlphaBlendingRect(         const vdc_channel_t       ch,         const vdc_layer_id_t       layer_id,         const vdc_onoff_t       gr_arc_on,         const vdc_alpha_blending_rect_t       * const param);                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         — VDC_CHANNEL_0: Channel 0         Specify channel 0 in this driver.</li> <li>vdc_layer_id_t layer_id: Layer ID         — VDC_LAYER_ID_2_RD: Layer 2 read processing         — VDC_LAYER_ID_3_RD: Layer 3 read processing</li> <li>vdc_onoff_t gr_arc_on: ON/OFF setting for alpha blending in a rectangular area</li> <li>vdc_alpha_blending_rect_t * param:         Setup parameter for alpha blending in a rectangular area         The setting is not changed if NULL is specified. See the description about the structure for the initial value.</li> </ul> |  |  |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_EXCEED_RANGE: Out-of-value-range error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul>                                                                                                                                                                                                                                          |  |  |

## Details

## (1) **Function**

This function performs the following processing for rectangle alpha blending:

- Turns on and off alpha blending in a rectangular area.
- Sets up the rectangular area subjected to alpha blending.
- Sets up the alpha value for alpha blending in a rectangular area.
- Makes fade-in/-out settings to be applied to rectangle alpha blending.

The setup and ON/OFF control of the alpha blending in rectangular area can be made separately. The alpha blending settings once established by this function remain valid until a hardware reset occurs, until overwritten with other settings, or until the specified layer resources are destroyed by the function R\_VDC\_ReleaseDataControl.



#### (2) Use conditions

When this function is to be used, the specified layer needs to be enabled. The layer is enabled by calling the function R\_VDC\_ReadDataControl on that layer. The function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) if the layer specified in layer\_id is found disabled.

#### (3) Parameter details

The members of the vdc\_alpha\_blending\_rect\_t structure is described below.

```
typedef struct
{
    const vdc_pd_disp_rect_t * gr_arc;
    const vdc_alpha_rect_t * alpha_rect;
    const vdc_scl_und_sel_t * scl_und_sel;
} vdc_alpha_blending_rect_t;
```

## Type Description

| Moniber Hame               |                                                    |
|----------------------------|----------------------------------------------------|
| const vdc_pd_disp_rect_t * | Rectangular area subjected to alpha blending       |
| gr_arc                     | The setting is not changed if NULL is specified.   |
| const vdc_alpha_rect_t *   | Parameter for alpha blending in a rectangular area |
| alpha_rect                 | The setting is not changed if NULL is specified.   |
| const vdc_scl_und_sel_t *  | Selection of lower-layer plane in scaler           |
| scl_und_sel                | This parameter is not referred in this driver.     |
|                            | Specify NULL.                                      |

The parameter gr\_arc is initialized by the driver to the same graphics display area when the API function R\_VDC\_ReadDataControl is called. The parameter alpha\_rect is kept at its initial values that are defined in the hardware manual if it has never been set up after a hardware reset. See the structure descriptions given below for its initial values. The parameters in vdc\_alpha\_blending\_rect\_t structure, including the parameters gr\_arc and alpha\_rect are kept at their initial values if they have never been set up after a hardware reset.

vdc\_pd\_disp\_rect\_t structure is described below.

```
typedef struct
{
    uint16_t vs_rel;
    uint16_t vw_rel;
    uint16_t hs_rel;
    uint16_t hw_rel;
} vdc_pd_disp_rect_t;
```

| Type<br>Member Name | Initial Value | Description                                                                                                                                                                                               |
|---------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| uint16_t<br>vs_rel  | 0             | Vertical start position of the valid image area for alpha blending in a rectangular area (lines)  This is the relative position from the vertical start position of the graphics display area.            |
| uint16_t<br>vw_rel  | - *           | Vertical width of the valid image area for alpha blending in a rectangular area (lines)                                                                                                                   |
| uint16_t<br>hs_rel  | 0             | Horizontal start position of the valid image area for alpha blending in a rectangular area (clock cycles)  This is the relative position from the horizontal start position of the graphics display area. |
| uint16_t<br>hw_rel  | _ *           | Horizontal width of the valid image area for alpha blending in a rectangular area (clock cycles)                                                                                                          |

Note: The effective image area vertical width and horizontal width are initialized by the driver to the same values of the graphics display area.

The rectangular area to be subjected to alpha blending is specified as a relative position within the graphics display area for the pertinent layer that is specified through the function  $R_VDC_ReadDataControl$  (see Figure 6-6).



Figure 6-6 Rectangular Area Setting for Alpha Blending

Even when the graphics display area is changed by the function R\_VDC\_ChangeReadProcess, the rectangular area for alpha blending does not follow the change. To change the graphics display area when using alpha blending in a rectangular area, it is also necessary to change the rectangular area for alpha blending.

The members of the vdc\_alpha\_rect\_t structure is described below.

| Initial Value | Description                                                                                                                 |
|---------------|-----------------------------------------------------------------------------------------------------------------------------|
| 0             | Alpha coefficient for alpha blending in a rectangular area                                                                  |
|               | Variation (-255 to +255)                                                                                                    |
| 0             | Frame rate for alpha blending in a rectangular area                                                                         |
|               | <pre>gr_arc_coef is added to the alpha value every time Vsync<br/>rises the number of times equal to gr_arc_rate + 1.</pre> |
|               | 0 to 255                                                                                                                    |
| 255           | Initial alpha value for alpha blending in a rectangular area                                                                |
|               | 0                                                                                                                           |

| gr_arc_def                |                | 0 to 255                                                                                              |
|---------------------------|----------------|-------------------------------------------------------------------------------------------------------|
| vdc_onoff_t<br>gr_arc_mul | VDC_OFF<br>(0) | Multiplication processing with current alpha at alpha blending in a rectangular area  VDC_OFF  VDC_ON |

## 6.20 R\_VDC\_Chromakey

| Synopsis     | Chroma-key setup                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Declaration  | vdc_error_t R_VDC_Chromakey(     const vdc_channel_t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         — VDC_CHANNEL_0: Channel 0         Specify channel 0 in this driver.</li> <li>vdc_layer_id_t layer_id: Layer ID         — VDC_LAYER_ID_0_RD: Layer 0 read processing         — VDC_LAYER_ID_2_RD: Layer 2 read processing         — VDC_LAYER_ID_3_RD: Layer 3 read processing         — VDC_LAYER_ID_3_RD: Layer 3 read processing</li> <li>vdc_onoff_t gr_ck_on: Chroma-key ON/OFF setting</li> <li>vdc_chromakey_t * param: Chroma-key setup parameter         The setting is not changed if NULL is specified. If this parameter has never been set up after a hardware reset, the initial value that is defined in the hardware manual remains valid. See the description about the structure for the initial value.</li> </ul> |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_IF_CONDITION: Interface condition error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                  |

## Details

## (1) **Function**

This function performs the following chroma-key related processing:

- Turns on and off the chroma-key processing.
- Sets up the color signals to be subject to chroma-key processing and the color signals after replacement.

The setup of chroma-key processing and its ON/OFF control can be made separately. Once set up chroma-key settings remain valid until a hardware reset occurs, until overwritten with other settings, or until the specified layer resources are destroyed by the function  $R_VDC_ReleaseDataControl$ .

## (2) Use conditions

When this function is to be used, the layer specified in layer\_id needs to be enabled. The layer is enabled by calling the function R\_VDC\_ReadDataControl on that layer. The function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) if the layer specified in layer\_id is found disabled.

The execution of chroma-key processing is inhibited if the color format (format of the frame buffer read signals) of the specified layer is set to YCbCr422 or YCbCr444. In such a case, the function returns an interface condition error (VDC\_ERR\_IF\_CONDITION).

## (3) Parameter details

vdc\_chromakey\_t structure is described below.

```
typedef struct
{
    uint32_t     ck_color;
    uint32_t     rep_color;
    uint8_t     rep_alpha;
} vdc_chromakey_t;
```

| Type<br>Member Name | Initial Value | Description                                                                                                                                                                |
|---------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| uint32_t            | 0             | RGB/CLUT signal for RGB-index/CLUT-index chroma-key                                                                                                                        |
| ck_color            |               | processing                                                                                                                                                                 |
|                     |               | Specify in the color format that is used in the target layer (LSB justified).                                                                                              |
| uint32_t            | 0             | Replaced RGB signal after RGB/CLUT-index chroma-key                                                                                                                        |
| rep_color           |               | processing                                                                                                                                                                 |
|                     |               | Specify in the color format that is used in the target layer (LSB justified). Specify, however, in the RGB888 format if the color format is set to CLUT8, CLUT4, or CLUT1. |
|                     |               | The alpha value in this parameter is ignored. Specify the replaced alpha signal in rep_alpha.                                                                              |
| uint8_t             | 0 *           | Replaced alpha signal after RGB/CLUT-index chroma-key                                                                                                                      |
| rep_alpha           |               | processing                                                                                                                                                                 |
|                     |               | Specify an alpha value in 8 bits.                                                                                                                                          |
|                     |               | 0 ~ 255                                                                                                                                                                    |

Note: The alpha value for layer 0 is automatically set by the driver to '255'.

## 6.21 R\_VDC\_CLUT

| Synopsis     | CLUT setup                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Declaration  | vdc_error_t R_VDC_CLUT(     const vdc_channel_t                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel         <ul> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> </ul> </li> <li>vdc_layer_id_t layer_id: Layer ID             <ul> <li>VDC_LAYER_ID_0_RD: Layer 0 read processing</li> <li>VDC_LAYER_ID_2_RD: Layer 2 read processing</li> <li>VDC_LAYER_ID_3_RD: Layer 3 read processing</li> </ul> </li> <li>vdc_clut_t * param: CLUT setup parameter                     <ul> <li>NULL.</li> </ul> </li> </ul> |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_EXCEED_RANGE: Out-of-value-range error</li> <li>VDC_ERR_RESOURCE_LAYER: Layer resource error</li> </ul>                                                                                                        |

## Details

## (1) **Function**

This function sets up CLUT for the specified layer.

## (2) Use conditions

When this function is to be used, the layer specified in layer\_id needs to be enabled. The layer is enabled by calling and executing the function R\_VDC\_ReadDataControl. The function returns a layer resource error (VDC\_ERR\_RESOURCE\_LAYER) if the layer specified in layer\_id is found disabled.



## (3) Parameter details

The members of the vdc\_clut\_t structure is described below.

## Type Description

| wember name      |                                                        |
|------------------|--------------------------------------------------------|
| uint32_t         | Number of colors in CLUT                               |
| color_num        | When CLUT1 format is used: 1 to 2                      |
|                  | When CLUT4 format is used: 1 to 16                     |
|                  | When CLUT8 format is used: 1 to 256                    |
| const uint32_t * | Address of the area storing the CLUT data (in ARGB8888 |
| clut             | format)                                                |
|                  | Do not specify NULL.                                   |

## 6.22 R\_VDC\_DisplayCalibration

| Synopsis     | Display calibration processing                                                                                                                                                                                                                                                                                                                                                  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header       | r_vdc.h                                                                                                                                                                                                                                                                                                                                                                         |
| Declaration  | vdc_error_t R_VDC_DisplayCalibration(                                                                                                                                                                                                                                                                                                                                           |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel</li> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> <li>vdc_disp_calibration_t * param: Display calibration parameter</li> <li>Do not specify NULL.</li> </ul>                                                                                                                                                 |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_NULL: NULL specification error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_PARAM_UNDEFINED: Undefined parameter specification error</li> <li>VDC_ERR_RESOURCE_OUTPUT: Output resource error</li> </ul> |

## Details

#### (1) **Function**

This function performs the following processing for display calibration:

- Sets up panel brightness adjustment.
- Sets up contrast adjustment.
- Sets up panel dithering.
- Makes control settings for the correction circuit sequence.

The settings established by this function remain valid until a hardware reset occurs or they are overwritten by this function with other settings.

## (2) Use conditions

Before using this function, it is necessary to set up display output by calling the function  $R_VDC_D$ isplayOutput. The function returns an output resource error (VDC\_ERR\_RESOURCE\_OUTPUT) if the display output is not set up.

### (3) Parameter details

The members of the vdc\_disp\_calibration\_t structure is described below.

```
typedef struct
   vdc_calibr_route_t
                                  route;
   const vdc_calibr_bright_t * bright;
   const vdc_calibr_contrast_t * contrast;
   const vdc_calibr_dither_t
                                * panel_dither;
} vdc_disp_calibration_t;
```

## Type

## **Description**

| Member Name                   | Besonption                                                  |
|-------------------------------|-------------------------------------------------------------|
| vdc_calibr_route_t            | Correction circuit sequence control                         |
| route                         | <ul><li>VDC_CALIBR_ROUTE_BCG:</li></ul>                     |
|                               | Brightness → contrast → gamma correction                    |
|                               | <ul><li>VDC_CALIBR_ROUTE_GBC:</li></ul>                     |
|                               | Gamma correction → brightness → contrast                    |
| const vdc_calibr_bright_t *   | Brightness (DC) adjustment parameter                        |
| bright                        | Specify NULL when this parameter value need not be changed. |
| const vdc_calibr_contrast_t * | Contrast (gain) adjustment parameter                        |
| contrast                      | Specify NULL when this parameter value need not be changed. |
| const vdc_calibr_dither_t *   | Panel dithering parameter                                   |
| panel_dither                  | Specify NULL when this parameter value need not be changed. |

If the brightness, contrast, and panel\_dither parameters have never been set up after a hardware reset, their initial values that are defined in the hardware manual remain valid. See the structure descriptions given below for their initial values.

The members of the vdc\_calibr\_bright\_t structure is described below.

```
typedef struct
             pbrt_g;
   uint16_t
             pbrt_b;
   uint16_t
   uint16_t
               pbrt_r;
} vdc_calibr_bright_t;
```

|   | ` ' | n | ^ |
|---|-----|---|---|
|   |     |   |   |
| • |     | ~ |   |

## Initial Value Description

| Member Name | Initial Value | Description                            |  |
|-------------|---------------|----------------------------------------|--|
| uint16_t    | 512           | Brightness (DC) adjustment of G signal |  |
| pbrt_g      |               | 0x0000 (-512) to 0x03FF (+511)         |  |
| uint16_t    | 512           | Brightness (DC) adjustment of B signal |  |
| pbrt_b      |               | 0x0000 (-512) to 0x03FF (+511)         |  |
| uint16_t    | 512           | Brightness (DC) adjustment of R signal |  |
| pbrt r      |               | 0x0000 (-512) to 0x03FF (+511)         |  |

The members of the vdc\_calibr\_contrast\_t structure is described below.

```
typedef struct
{
    uint8_t cont_g;
    uint8_t cont_b;
    uint8_t cont_r;
} vdc_calibr_contrast_t;
```

| Type<br>Member Name | Initial Value | Description                                      |
|---------------------|---------------|--------------------------------------------------|
| uint8_t             | 128           | Contrast (gain) adjustment of G signal           |
| cont_g              |               | 0x0000 (0/128[times]) to 0x00FF (255/128[times]) |
| uint8_t             | 128           | Contrast (gain) adjustment of B signal           |
| cont_b              |               | 0x0000 (0/128[times]) to 0x00FF (255/128[times]) |
| uint8_t             | 128           | Contrast (gain) adjustment of R signal           |
| cont_r              |               | 0x0000 (0/128[times]) to 0x00FF (255/128[times]) |

The members of the vdc\_calibr\_dither\_t structure is described below.

| Type<br>Member Name   | Initial Value | Description                                                 |
|-----------------------|---------------|-------------------------------------------------------------|
| vdc_panel_dither_md_t | 0             | Panel dither operation mode                                 |
| pdth_sel              |               | <ul> <li>VDC_PDTH_MD_TRU (0): Truncate</li> </ul>           |
|                       |               | <ul> <li>VDC_PDTH_MD_RDOF (1): Round-off</li> </ul>         |
|                       |               | <ul> <li>VDC_PDTH_MD_2X2 (2): 2x2 pattern dither</li> </ul> |
|                       |               | VDC_PDTH_MD_RAND (3): Random pattern dither                 |
| uint8_t               | 3             | Pattern value (A) of 2x2 pattern dither                     |
| pdth_pa               |               | 0 to 3                                                      |
|                       |               | Referenced only when pdth_sel is set to VDC_PDTH_MD_2X2.    |
| uint8_t               | 0             | Pattern value (B) of 2x2 pattern dither                     |
| pdth_pb               |               | 0 to 3                                                      |
|                       |               | Referenced only when pdth_sel is set to VDC_PDTH_MD_2X2.    |
| uint8_t               | 2             | Pattern value (C) of 2x2 pattern dither                     |
| pdth_pc               |               | 0 to 3                                                      |
|                       |               | Referenced only when pdth_sel is set to VDC_PDTH_MD_2X2.    |
| uint8_t               | 1             | Pattern value (D) of 2x2 pattern dither                     |
| pdth_pd               |               | 0 to 3                                                      |
|                       |               | Referenced only when pdth_sel is set to VDC_PDTH_MD_2X2.    |

## 6.23 R\_VDC\_GammaCorrection

| Synopsis     | Gamma correction setup                                                                                                                                                                                                                                            |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Header       | r_vdc.h                                                                                                                                                                                                                                                           |  |
| Declaration  | vdc_error_t R_VDC_GammaCorrection(     const vdc_channel_t                                                                                                                                                                                                        |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel</li> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> <li>vdc_onoff_t gam_on: Gamma correction ON/OFF setting</li> <li>vdc_gamma_correction_t * param: Gamma correction setup parameter</li> </ul> |  |
| Return value | <ul> <li>vdc_error_t: Error code</li> <li>VDC_OK: Normal termination</li> <li>VDC_ERR_PARAM_CHANNEL: Channel invalid error</li> <li>VDC_ERR_PARAM_BIT_WIDTH: Bit width error</li> <li>VDC_ERR_RESOURCE_OUTPUT: Output resource error</li> </ul>                   |  |

## Details

## (1) **Function**

This function performs the following processing for gamma correction:

- Turns on and off gamma correction processing.
- Sets up the gamma correction gain adjustment values for the G/B/R signals.
- Sets up the gamma correction start threshold values for the G/B/R signals.

The setup of the gamma correction parameters and the ON/OFF control of gamma correction processing can be made separately. The gamma correction parameter settings once established by this function remain valid until a hardware reset occurs or they are overwritten with other settings.

## (2) Use conditions

Before using this function, it is necessary to set up display output by calling the function R\_VDC\_DisplayOutput. The function returns an output resource error (VDC\_ERR\_RESOURCE\_OUTPUT) if the display output is not set up.

#### (3) Parameter details

The members of vdc\_gamma\_correction\_t structure is described below.

| Type<br>Member Name | Description                                                 |
|---------------------|-------------------------------------------------------------|
| const uint16_t *    | Gain adjustment of area 0 to 31 of G signal                 |
| gam_g_gain          | Unsigned (0 to 2047[LSB], 1024[LSB] = 1.0[time])            |
|                     | Specify NULL when this parameter value need not be changed. |
| const uint8_t *     | Start threshold of area 1 to 31 of G signal                 |
| gam_g_th            | Unsigned (0 to 255[LSB])                                    |
|                     | Specify NULL when this parameter value need not be changed. |
| const uint16_t *    | Gain adjustment of area 0 to 31 of B signal                 |
| gam_b_gain          | Unsigned (0 to 2047[LSB], 1024[LSB] = 1.0[time])            |
|                     | Specify NULL when this parameter value need not be changed. |
| const uint8_t *     | Start threshold of area 1 to 31 of B signal                 |
| gam_b_th            | Unsigned (0 to 255[LSB])                                    |
|                     | Specify NULL when this parameter value need not be changed. |
| const uint16_t *    | Gain adjustment of area 0 to 31 of R signal                 |
| gam_r_gain          | Unsigned (0 to 2047[LSB], 1024[LSB] = 1.0[time])            |
|                     | Specify NULL when this parameter value need not be changed. |
| const uint8_t *     | Start threshold of area 1 to 31 of R signal                 |
| gam_r_th            | Unsigned (0 to 255[LSB])                                    |
|                     | Specify NULL when this parameter value need not be changed. |

If the parameters have never been set up after a hardware reset, their initial values that are defined in the hardware manual remain valid. The initial values are given below.

- Gain adjustment of area 0 to 31 of G/B/R signal: All 1024 (= 1.0[time])
- Start threshold of area 1 to 31 of G/B/R signal: The start threshold value of area n is n x 8.



## 6.24 R\_VDC\_GetISR

| Synopsis     | Interrupt service routine acquisition processing                                                                                                                                                         |  |  |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Header       | r_vdc.h                                                                                                                                                                                                  |  |  |  |
| Declaration  | <pre>void (*R_VDC_GetISR(</pre>                                                                                                                                                                          |  |  |  |
| Arguments    | <ul> <li>vdc_channel_t ch: Channel</li> <li>VDC_CHANNEL_0: Channel 0</li> <li>Specify channel 0 in this driver.</li> <li>vdc_int_type_t type: Interrupt type</li> <li>See 5.2(8) for details.</li> </ul> |  |  |  |
| Return value | <ul> <li>void (* )(const uint32_t int_sense): Function pointer to the interrupt service routine</li> <li>Other than 0: Normal termination</li> <li>0: Error</li> </ul>                                   |  |  |  |

#### Details

## (1) **Function**

This function returns the function pointer to the specified interrupt service routine.

It returns a '0' if the channel specified in ch or the interrupt type specified in type is found invalid.

## (2) Use conditions

There are no particular conditions with respect to the call of this function.

## 6.25 R\_SPEA\_WindowOffset

| Synopsis     | Setting the coordinate offset of the window                                                                                                                                                                                                                                                                                                                      |  |  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Header       | r_spea.h                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Declaration  | spea_error_t R_SPEA_WindowOffset(     const vdc_layer_id_t                                                                                                                                                                                                                                                                                                       |  |  |
| Arguments    | <ul> <li>vdc_layer_id_t layer_id: layer ID  — VDC_LAYER_ID_2_RD: layer 2  — VDC_LAYER_ID_3_RD: layer 3 Do not specify VDC_LAYER_ID_0_RD.</li> <li>uint16_t offset_x:     offset_x should be 0 or more and equal to or less than 2047 in 2 [pixel] units.</li> <li>uint16_t offset_y:     offset_y should be 0 or more and equal to or less than 8191.</li> </ul> |  |  |
| Return value | <ul> <li>spea_error_t: Error code</li> <li>— SPEA_OK: Normal termination</li> <li>— SPEA_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>— SPEA_ERR_PARAM: Unauthorized condition error</li> </ul>                                                                                                                                                           |  |  |

#### Details

## (1) **Function**

This function performs the following processing related to data read control.

• Set the arrangement of VDC (layers 2 and 3) display area on virtual frame of SPEA.

## (2) Use conditions

There are no particular conditions with respect to the call of this function.

## (3) Parameter details

In this function, as shown in Figure 6-7, set the arrangement of the display area of VDC on the SPEA virtual frame. This offset is the origin (0, 0) when setting the SPEA Window position.



Figure 6-7 Relationship between virtual frame and VDC display area

## 6.26 R SPEA SetWindow

Synopsis Setting Window Parameters Header r spea.h Declaration spea error t R SPEA SetWindow( const vdc\_layer\_id\_t layer\_id, const spea\_window\_id\_t window\_id, const spea onoff t sken, const spea\_sklym\_t \* sklym, const spea\_skpsm\_t \* skpsm, const void \* buffer); Arguments vdc\_layer\_id\_t layer\_id: layer ID — VDC LAYER ID 2 RD: layer 2 — VDC\_LAYER\_ID\_3\_RD: layer 3 Do not specify VDC\_LAYER\_ID\_0\_RD. spea\_window\_id\_t window\_id: Window ID - WINDOW 00 - WINDOW 15: Window ID spea onoff t sken: Window ON/OFF - SPEA ON — SPEA\_OFF : spea\_sklym\_t \* sklym: Window size — sklym.width be 0 or more and equal to or less than 2047 in 2 [pixel] units. sklym.height be 0 or more and equal to or less than 8191. spea\_skpsm\_t \* skpsm: Window start coordinates. — Set skpsm.x in units of 2 [pixels]. An error occurs if the result of adding offset\_x set in "R\_SPEA\_WindowOffset()" to skpsm.x is not 0 or more but 2047 or less. — An error occurs if the result of adding offset\_y set in "R\_SPEA\_WindowOffset()" to skpsm.y is not 0 or more but 8191 or less. void \* buffer : Window read buffer address Specify a multiple of 8 address. Return value spea\_error\_t: Error code — SPEA\_OK: Normal termination

## Details

## (1) **Function**

This function performs the following processing related to data read control.

- SPEA Window ON / OFF
- Set window starting coordinates and size and read buffer address to SPEA.
- VDC frame buffer burst transfer mode setting (SPEA\_ON: 128 bytes SPEA\_OFF: 32 byte transfer)

— SPEA\_ERR\_PARAM\_LAYER\_ID: Invalid layer ID error— SPEA\_ERR\_PARAM: Unauthorized condition error

## (2) Use conditions

There are no particular conditions with respect to the call of this function. SPEA operates using layers 2 and 3 of the VDC. Therefore, please also set the VDC.

## (3) **Sprite layer**

When using SPEA, it is necessary to set the layer 2 and layer 3 of the VDC. Please set the following values to the base address of frame buffer used for layer setting of VDC and line offset address of frame buffer.

#define VIRTUAL\_FRAME\_BASE\_ADD (0x30000000u) #define VIRTUAL\_FRAME\_STRAID (8192u)

## 6.27 R\_SPEA\_WindowUpdate

| Synopsis     | Window parameter update request                                                                                                                                          |  |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Header       | r_spea.h                                                                                                                                                                 |  |  |
| Declaration  | spea_error_t R_SPEA_WindowUpdate(     const vdc_layer_id_t                                                                                                               |  |  |
| Arguments    | <ul> <li>vdc_layer_id_t layer_id: layer ID</li> <li>VDC_LAYER_ID_2_RD: layer 2</li> <li>VDC_LAYER_ID_3_RD: layer 3</li> <li>Do not specify VDC_LAYER_ID_0_RD.</li> </ul> |  |  |
| Return value | <ul> <li>spea_error_t: Error code</li> <li>— SPEA_OK: Normal termination</li> <li>— SPEA_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> </ul>                           |  |  |

#### Details

## (1) **Function**

This function performs the following processing related to data read control.

• Request to update SPEA Window parameters.

## (2) Use conditions

There are no particular conditions with respect to the call of this function.

## 6.28 R\_RLE\_SetWindow

| Synopsis<br>Header | Setting the RLE parameter r_spea.h                                                                                                                                                                     |  |  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Declaration        | spea_error_t R_RLE_SetWindow(                                                                                                                                                                          |  |  |
| Arguments          | <ul> <li>vdc_layer_id_t layer_id: layer ID</li></ul>                                                                                                                                                   |  |  |
| Return value       | <ul> <li>spea_error_t: Error code</li> <li>— SPEA_OK: Normal termination</li> <li>— SPEA_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> <li>— SPEA_ERR_PARAM: Unauthorized condition error</li> </ul> |  |  |

### Details

## (1) **Function**

This function performs the following processing related to data read control.

- RLE ON /OFF.
- Setting SPEA RLE parameters.

## (2) Use conditions

There are no particular conditions with respect to the call of this function. RLE operates using layers 0 of the VDC. Therefore, please also set the VDC.

## (3) RLE (run-length encoded) layer

RLE unit operates using layer 0 of VDC. Data compressed in Targa format can be expanded and displayed. It is possible to realize high resolution display with less memory. However, the compression ratio of data depends on the image.

### (4) About creating image in Targa format.

Please use graphics editor tool such as GIMP to create Targa format image file. (Check operation with GIMP 2.8)

## (5) Restrictions on image creation.

Targa format images used for RLE units, the following restrictions must be observed.

- Note 1. If an image data size in the horizontal direction does not fit to 128 bytes alignment, some dummy data in each line needs to be added.
  - 2. After completion of the reading of each line, the RLE unit reads additional 128 bytes. For this reason, 128 bytes of additional dummy data must be inserted in each line.
  - 3. Color data format: 24 bpp (Alpha channel not included).

Example: Dummy data insertion required for each line in the horizontal 240 pixel image of 32bpp (Figure 6-8): 64- and 128-byte of dummy data are required to satisfy the restrictions of the Note 1 and Note 2, respectively. Dummy data insertion of 192 bytes in total is required. The number of horizontal pixels after dummy data insertion is 288 pixels.



Figure 6-8 About dummy data

## (6) Targa image file header.

Specify Targa format image file with header removed. The header of Targa format is fixed at 18 [byte]. Please use the data after that.



Figure 6-9 Targa image file header.

## 6.29 R\_RLE\_WindowUpdate

| Synopsis<br>Header | RLE parameter update request r_spea.h                                                                                                                      |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Declaration        | spea_error_t R_RLE_WindowUpdate(     const vdc_layer_id_t                                                                                                  |
| Arguments          | <ul> <li>vdc_layer_id_t layer_id: layer ID</li> <li>VDC_LAYER_ID_0_RD: layer 0</li> <li>Do not specify VDC_LAYER_ID_2_RD and VDC_LAYER_ID_3_RD.</li> </ul> |
| Return value       | <ul> <li>spea_error_t: Error code</li> <li>— SPEA_OK: Normal termination</li> <li>— SPEA_ERR_PARAM_LAYER_ID: Invalid layer ID error</li> </ul>             |

## Details

## (1) **Function**

This function performs the following processing related to data read control.

• Request to update RLE parameters.

## (2) Use conditions

There are no particular conditions with respect to the call of this function.

#### 7. Reference Documents

User's Manual: Hardware

RZ/A2M Group User's Manual: Hardware

The latest version can be downloaded from the Renesas Electronics website.

RTX921053C00000BE (RZ/A2M CPU board) User's Manual

The latest version can be downloaded from the Renesas Electronics website.

RTK79210XXB00000BE (RZ/A2M SUB board) User's Manual

The latest version can be downloaded from the Renesas Electronics website.

ARM Architecture Reference Manual ARMv7-A and ARMv7-R edition Issue C

The latest version can be downloaded from the ARM website.

ARM Cortex<sup>TM</sup>-A9 (Revision: r4p1) Technical Reference Manual

The latest version can be downloaded from the ARM website.

ARM Generic Interrupt Controller Architecture Specification - Architecture version 2.0

The latest version can be downloaded from the ARM website.

ARM CoreLink<sup>TM</sup> Level 2 Cache Controller L2C-310 (Revision: r3p3) Technical Reference Manual

The latest version can be downloaded from the ARM website.

Technical Update/Technical News

The latest information can be downloaded from the Renesas Electronics website.

User's Manual: Development Tools

Integrated development environment e2studio User's Manual can be downloaded from the Renesas Electronics website.

The latest version can be downloaded from the Renesas Electronics website.



## **Website and Support**

Renesas Electronics Website http://www.renesas.com/

Inquiries

http://www.renesas.com/contact/

All trademarks and registered trademarks are the property of their respective owners.

## **Revision History**

|      |              | Description |                                                              |
|------|--------------|-------------|--------------------------------------------------------------|
| Rev. | Date         | Page        | Summary                                                      |
| 1.00 | Sep 14, 2018 | -           | First edition issued                                         |
| 1.01 | Dec 28, 2018 | p.97        | Modified the param of rle_onoff_t in "6.28 R_RLE SetWindow". |
|      |              | all         | Modified the speling misstake(VDC 5 -> VDC).                 |

## General Precautions in the Handling of Microprocessing Unit and Microcontroller Unit Products

The following usage notes are applicable to all Microprocessing unit and Microcontroller unit products from Renesas. For detailed usage notes on the products covered by this document, refer to the relevant sections of the document as well as any technical updates that have been issued for the products.

#### 1. Handling of Unused Pins

Handle unused pins in accordance with the directions given under Handling of Unused Pins in the manual.

The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual.

#### 2. Processing at Power-on

The state of the product is undefined at the moment when power is supplied.

- The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied.
  - In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed.
  - In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified.

#### 3. Prohibition of Access to Reserved Addresses

Access to reserved addresses is prohibited.

 The reserved addresses are provided for the possible future expansion of functions. Do not access these addresses; the correct operation of LSI is not guaranteed if they are accessed.

#### 4. Clock Signals

After applying a reset, only release the reset line after the operating clock signal has become stable. When switching the clock signal during program execution, wait until the target clock signal has stabilized.

When the clock signal is generated with an external resonator (or from an external oscillator) during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Moreover, when switching to a clock signal produced with an external resonator (or by an external oscillator) while program execution is in progress, wait until the target clock signal is stable.

## 5. Differences between Products

Before changing from one product to another, i.e. to a product with a different part number, confirm that the change will not lead to problems.

The characteristics of Microprocessing unit or Microcontroller unit products in the same group but having a different part number may differ in terms of the internal memory capacity, layout pattern, and other factors, which can affect the ranges of electrical characteristics, such as characteristic values, operating margins, immunity to noise, and amount of radiated noise. When changing to a product with a different part number, implement a system-evaluation test for the given product.

#### Notice

- criptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully resp the incorporation or any other use of the circuits, software, and information in the design of your product or system. Renesas Electronics disclaims any and all liability for any losses and damages incurred by you or third parties arising from the use of these circuits, software, or information
- 2. Renesas Electronics hereby expressly disclaims any warranties against and liability for infringement or any other claims involving patents, copyrights, or other intellectual property rights of third parties, by or arising from the use of Renesas Electronics products or technical information described in this document, including but not limited to, the product data, drawings, charts, programs, algorithms, and application
- 3. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 4. You shall not alter, modify, copy, or reverse engineer any Renesas Electronics product, whether in whole or in part. Renesas Electronics disclaims any and all liability for any losses or damages incurred by you or third parties arising from such alteration, modification, copying or reverse engineering.
- 5. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The intended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below.
  - Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment: industrial robots: etc.

"High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control (traffic lights); large-scale communication equipment; key financial terminal systems; safety control equipment; etc. Unless expressly designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not intended or authorized for use in products or systems that may pose a direct threat to human life or bodily injury (artificial life support devices or systems; surgical implantations; etc.), or may cause serious property damage (space system; undersea repeaters; nuclear power control systems; aircraft control systems; key plant systems; military equipment; etc.). Renesas Electronics disclaims any and all liability for any damages or losses incurred by you or any third parties arising from the use of any Renesas Electronics product that is inconsistent with any Renesas Electronics data sheet, user's manual or other Renesas Electronics document.

- 6. When using Renesas Electronics products, refer to the latest product information (data sheets, user's manuals, application notes, "General Notes for Handling and Using Semiconductor Devices" in the reliability handbook, etc.), and ensure that usage conditions are within the ranges specified by Renesas Electronics with respect to maximum ratings, operating power supply voltage range, heat dissipation characteristics, installation, etc. Renesas Electronics disclaims any and all liability for any malfunctions, failure or accident arising out of the use of Renesas Electronics products outside of such specified
- 7. Although Renesas Electronics endeavors to improve the quality and reliability of Renesas Electronics products, semiconductor products have specific characteristics, such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Unless designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not subject to radiation resistance design. You are responsible for implementing safety measures to guard against the possibility of bodily injury, injury or damage caused by fire, and/or danger to the public in the event of a failure or malfunction of Renesas Electronics products, such as safety design for hardware and software, including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult and impractical, you are responsible for evaluating the safety of the final products or systems manufactured by you.
- 8. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. You are responsible for carefully and sufficiently investigating applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive, and using Renesas Electronics products in compliance with all these applicable laws and regulations. Renesas Electronics disclaims any and all liability for damages or losses occurring as a result of your noncompliance with applicable aws and regulations
- 9. Renesas Electronics products and technologies shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You shall comply with any applicable export control laws and regulations promulgated and administered by the governments of any countries asserting jurisdiction over the parties or transactions.
- 10. It is the responsibility of the buyer or distributor of Renesas Electronics products, or any other party who distributes, disposes of, or otherwise sells or transfers the product to a third party, to notify such third earty in advance of the contents and conditions set forth in this document
- 11. This document shall not be reprinted, reproduced or duplicated in any form, in whole or in part, without prior written consent of Renesas Electronics
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its directly or indirectly controlled subsidiaries.

(Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics

(Rev.4.0-1 November 2017)



#### SALES OFFICES

## Renesas Electronics Corporation

http://www.renesas.com

Refer to "http://www.renesas.com/" for the latest and detailed information.

Renesas Electronics Corporation TOYOSU FORESIA, 3-2-24 Toyosu, Koto-ku, Tokyo 135-0061, Japan

Renesas Electronics America Inc. 1001 Murphy Ranch Road, Milpitas, CA 95035, U.S.A. Tel: +1-408-432-8888, Fax: +1-408-434-5351

Renesas Electronics Canada Limited 9251 Yonge Street, Suite 8309 Richmond Hill, Ontario Canada L4C 9T3 Tel: +1-905-237-2004

Renesas Electronics Europe Limited
Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K
Tel: +44-1628-651-700

Renesas Electronics Europe GmbH

Arcadiastrasse 10, 40472 Düsseldorf, Germany Tel: +49-211-6503-0, Fax: +49-211-6503-1327

Renesas Electronics (China) Co., Ltd.
Room 1709 Quantum Plaza, No.27 ZhichunLu, Haidian District, Beijing, 100191 P. R. China Tel: +86-10-8235-1155, Fax: +86-10-8235-7679

Renesas Electronics (Shanghai) Co., Ltd.

Unit 301, Tower A, Central Towers, 555 Langae Road, Putuo District, Shanghai, 200333 P. R. China Tel: +86-21-2226-0888, Fax: +86-21-2226-0999

Renesas Electronics Hong Kong Limited

Unit 1601-1611, 16IF., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tel: +852-2265-6688, Fax: +852 2886-9022

Renesas Electronics Taiwan Co., Ltd. 13F, No. 363, Fu Shing North Road, Taipei 10543, Taiwan Tel: +886-2-8175-9600, Fax: +886 2-8175-9670

Renesas Electronics Singapore Pte. Ltd.
80 Bendemeer Road, Unit #06-02 Hyflux Innovation Centre, Singapore 339949
Tel: +65-6213-0200, Fax: +65-6213-0300

Renesas Electronics Malaysia Sdn.Bhd.
Unit 1207, Block B, Menara Amcorp, Amcorp Trade Centre, No. 18, Jln Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tel: +60-3-7955-9390, Fax: +60-3-7955-9510

Renesas Electronics India Pvt. Ltd. No.777C, 100 Feet Road, HAL 2nd Stage, Ind Tel: +91-80-67208700, Fax: +91-80-67208777 Indiranagar, Bangalore 560 038, India

Renesas Electronics Korea Co., Ltd. 17F, KAMCO Yangjae Tower, 262, Gangnam-daero, Gangnam-gu, Seoul, 06265 Korea Tel: +82-2-558-3737, Fax: +82-2-558-5338