

LCD Controller Setup Example

R01AN0669EJ0101 Rev.1.01 Jun 09, 2011

# Introduction

This application note describes how to use the LCD controller (LCDC) of the SH7722 and SH7731, and shows a display example by the TFT-LCD module.

# **Target Device**

SH7722, SH7731

### Contents

| 1. | Preface                                     | 2    |
|----|---------------------------------------------|------|
| 2. | LCDC Operation                              | 4    |
| 3. | Estimating Load on the Bus in System Design | . 23 |
| 4. | Description of the Sample Application       | . 27 |
| 5. | Listing of the Sample Program               | . 41 |
| 6. | Execution Results                           | . 57 |
| 7. | Documents for Reference                     | . 58 |



### 1. Preface

### 1.1 Specifications

• In this application note, section 2 gives a supplementary explanation of the LCDC description in the hardware manual, and section 3 describes the LCDC bus load factor necessary for system design. Section 4 shows an application example in which four types of images are alternately displayed on the TFT-LCD module and the TFT-LCD module is repeatedly turned on and off.

### 1.2 Modules Used

• LCDC

### 1.3 Applicable Conditions

| • Evaluation board                                                                                                                                                                                                         | SH7722 reference platform (product code: R0P7722TH001ARK) manufactured by Renesas Electronics Corporation |                                                |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------|--|--|
|                                                                                                                                                                                                                            | External memory (area 0)                                                                                  | 64-MB NOR-type flash memory: S29GL512N10FF1020 |  |  |
|                                                                                                                                                                                                                            |                                                                                                           | from Spansion                                  |  |  |
|                                                                                                                                                                                                                            | (area 3)                                                                                                  | 64-MB SDRAM: MT48LC8M16A2B475 from Micron      |  |  |
| • MCU                                                                                                                                                                                                                      | 3GV)                                                                                                      |                                                |  |  |
| • Operating frequency                                                                                                                                                                                                      | CPU clock: 200.00 MHz                                                                                     |                                                |  |  |
|                                                                                                                                                                                                                            | SH bus clock: 100.00 MHz                                                                                  |                                                |  |  |
|                                                                                                                                                                                                                            | U memory clock: 100.00 MHz                                                                                |                                                |  |  |
|                                                                                                                                                                                                                            | Bus clock: 50.00 MHz                                                                                      |                                                |  |  |
|                                                                                                                                                                                                                            | SDRAM clock: 80.00 MHz                                                                                    |                                                |  |  |
|                                                                                                                                                                                                                            | Peripheral clock: 25.00 MHz                                                                               | Z                                              |  |  |
| Note: The operating frequency is set not at the maximum specification but at a setting that makes the peripheral clock frequency become 25 MHz. For details on the frequency determination method, refer to section 4.2.2. |                                                                                                           |                                                |  |  |

- Bus width for area 0 16-bit (with the MD3 pin at the low level)
- Bus width for area 3 64-bit
- Clock operating mode Mode 0 (with the MD0 pin and the MD1 pin at the low level)
- Endian Little endian (with the MD5 pin at the high level)
  - Toolchain SuperH RISC engine Standard Toolchain Ver.9.3.0.0 from Renesas Electronics
- Compiler options
   Default settings of High-performance Embedded Workshop
  - (-cpu=sh4aldsp -endian=little -include="\$(PROJDIR)\inc" -object="\$(CONFIGDIR)\\$(FILELEAF).obj" -debug -optimize=0 -gbr=auto -chgincpath -errorpath -global\_volatile=0 -opt\_range=all -infinite\_loop=0

-del\_vacant\_loop=0 -struct\_alloc=1 -nologo)



# 1.4 Terms Used in This Application Note

• Frame

A frame is pixel information located in the memory in the same way the image is to be displayed on the screen. A buffer in which frame information is stored is called a frame buffer. The LCDC reads pixel information from the frame buffers and uses it to display images.

• Refresh rate [Hz]

Indicates how many times the LCD module connected to the LCDC rewrites the screen in 1 second. This is equal to the frequency of the vertical sync signal VSYNC output by the LCDC in 1 second.

• Frame rate [fps]

Indicates the number of images updated by the image display system in 1 second. The upper limit of the images that can be updated by the LCD module is equal to the refresh rate [Hz].

When the frame rate is lower than the refresh rate, e.g., frame rate is 30 fps for an LCD module whose VSYNC frequency is 60 Hz, the LCD module displays updated images for 30 times in the period of 60 VSYNC signals.

# 1.5 Scope of This Application Note

This application note describes the basic usage method of the LCDC without an OS, that is, to continuously display images in the frame buffers onto the LCD module supporting the RGB interface mode. The following functions are not covered by the descriptions in this application note.

- Linked operation of BEU and LCDC
- YCbCr output
- Color palette
- SYS interface
- Sub LCD module display
- Partial screen mode
- Write-back of display data
- VSYNC input mode
- One-shot mode

# 1.6 Related Application Note

The operation of the reference programs in this application note has been confirmed under setup conditions partially modified from those in the "SH7722/SH7731 Group Application Note: SH7722/SH7731 Example of Initialization (REJ06B0942)". Also refer to that application note.



# 2. LCDC Operation

# 2.1 Overview of LCDC

The LCDC is an image system module that can read image data from the frame buffers located in the external memory and display images onto the TFT-LCD module. This application note introduces a setup example in which RGB- or YCbCr-format image data is read and an image is displayed on the LCD module in RGB interface mode.



Figure 1 Image of LCDC Operation

### 2.1.1 Image Data Read

The LCDC reads from the frame buffer one pixel each rightward, starting from the base point of an image that is located at the top-left corner. The pixel information for the amount of the horizontal image size is called one line. After reading for one line has finished, reading is continued after returning to the left end one line down. Reading for one frame is completed when the number of lines equal to the vertical image size has been read. Reading of the next frame is started again from the base point.



Figure 2 Image Data Input



### 2.1.2 Image Data Output

The LCDC outputs image data in synchronization with the following three sync signals.

- Dot clock (DotCLK):
- The information for one pixel is output in synchronization with the dot clock.
- Horizontal sync signal (HSYNC):

The information for a single horizontal line of an image is output in synchronization with the horizontal sync signal. The periods that are before and after the sync signal and in which no pixel information is output are referred to as the horizontal front porch and horizontal back porch, respectively.

• Vertical sync signal (VSYNC): The information for a single frame of an image is output in synchronization with the vertical sync signal. The periods that are before and after the sync signal and in which no pixel information is output are referred to as the vertical front porch and vertical back porch, respectively.





Each cycle of the sync signal includes an image-display period and a non-display period. The non-display period in the horizontal direction starts from the end of displaying a single line from the left to the right and lasts until the beginning of displaying the next single line after returning to the left. This period is called the horizontal blanking period. The non-display period in the vertical direction starts from the end of displaying a single frame and lasts until the beginning of displaying the next single frame. This period is called the vertical blanking period.



# 2.2 LCDC Specifications

Table 1 lists the main specifications of the LCDC.

#### Table 1 LCDC Specifications

| Item                                                                                                                                      | Specifications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Maximum displayable size by<br>LCD module<br>Note: The bus occupation<br>rate needs to be calculated in<br>actual display operations. For | <ul> <li>[Horizontal image size]</li> <li>Up to 1024 pixels when the output data format is the 16-bit RGB565 packed format (2 bytes/pixel)</li> <li>Up to 512 pixels when the output data format is the 32-bit RGB888 packed format (4 bytes/pixel)</li> </ul>                                                                                                                                                                                                                                                                                                                                             |  |
| details, see section 3.                                                                                                                   | [Vertical image size] Up to 1024 pixels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| Input data format                                                                                                                         | 32-bit RGB888 packed format (from the lower bits)<br>32-bit RGB888 packed format (from the upper bits)<br>24-bit RGB888 packed format (* See section 2.3.4, Note 2.)<br>16-bit RGB565 packed format<br>32-bit RGB666 packed format<br>16-bit RGB444 packed format<br>24-bit RGB666 packed format<br>24-bit BGR666 packed format<br>32-bit BGR888 packed format<br>32-bit BGR888 packed format<br>32-bit RGB565 packed format<br>32-bit RGB565 packed format<br>YCbCr444<br>YCbCr422<br>YCbCr420                                                                                                            |  |
| Output data format                                                                                                                        | [RGB interface]<br>RGB8 3 cycle/pixel<br>RGB9 2 cycle/pixel<br>RGB12a 2 cycle/pixel<br>RGB12b 1 cycle/pixel<br>RGB16 1 cycle/pixel<br>RGB18 1 cycle/pixel<br>RGB24 1 cycle/pixel<br>[SYS interface] Not handled in this application note.                                                                                                                                                                                                                                                                                                                                                                  |  |
| Display data write-back                                                                                                                   | Not handled in this application note.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| LCD driver interface                                                                                                                      | <ul> <li>[RGB interface of main LCD]</li> <li>Interface using horizontal sync signal and vertical sync signal</li> <li>The polarity of a signal can be set</li> <li>The output width and output position of an image signal can be set</li> <li>[SYS interface of main LCD]</li> <li>Not handled in this application note.</li> <li>[Only SYS interface of sub LCD]</li> <li>Not handled in this application note.</li> </ul>                                                                                                                                                                              |  |
| Dot clock                                                                                                                                 | <ul> <li>The source clock should be selected from the following three clocks and it can be output after its frequency has been divided.</li> <li>Bus clock (Bφ)</li> <li>Peripheral clock (Pφ)</li> <li>External input clock</li> <li>A frequency of up to 33.3 MHz can be output. If Bφ is set to a frequency slower than 33.3 MHz, the value of Bφ becomes the maximum value of the dot clock.</li> <li>The division ratio can be selected from 1/1 (no division), 1/2, and 1/3 to 1/60. Division in which the numerator becomes a value other than 1 (e.g., division by 2/5) is not allowed.</li> </ul> |  |

RENESAS

# 2.3 LCDC Setup

The LCDC functions and register setting methods are described here.

### 2.3.1 Canceling Module Standby State

The SH7722 has a module standby function that starts and stops clock supply to each peripheral module. Since the LCDC is a module whose clock supply is halted after a power-on reset, the module standby state has to be canceled and the clock supply started before setting the LCDC registers.

Table 2 shows the register used for setting a power saving mode.

#### Table 2 Power-Down Mode Setting

| Function                                        | Register                                        |
|-------------------------------------------------|-------------------------------------------------|
| Enables or disables the<br>LCDC power-down mode | MSTP200 bit in module stop register 2 (MSTPCR2) |

When canceling the module standby state by software, start setting the LCDC registers after making sure that the module standby state has been canceled by polling until the MSTP200 bit is read as 0. The LCDC registers cannot be written to in the module standby state.

### 2.3.2 Setting the Source for Data Acquisition

The LCDC selects the memory or BEU as the source for acquiring image data. When the BEU is selected, the LCDC operates together with the BEU. In the SH7731 that does not incorporate the BEU, the source for data acquisition needs not be set, and data is always acquired from the memory. In the SH7722, the source for data acquisition can be selected as the memory or the BEU. If the BEU is selected, BEU-LCDC linked operation is performed (linked operation of the BEU and LCDC is not handled in this application note).

Table 3 shows the LCDC register used for setting the source for data acquisition.

#### Table 3 Setting the Source for Data Acquisition

| Function                                   | Register                                                                                                                                    |
|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Setting the Source for Data<br>Acquisition | <ul> <li>LCDC control register 2 (LDCNT2R)</li> <li>In the SH7731, the source for data acquisition must always be set to memory.</li> </ul> |

#### 2.3.3 Setting the Output Destination

The LCDC selects from two display destinations: main LCD and sub LCD. The RGB interface or SYS interface can be selected for the main LCD. Only the SYS interface is available for the sub LCD.

In this application note, only the RGB interface of the main LCD is handled.

Table 4 shows the LCDC registers used for setting the output destination.

| Table 4 | Setting the Output Destination |
|---------|--------------------------------|
|---------|--------------------------------|

| Function           | Register                          |
|--------------------|-----------------------------------|
| Setting the Output | LCDC control register 1 (LDCNT1R) |
| Destination        | LCDC control register 2 (LDCNT2R) |



### 2.3.4 Setting the Frame Buffer

Figure 4 shows the frame buffer information required by the LCDC when reading image data from the memory.



#### Figure 4 Frame Buffer Configuration

- (1) Start address: Set a 8-byte aligned address for the base point address of the frame buffer. The address should be set as a 32-bit physical address with the upper three bits as 0.
- (2) Actual data size: Specify the horizontal image size in pixel units. Note that this setting must be a multiple of 8 because the LCDC handles data in the horizontal direction in units of characters (1 character: 8 pixels).
- (3) Number of lines: Specify the vertical image size in pixel units.
- (4) Frame buffer size: Specify the frame buffer size in byte units, independent of the horizontal image size. The frame buffer size must be equal to or greater than the horizontal image size. When set to a value greater than the horizontal image size, the right end of the frame buffer becomes invalid data.
- (5) Image format: The LCDC can handle the image formats listed in "input data format" in table 1.
  - Only one frame buffer is used for the RGB format.
  - Since the YCbCr format data is handled with the Y signal and CbCr signal separated, two frame buffers are used. In this case, set start address (1) in the register for the start address of the Y signal and the register for the start address of the CbCr signal. Set frame buffer information on the Y signal for (2) to (4).
- Notes: 1. If YCbCr has been set as the image format, when an image is output to the RGB interface, the color converted format (YUV → RGB) supports only the ITU-BT.601 standard. The conversion formula can be selected from the following two types.
  - Extension type: Conversion of BT.601-range YCbCr (Y: 16 to 235, C: 16 to 240) ↔ full-range RGB (0 to 255)
  - Compression type: Conversion of full-range YCbCr (0 to 255)  $\leftrightarrow$  full-range RGB (0 to 255)
  - Though 24-bpp RGB888 is not listed in table 31.7, RGB Packed Format, in section 31, LCD Controller (LCDC), in the "SH7722 Group Hardware Manual (REJ09B0314-0200) Rev. 2.00", or in table 27.7, RGB Packed Format, in section 27, LCD Controller (LCDC), in the "SH7731 Group Hardware Manual (REJ09B0488-0100) Rev. 1.00", it can be used by setting PKF[4:0] = B'00010.
  - 3. When the image format of the frame buffer differs from the image format of the LCD module that is connected to the LCDC, the LCDC automatically pads the lower bits with 0 or discards the lower bits. For example, when the image format of the frame buffer is RGB565 while the image format of the LCD module is RGB666, the LCDC adds 0 to the LSB in the R and B data and outputs the data in the RGB666 format. For details on how to set the image format of the LCD module, see section 2.3.8.

Table 5 shows the LCDC registers used for setting the frame buffer.



#### Table 5 Frame Buffer Setting

| Function                                                                                                                  | Register                                                             |
|---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| Sets the start address (Y signal/RGB signal)                                                                              | Main LCD display data read start address register 1 (MLDSA1R)        |
| Sets the start address (CbCr signal)                                                                                      | Main LCD display data read start address register 2 (MLDSA2R)        |
| Horizontal image size                                                                                                     | See section 2.3.7, Setting the Sync Signals.                         |
| Vertical image size                                                                                                       | See section 2.3.7, Setting the Sync Signals.                         |
| Horizontal size of frame buffer (stride)                                                                                  | Main LCD display data storing memory line size<br>register (MLDMLSR) |
| Selects the image format (RGB888, RGB565, and YCbCr420, etc.), and selects the YCbCr $\rightarrow$ RGB conversion formula | Main LCD data format register (MLDDFR)                               |

### 2.3.5 Setting Data Swapping

The LCDC is a module that operates in big endian. When the SH7722/SH7731 is operated in little endian and data is located in the frame buffers in the memory in little endian, data swapping should be set adequately for each image format. Byte swapping, word swapping, and longword swapping can be individually set when the LCDC reads data from the memory.

Table 6 shows the LCDC register used for setting data swapping.

#### Table 6 Data Swapping Setting

| Register                                     |
|----------------------------------------------|
| LCDC input image data swap register (LDDDSR) |
|                                              |
|                                              |
|                                              |

Table 7 shows examples of swapping setting for frequently used image formats.

#### Table 7 Swapping Setting Examples

| Image Format                                      | Setting                                          |  |
|---------------------------------------------------|--------------------------------------------------|--|
| 32-bit RGB888 packed format (from the lower bits) | s) LDDDSR = 0x00000004                           |  |
| 32-bit RGB888 packed format (from the upper bits) | <ul> <li>Longword swapping is enabled</li> </ul> |  |
| 24-bit RGB888 packed format                       | LDDDSR = 0x00000007                              |  |
|                                                   | <ul> <li>Longword swapping is enabled</li> </ul> |  |
|                                                   | <ul> <li>Word swapping is enabled</li> </ul>     |  |
|                                                   | Byte swapping is enabled                         |  |
| 16-bit RGB565 packed format                       | LDDDSR = 0x0000006                               |  |
|                                                   | <ul> <li>Longword swapping is enabled</li> </ul> |  |
|                                                   | Word swapping is enabled                         |  |



### 2.3.6 Setting the Dot Clock

The dot clock should be set according to the AC characteristics of the LCD module to be used. The dot clock can be generated by dividing the source clock.

- (1) Source clock: Can be selected from the three clock types of the bus clock (Bφ), peripheral clock (Pφ), and external input clock input from the LCDLCLK pin. Since only an integer ratio (1/1, 1/2, 1/3, ...) can be set for the frequency division ratio, select the source clock whose cycle is an integer multiple of the desired dot clock. Note that the following restrictions are applied.
  - When  $P\phi$  is selected,  $P\phi$  should be set to a lower frequency than  $B\phi$ .
  - The external input clock should have a frequency equal to or lower than  $B\phi$ , including jitter.
- (2) Division ratio: Select the division ratio of 1/1 or other than 1/1 (1/2, 1/3, ...). When "other than 1/1" is selected, the division ratio is determined by both the denominator (m) of the division ratio and the dot clock pattern.

#### How to Determine the Division Ratio

When "other than 1/1" is selected, the pattern set in LCD dot clock pattern registers 1 and 2 for the source clock is output without change as the dot clock, as shown in figure 5.

The relationship between the settings of the bits in the LCD dot clock pattern registers and the dot clock output level is determined by the setting of the DWPOL bit in main LCD module type register 1 as follows:

- DWPOL bit = 1: LCD dot clock pattern register  $(0, 1) \rightarrow$  Dot clock output level (H, L)
- DWPOL bit = 0: LCD dot clock pattern register  $(0, 1) \rightarrow$  Dot clock output level (L, H)

Described in this section is the case in which the DWPOL bit is set to 0. When setting the DWPOL bit to 1, assume that the dot clock output level is inverted.

| LCD dot clock pattern register 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 |                      |                                                            |
|----------------------------------------------------------------------|----------------------|------------------------------------------------------------|
|                                                                      | 1: High-level output | [DWPOL = 1]<br>1: Low-level output<br>0: High-level output |
| Dot clock                                                            |                      |                                                            |
| When the pattern is set as "1010", the division ratio                | ) is 1/2.            |                                                            |

#### Figure 5 Division Ratio Setting

Normally, a cyclic pattern in which 1 and 0 appear alternately, such as, "1010..." and "110110...", is set as the dot clock pattern. This repetitive cycle is denoted by "A". A = 2 for the pattern of "10,10,...". A = 3 for the pattern of "110,110,...". At this time, the division ratio is 1/A.

- (1) To make the division ratio be 1/A, select a denominator (m) divisible by A from among 42, 48, 54, and 60. m can be selected from only these four values. Any value can be selected as long as it is divisible.
- (2) Next, set the "1, 0" pattern of the repetitive cycle A in the LCD dot clock pattern registers for the number of bits equal to the value of m. If A = 2, set the "1010..." pattern in which 1 and 0 are alternately lined one bit each. If A = 3, set the "110110..." or "100100..." pattern. When the division ratio is set to an odd number like A = 3, the number of 1s and 0s are not the same so the clock duty ratio will not be 1:1. Confirm that the LCD module used does not have any problems with the duty ratio of the dot clock not being 1:1.

| Source clock                                                                | or |  |  |
|-----------------------------------------------------------------------------|----|--|--|
|                                                                             |    |  |  |
| When the pattern is set as "110110" or "100100", the division ratio is 1/3. |    |  |  |

Figure 6 Setting a Division Ratio of 1/3



(3) Do not make a setting that causes the numerator to be a value other than 1, e.g., 2/5. When such a setting is made, the cycle width of each clock differs and jittering occurs.



#### Figure 7 Setting a Division Ratio of 2/5 (Setting Prohibited)

The division ratio can be set from 1/2 to 1/60. If a desired dot clock cannot be obtained by frequency division, input an appropriate clock signal to the LCDLCLK pin and select the external clock as the source clock.

Table 8 shows the LCDC register used for setting dot clock.

#### Table 8 Dot Clock Setting

| Function                                                            | Register                                            |
|---------------------------------------------------------------------|-----------------------------------------------------|
| Selects the source clock                                            | LCDC dot clock register (LDDCKR)                    |
| Selects division by 1/1 or<br>division by a value other than<br>1/1 |                                                     |
| Selects the denominator (m) of the division ratio                   |                                                     |
| Sets the dot clock pattern                                          | Main LCD dot clock pattern register 1 (MLDDCKPAT1R) |
|                                                                     | Main LCD dot clock pattern register 2 (MLDDCKPAT2R) |

The denominator (m) of the division ratio is set by the MDCDR bits in the LCDC dot clock register (LDDCKR). Figure 8 shows which bits in LCD dot clock pattern registers 1 and 2 are used.



### Figure 8 Bits Used in LCD Dot Clock Pattern Registers 1 and 2



Dot clock pattern examples with division ratios from 1/2 to 1/8 are shown in table 9.

| Division | Selectable      |                                                                    |
|----------|-----------------|--------------------------------------------------------------------|
| Ratio    | Denominator (m) | Dot Clock Pattern to be Set (Illustrated with Smallest Possible m) |
| 1/2      | 42, 48, 54, 60  | MLDDCKPAT1R = 0x000002AA,                                          |
|          |                 | MLDDCKPAT2R = 0xAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA                |
| 1/3      | 42, 48, 54, 60  | H:L = 2:1, MLDDCKPAT1R = 0x0000036D,                               |
|          |                 | MLDDCKPAT2R = 0xB6DB6DB6                                           |
|          |                 | or                                                                 |
|          |                 | H:L = 1:2, MLDDCKPAT1R = 0x00000249,                               |
|          |                 | MLDDCKPAT2R = 0x24924924                                           |
| 1/4      | 48, 60          | MLDDCKPAT1R = 0x0000CCCC,                                          |
|          |                 | MLDDCKPAT2R = 0xCCCCCCCC                                           |
| 1/5      | 60              | H:L = 2:1, MLDDCKPAT1R = $0x0E739CE7$ ,                            |
|          |                 | MLDDCKPAT2R = 0x39CE739C                                           |
|          |                 | or                                                                 |
|          |                 | H:L = 1:2, MLDDCKPAT1R = 0x0C6318C6,                               |
|          |                 | MLDDCKPAT2R = 0x318C6318                                           |
| 1/6      | 42, 48, 54, 60  | MLDDCKPAT1R = 0x0000038E,                                          |
|          |                 | MLDDCKPAT2R = 0x38E38E38                                           |
| 1/7      | 42, 48          | H:L = 4:3, MLDDCKPAT1R = 0x000003C7,                               |
|          |                 | MLDDCKPAT2R = 0x8F1E3C78                                           |
|          |                 | or                                                                 |
|          |                 | H:L = 3:4, MLDDCKPAT1R = 0x00000387,                               |
|          |                 | MLDDCKPAT2R = 0x0E1C3870                                           |
| 1/8      | 48              | MLDDCKPAT1R = 0x0000F0F0,                                          |
|          |                 | MLDDCKPAT2R = 0xF0F0F0F0                                           |

# Table 9 Division Ratio Setting Examples



### 2.3.7 Setting the Sync Signals

The sync signal parameters in figure 9 should be set according to the characteristics (A) to (E) and (a) to (e) in figure 3 of the LCD module used.



#### Figure 9 Sync Signal Configuration

- (1) HTCN: Sets the horizontal cycle in units of characters.
- (2) HDCN: Sets the horizontal display period in units of characters.
- (3) HSYNW: Sets the horizontal sync signal width in units of characters.
- (4) HSYNP: Sets "horizontal display period + horizontal front porch width" in units of characters.
- (5) VTLN: Sets the vertical cycle in units of horizontal sync signals.
- (6) VDLN: Sets the vertical display period in units of horizontal sync signals.
- (7) VSYNW: Sets the vertical sync signal width in units of horizontal sync signals.
- (8) VSYNP: Sets "vertical display period + vertical front porch width" in units of horizontal sync signals.

### **Notes on Horizontal Direction Settings**

- 1 character = 8 pixels (8 dot clocks). Accordingly, each parameter in the horizontal direction can be set only in dot clock cycles as a multiple of 8. In some cases, a parameter in the horizontal direction needs to be set in dot clock cycles as a value other than a multiple of 8, depending on the LCD module used. However, in such a case, specify the nearest multiple of 8, convert that value into units of characters (change it to 1/8 of the value), and set the converted value. Confirm thoroughly that this setting does not cause trouble in the LCD module used. For example, there may be an undisplayed range at either the left or right end.
- The size of horizontal pixel data must be equal to or less than 2048 bytes per line. For example, when the 16-bit RGB565 packed format is specified by setting the PKF bits in MLDDFR to B'00011, the maximum number of horizontal pixels is 1024 (128 characters).
- Make a setting to satisfy the expression of "HTCN  $\ge$  HDCN + 3".
- Make a setting to satisfy the expression of "HTCN  $\geq$  HSYNP + HSYNW".
- Make a setting to satisfy the expression of "HSYNP ≥ HDCN + 1".



### Notes on Vertical Direction Settings

• Make a setting to satisfy the expression of "VTLN  $\ge$  VDLN + 1".

Table 10 shows the LCDC registers used for setting the sync signals.

| Function                        | Register                                                |  |
|---------------------------------|---------------------------------------------------------|--|
| Sets the horizontal sync signal | Main LCD horizontal character number register (MLDHCNR) |  |
|                                 | Main LCD horizontal sync signal register (MLDHSYNR)     |  |
| Sets the vertical sync signal   | Main LCD vertical line number register (MLDVLNR)        |  |
|                                 | Main LCD vertical sync signal register (MLDVSYNR)       |  |

### Table 10 Sync Signal Setting

### 2.3.8 Setting the LCD Interface

The LCD module interface (RGB or SYS), transfer mode, signal polarity, etc. should be set according to the specifications of the LCD module used. Set each value with reference to the datasheet for the LCD module used.

- (1) Module interface: Selects the RGB interface or SYS interface. This application note shows settings for a case in which the RGB interface is selected.
- (2)Main LCD module setting: Selects the bit width and number of transfer cycles of the image data of the LCD module.
- (3) Sync signal polarity: Sets the vertical sync signal (VSYNC) and horizontal sync signal (HSYNC) to low-active or high-active. When low-active is set, a low-level signal is output during the period of the sync signal (HSYNC/VSYNC in section 2.3.7). In contrast, a high-level signal is output when high-active is set.
- (4) HSYNC signal output control: Sets whether or not to output HSYNC during the VSYNC blanking period.
- (5) Dot clock control: Sets whether or not to output the dot clock during the blanking period of VSYNC and HSYNC.
- (6) Dot clock polarity: Selects whether the LCD module latches image data at the rising edge of the dot clock or the falling edge of the dot clock.
- (7) Display enable signal polarity: Sets the display enable signal (LCDDISP) to low-active or high-active.
- (8) Display data polarity: Sets the display data to high-active (bit value is output without change) or low-active (bit value is output after being inverted).

For details, please refer to the section 31.3.8 "Main LCD Module Type Register 1 (MLDMT1R)" in the *SH7722 Group Hardware Manual* (REJ09B0314), or the section 27.3.8 "Main LCD Module Type Register 1 (MLDMT1R)" in the *SH7731 Group Hardware Manual* (REJ09B0488).

Table 11 shows the LCDC registers used for setting the LCD interface.

#### Table 11 Setting the LCD Interface

| Function                                                                                                                     | Register                                  |
|------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| <ul> <li>Setting the module interface</li> <li>VSYNC polarity</li> <li>HSYNC polarity</li> <li>Dot clock polarity</li> </ul> | Main LCD module type register 1 (MLDMT1R) |
| Note: Used when the SYS                                                                                                      | Main LCD module type register 2 (MLDMT2R) |
| interface is selected. Not handled in this application note.                                                                 | Main LCD module type register 3 (MLDMT3R) |



### 2.3.9 Setting the Power Management

The LCDC has a function to operate, in accordance with the specified sequence, three control signals for managing the power supply of the LCD module. Using this function enables power control of the LCD module to be synchronized with the display start and display stop of the LCDC. The external pins that can be controlled by this function are the following three pins (hereafter expressed as power management pins).

- LCDVCPWC pin: First pin to become high at display start and last pin to become low at display stop.
- LCDVEPWC pin: Second pin to become high at display start and second pin to become low at display stop.
- LCDDON pin: Last pin to become high at display start and first pin to become low at display stop.

Table 12 shows the LCDC registers used for setting the power management.

#### Table 12 Power Management Setting

| Function                      | Register                                    |
|-------------------------------|---------------------------------------------|
| Sets the timing for the power | Main LCD power management register (MLDPMR) |
| management pins               |                                             |

Transitions of the signal levels of the power management pins at LCDC activation are shown in figure 10.



Figure 10 Transition Example of Power Management Pins

The delay between each signal is a number of frames equal to the value of the bits in MLDPMR for setting the sequence interval. For details, please refer to the section 31.3.26 "Main LCD Power Management Register (MLDPMR)" and the section 31.4.6 "Power Management Function" in the *SH7722 Group Hardware Manual* (REJ09B0314), or the section 27.3.26 "Main LCD Power Management Register (MLDPMR)" and the section 27.4.6 "Power Management Function" in the *SH7721 Group Hardware Manual* (REJ09B0314), or the section "in the *SH7731 Group Hardware Manual* (REJ09B0488).

# 2.4 Activation and Termination of LCDC

Figure 11 shows a flowchart of activating the LCDC and starting display on the main LCD module.



Figure 11 LCDC Activation Flow

Figure 12 shows a flowchart of terminating the LCDC and stopping display on the main LCD module.



Figure 12 LCDC Termination Flow



- LCDC setup which is described in section 2.3 can be made in a random order after the module standby state has been canceled. The setup can be started from any setting.
- When using an LCDC interrupt, start main LCD display after enabling interrupts to be generated. If generation of an LCDC interrupt is enabled (interrupt mask is cleared, etc.) after display has already been started, an interrupt may occur at an undesired timing.
- Starting or stopping of main LCD display is controlled by the DO bit in LCDC control register 2 (LDCNT2R). Since this application note only handles main LCD display, other display enable control bits should be handled as shown in table 13.
- Display start and display stop can be confirmed by the LPS bits in the main LCD power management register (MLDPMR), regardless of whether the power management function is used.

#### Table 13 Display Enable Bits at Main LCDC Control

| LCDC Register Name                   | Display Enable      | Remarks                                                 |
|--------------------------------------|---------------------|---------------------------------------------------------|
| LCDC control register 1<br>(LDCNT1R) | DE: Display Enable  | Always set to 1.                                        |
| LCDC control register 2              | ME: Main LCD Enable | Always set to 1.                                        |
| (LDCNT2R)                            | SE: Sub LCD Enable  | Always set to 0.                                        |
|                                      | DO: Display On      | Set to 1 at display start and set to 0 at display stop. |



# 2.5 LCDC Synchronous Design

If there is only one frame buffer when the image data to be displayed by the LCDC is updated, while the LCDC is reading data from the frame buffer, new frame information is drawn to that same frame buffer. This causes the image to be distorted, such as, screen tearing. The necessary operations to avoid this are to prepare several frame buffers, and change the LCDC reading destination upon completion of drawing to the frame buffer whose contents are to be displayed next. The LCDC facilitates frame buffer switching by having two planes for frame buffer information.



Figure 13 Overview of Plane Switching Operation



### 2.5.1 Multiple Buffer Switching Using Register Planes A and B

The LCDC has frame buffer information for two planes: plane A and plane B. The register plane being displayed is called the used plane and the register plane not being displayed is called the unused plane. The information on the frame buffer to be displayed next is set to the unused plane, and upon completion of drawing to the frame buffer, the used plane and unused plane are switched and the new frame buffer is displayed.

For a register with planes A and B, the same value should be set for both planes A and B, except for the address registers (MLDSA1R and MLDSA2R). While the LCDC is activated, only the address register values can be changed.

Table 14 lists the registers which have planes A and B and are handled in this application note. When plane A is displayed, the LCDC operates with the plane A register settings, whereas when plane B is displayed, the LCDC operates with the plane B register settings.

A mirror address can be used to set an unused-plane register. All registers with two planes A and B have mirror addresses, and reading from and writing to a mirror address results in reading from and writing to an unused plane.

#### Table 14 Registers Having Planes A and B and Appearing in this Application Note

| LCDC Display Enable                                               | Remarks                                         |
|-------------------------------------------------------------------|-------------------------------------------------|
| Main LCD display data read start address register 1 (MLDSA1R)     | _                                               |
| Main LCD display data read start address register 2 (MLDSA2R)     | _                                               |
| Main LCD module type register 1 (MLDMT1R)                         | The same value should be set in planes A and B. |
| Main LCD data format register (MLDDFR)                            | The same value should be set in planes A and B. |
| Main LCD display data storing memory line size register (MLDMLSR) | The same value should be set in planes A and B. |
| Main LCD horizontal character number register (MLDHCNR)           | The same value should be set in planes A and B. |
| Main LCD horizontal sync signal register (MLDHSYNR)               | The same value should be set in planes A and B. |
| Main LCD vertical line number register (MLDVLNR)                  | The same value should be set in planes A and B. |
| Main LCD vertical sync signal register (MLDVSYNR)                 | The same value should be set in planes A and B. |

Note: Though the LCDC input image data swap register (LDDDSR) is stated to have planes A and B in table 31.3, Register Configuration, in section 31, LCD Controller (LCDC), in the "SH7722 Group Hardware Manual (REJ09B0314-0200) Rev. 2.00", or in table 27.3, Register Configuration, in section 27, LCD Controller (LCDC), in the "SH7731 Group Hardware Manual (REJ09B0488-0100) Rev. 1.00", this is an error.



### **Plane Switching Method**

The register planes can be manually switched by software and automatically switched by hardware.

• Software switching: When the MRS bit in the LCDC register side change control register (LDRCNTR) is inverted from 0 to 1 or from 1 to 0, planes A and B are switched at the same time the next frame display operation is finished (a frame end interrupt (FE) occurs simultaneously with the frame display operation end). When the MRS bit is changed from 0 to 1, plane A is switched to plane B, and when the MRS bit is changed from 1 to 0, plane B is switched to plane A. At this time, the MRC bit in LDRCNTR must be set to 0 to disable hardware switching. Figure 14 shows the timing chart for hardware switching. Shown here is an example of flag usage by software in order to achieve synchronization with the previous-stage processing.



Figure 14 Timing of Software Switching Occurrence

The drawing end flag is set when the previous-stage processing has completed drawing. The LCDC monitors the drawing end flag by the frame end interrupt processing. If the flag is set, information on the frame buffer displayed next is set to the unused-plane registers and the MRS bit is inverted. Register plane switching occurs simultaneously with the next frame end interrupt, and the image displayed by the LCDC is updated.



• Hardware switching: When the MRC bit in the LCDC register side change control register (LDRCNTR) is set to 1, the LCDC automatically switches planes A and B each time the frame display operation finishes (a frame end interrupt (FE) occurs simultaneously with the frame display operation end). At this time, the MRS bit setting is invalidated.

Frame buffer #0 Previous-stage LCDC processing #1 Plane A: Frame buffer #0 Plane B: Frame buffer #0  $\parallel$ VSYNC VSYNC VSYNC VSYNC VSYNC FE (frame end interrupt) FE FE FE| FE Previous-stage awing pi ocessing to #1 processing Information on frame buffer for which drawing has completed is set Next frame information Frame buffer #0 Frame buffer #1 (retained by software) eB) ad from #0 (plane A) Read from #0 (pla Read from #0 (plane A) Read from #0 (plane B) Read from #1 (plane A) Read from #1 (plane P LCDC Display #0 (plane A) Display #0 (pl eB) Display #0 (plane A) Display #0 (plane B) Display #1 (plane A) Display #1 (plane Display of #1 Reading of next frame is is started started simultaneously with FE Information on frame buffer #0 Write #0 Write #0 Write #1 Write #1 Write #1 is set to both planes A and B to plane A to plane B to plane B to plane A to plane A because plane switching alwa Software processing: occurs [FE interrupt processing] Always writes information on the next frame buffer to unused-plane registers





Since the planes are switched automatically at the same time a frame end interrupt (FE) occurs in hardware switching, when drawing to the new frame buffer has not completed, both planes A and B need the same frame information. Therefore, in the operation example shown, the frame buffer information that should be displayed next is retained, and the next frame buffer information is set to the unused-plane registers at every frame end interrupt. The same frame buffer information is set to planes A and B in the initial state, and information on the currently displayed frame is set to the unused plane if the frames are not updated.

After the LCDC is activated, the LCDC displays frame buffer #0 while automatically switching planes A and B until the previous-stage processing has completed drawing. After drawing has finished, the previous-stage processing updates the next frame information. After update, the LCDC sets the new frame information to the unused-plane registers by the frame end interrupt processing, and the image to be displayed simultaneously with the next frame end interrupt is updated.

With either switching method, register planes are switched at the same time a frame end interrupt is generated. Accordingly, when the user needs to change the settings of the unused plane, to perform it in the frame end interrupt processing is the best timing for software.



#### 2.5.2 Synchronous Design Example of Asynchronous Previous-Stage Processing and Multiple Buffers of LCDC

This section shows an operation example of a system in which an image is updated asynchronously with VSYNC of the LCDC by the previous-stage processing and that image is displayed by the LCDC, such as captured images or movie of a camera. Three planes are allocated for the frame buffers of the LCDC, and planes are switched by software switching. The LCDC refresh rate is assumed to be 60 Hz, and the frame rate of the previous-stage processing is assumed to be approximately 30 fps.

Information on frame buffer #0 is set to plane A. In the frame end interrupt processing, the drawing end flag of the previous-stage processing is checked. If the next frame buffer can be displayed, information on the next frame buffer #1 is set to the mirror address and the MRS bit in the LCDC register side change control register (LDRCNTR) is inverted. Hereafter, the drawing end flag of the previous-stage processing is checked in the frame end interrupt processing. Depending on the result, the mirror address is set to the register and the MRS bit is inverted, thus causing the planes to be switched.



Figure 16 Operation Example of Movie Display System Using Three Frame Buffers



# 3. Estimating Load on the Bus in System Design

As the SH7722 has an architecture where the video and audio modules and the CPU share the external memory through the SHwy bus, the system design should estimate the load on the bus and ensure that the total load from all modules does not exceed the transfer bandwidth for the memory.

### 3.1 Bus Occupancy by LCDC

The LCDC provides a function for displaying up to the maximum displayable size by LCD module as shown in table 1. However, the images to be displayed are stored in the external memory connected through the SHwy bus, which is shared with the CPU, so memory access contention occurs among the LCDC, CPU, and other modules. The LCDC should read data from the external memory without delay so that every image is displayed in time. If read access is delayed, the LCDC buffer will underflow and image display will be disturbed.

The LCDC has a line buffer; as soon as display of a frame is completed, the LCDC starts prefetching the next frame. Even during the blanking period, it can read data from memory into the line buffer. Figure 17 shows the best case where the LCDC constantly reads frame buffer data from memory without interruption by other memory access.



Figure 17 Best Case for Frame Buffer Reading

The bus bandwidth (byte/s) required by the LCDC in the best case is calculated as follows:

Horizontal image size [pixels] × vertical image size [pixels] × input pixel size [byte/pixel] × refresh rate [fps]

In actual systems, there will always be memory access contention among the LCDC, CPU, and other modules and the best case cannot be achieved (figure 18).





#### Figure 18 Frame Buffer Reading in Actual Systems

In the worst case, the LCDC requires enough bus bandwidth to complete reading the data that should be output in one dot-clock period from memory within one dot-clock period. This is the maximum bus bandwidth required by the LCDC.

The rate (byte/s) of image data output from the LCDC is calculated as follows.

Rate of image data output from LCDC [byte/s] =

LCDC dot-clock frequency  $\times$  (output pixel size / number of transfer cycles  $*^1$ )

Note: \*1. Number of transfer cycles:

This is the amount of transfers per cycle determined by the main LCD module setting in section 2.3.8. For example, when MIFTYP[3:0] = b'0000 in MLDMT1R, three-time transfer at 24 bpp is selected. Therefore, (output pixel size / number of transfer cycles) = (24 / 8) / 3 = 1 [byte/cycle]. When MIFTYP[3:0] = b'1011, which selects one-time transfer at 24 bpp, (output pixel size / number of transfer cycles) = (24 / 8) / 3 = 1 [byte/cycle]. When MIFTYP[3:0] = b'1011, which selects one-time transfer at 24 bpp, (output pixel size / number of transfer cycles) = (24 / 8) / 1 = 3 [byte/cycle].

The maximum bus bandwidth required by the LCDC can be calculated by replacing the output pixel size with the input pixel size in the above equation (according to note 3 in section 2.3.4, when input pixel size  $\neq$  output pixel size, the LCDC pads the lower bits with 0 or discards the lower bits to convert the input pixels into the output pixels).

Rate of image data input to LCDC [byte/s] =

LCDC dot-clock frequency × (input pixel size / number of transfer cycles)

When estimating the load on the bus from the LCDC, assume the worst case and control any other memory access or bus occupancy so that the maximum bus bandwidth requirement is satisfied.

### 3.2 Effective Bandwidth of SDRAM

As the SH7722/SH7731 internal bus (SHwy bus) has enough transfer bandwidth relative to the external memory, the transfer bandwidth of the external memory will be a bottleneck in a system. When frame buffers are allocated in the SDR-SDRAM (SDRAM), the peak bandwidth of the SDRAM is calculated as follows.

#### SDRAM peak bandwidth = SDRAM frequency [MHz] × SDRAM bus width [byte/cycle]

In actual applications such as video systems, multiple memory blocks are accessed at the same time. Accordingly, the SDRAM command sequence and CAS latency will be practical matters of concern because they cause access wait.





Figure 19 Examples of SDRAM Access

For example, an estimate of the effective SDRAM bandwidth is shown below assuming the following conditions.

- SDRAM frequency: 106.66 MHz
- SDRAM bus width: 32-bit
- Practical number of access wait cycles (WAIT): 5 (Estimated by considering the command issuing and CAS latency and assuming that the SBSC is set to bank active mode and the burst count is set to 4)
- Access size: 16-byte (Most of the access from the LCDC is 32-byte burst access, but 16-, 8-, or 4-byte burst access also occurs. In this calculation example, 16-byte burst access is used as an average of the access sizes.)
- Number of Bursts (BN): 4

Effective SDRAM bandwidth = SDRAM frequency [MHz] × (data readable in one cycle) [byte/cycle]

= SDRAM frequency [MHz] × access size [byte] / (WAIT + BN) [cycle]

= 188 Mbytes/s

In the earlier stages of design, the target ratio of the load on the bus from the video and audio modules should be 60% or less of the effective bandwidth.

Effective SDRAM bandwidth  $\times$  60% = 190 Mbytes/s  $\times$  0.6 = 113 Mbytes/s



# 3.3 Sample Calculation of Load on the Bus from LCDC

When the LCDC displays  $640 \times 480$  RGB565 images on a VGA-size LCD module with the 18-bpp (RGB666) bus width in one-time transfer mode at a 25-MHz dot clock and a 60-Hz refresh rate, the maximum instantaneous data rate required by the LCDC is calculated as follows.

25 [MHz] × (16 / 8) [Byte] / 1 [time transfer] = 50.0 [Mbytes/s]

This rate is faster than the target rate (effective SDRAM bandwidth  $\times$  60% = 113 Mbytes/s) in section 3.2.



# 4. Description of the Sample Application

This section describes an example of pin connection and various settings as a sample application that uses the LCDC to display graphic images.

# 4.1 TFT-LCD Panel Specifications

The following shows the specifications of the LS037V7DW01 TFT-LCD panel (manufactured by Sharp Corporation) used in this sample application. As the details of the specifications differ depending on the TFT-LCD panel actually used in your system, please refer to the datasheet for the target LCD panel.

### 4.1.1 General Specifications

Table 15 lists the general specifications of the TFT-LCD panel used in this application.

| Item                | Specifications                                                                                        |
|---------------------|-------------------------------------------------------------------------------------------------------|
| Resolution          | VGA or QVGA (VGA is used in this application)                                                         |
| Pixel format        | H 480 $\times$ V 640 (Number of dots: H (480 $\times$ 3) $\times$ V640)<br>* 1 pixel = R + G + B dots |
| Pixel configuration | R, G, B vertical stripe                                                                               |
| Input signal        | CMOS RGB (6 bits each, digital)                                                                       |

### 4.1.2 Pin Functions

Table 16 lists the pin functions of the TFT-LCD panel used in this application.

| Symbol | Description                                   |
|--------|-----------------------------------------------|
| RESB   | Reset signal                                  |
| INI    | Power on control                              |
| DEN    | Data enable signal                            |
| HSYNC  | Horizontal synchronizing signal               |
| VSYNC  | Vertical synchronizing signal                 |
| CLKIN  | System clock signal                           |
| R5-0   | Red data signals (6 bits, MSB: R5, LSB: R0)   |
| G5-0   | Green data signals (6 bits, MSB: G5, LSB: G0) |
| B5-0   | Blue data signals (6 bits, MSB: B5, LSB: B0)  |



### 4.1.3 Interface Timing

Table 17 lists the interface timing and characteristics of the TFT-LCD panel used in this application.

| Table 17 TFT-LCD Panel Timing Characteristics | (Excerpt from Datasheet) |
|-----------------------------------------------|--------------------------|
|-----------------------------------------------|--------------------------|

|       |                        |      |                  |      | -     |      |       |
|-------|------------------------|------|------------------|------|-------|------|-------|
| ltem  |                        | MODE | Symbol           | Min. | Тур.  | Max. | Unit  |
| CLK   | Cycle time             | VGA  | t <sub>CLK</sub> | 38   | 39.7  | 41.7 | ns    |
|       |                        | QVGA | _                | 152  | 158.8 | 167  |       |
| HSYNC | Cycle time             | VGA  | t <sub>HS</sub>  | _    | 648   | _    | CLK   |
|       |                        | QVGA | —                | _    | 324   | _    |       |
|       | Horizontal back porch  | VGA  | t <sub>HBP</sub> | 28   | 78    | 166  |       |
|       |                        | QVGA | —                | 14   | 38    | 82   |       |
|       | Horizontal front porch | VGA  | t <sub>HFP</sub> | 0    | 88    | 138  |       |
|       |                        | QVGA | _                | 0    | 44    | 68   |       |
|       | Valid display period   | VGA  | t <sub>HHW</sub> | _    | 480   | _    |       |
|       |                        | QVGA | _                | _    | 240   | _    |       |
|       | Sync signal width      |      | t <sub>HSW</sub> | _    | 2     | _    |       |
| VSYNC | Cycle time             | VGA  | t <sub>VS</sub>  | _    | 648   | _    | Hsync |
|       |                        | QVGA | —                | _    | 324   | _    |       |
|       | Vertical back porch    | VGA  |                  | _    | (1)   | _    |       |
|       |                        | QVGA | —                | _    | (1)   | _    |       |
|       | Vertical front porch   | VGA  |                  | _    | (6)   | _    |       |
|       |                        | QVGA | —                | _    | (2)   | _    |       |
|       | Valid display period   | VGA  | _                | _    | 640   | _    |       |
|       |                        | QVGA | _                | _    | 320   | _    |       |
|       | Sync signal width      |      | t <sub>VSW</sub> |      | 1     |      |       |

Note: The vertical back porch and vertical front porch times are estimated from the timing chart because they are not specified in the AC characteristics table.

Table 18 shows an example of LCDC timing settings for VGA display calculated from the characteristics listed in table 17.



| Function          | Register                                                   | Bit Name                                                                 | Number of<br>Dot Clock | Setting<br>Value<br>Example |
|-------------------|------------------------------------------------------------|--------------------------------------------------------------------------|------------------------|-----------------------------|
| Horizontal timing | Main LCD horizontal character<br>number register (MLDHCNR) | HTCN:<br>1/8 of horizontal cycle                                         | 648/8 = 81             | 0x51                        |
| settings          |                                                            | HDCN:<br>1/8 of horizontal display period                                | 480/8 = 60             | 0x3C                        |
|                   | Main LCD horizontal sync signal register (MLDHSYNR)        | HSYNW:<br>1/8 of horizontal sync signal width                            | 2/8 = 1                | 0x01                        |
|                   |                                                            | HSYNP:<br>1/8 of (horizontal display period +<br>horizontal front porch) | 568/8 = 71             | 0x47                        |
| Vertical timing   | Main LCD vertical line number register (MLDVLNR)           | VTLN:<br>Vertical cycle                                                  | 648                    | 0x288                       |
| settings          |                                                            | VDLN:<br>Vertical display period                                         | 640                    | 0x280                       |
|                   | Main LCD vertical sync signal register (MLDVSYNR)          | VSYNW:<br>Vertical sync signal width                                     | 1                      | 0x01                        |
|                   |                                                            | VSYNP:<br>Vertical display period + vertical<br>front porch              | 646                    | 0x286                       |

### Table 18 Example of VGA Timing Settings

Although the horizontal sync signal width is two clock cycles according to the datasheet, the minimum horizontal sync signal width that can be specified in the LCDC is eight clock cycles (one character). Therefore, the horizontal back porch time is set to 72 clock cycles, which is six clock cycles shorter than the standard 78 clock cycles.



# 4.2 TFT-LCD Panel Connection Circuit Example

# 4.2.1 Pin Connection Example

Figure 20 shows the TFT-LCD panel connection circuit example in this application.

| SH7722/SH7731 |                                                                                                      | LS037V7DW01         |
|---------------|------------------------------------------------------------------------------------------------------|---------------------|
| LCDD17        |                                                                                                      | R5                  |
| LCDD16        |                                                                                                      | R4                  |
| LCDD15        |                                                                                                      | R3                  |
| LCDD14        |                                                                                                      | R2                  |
| LCDD13        |                                                                                                      | R1                  |
| LCDD12        |                                                                                                      | R0                  |
| LCDD11        |                                                                                                      | G5                  |
| LCDD10        |                                                                                                      | G4                  |
| LCDD9         |                                                                                                      | G3                  |
| LCDD8         |                                                                                                      | G2                  |
| LCDD7         |                                                                                                      | G1                  |
| LCDD6         |                                                                                                      | G0                  |
| LCDD5         |                                                                                                      | B5                  |
| LCDD4         |                                                                                                      | B4                  |
| LCDD3 -       |                                                                                                      | B3                  |
| LCDD2         |                                                                                                      | B2                  |
| LCDD1 -       |                                                                                                      | B1                  |
| LCDD0 -       |                                                                                                      | В0                  |
| LCDDCK        |                                                                                                      | CLKIN               |
| LCDHSYN       |                                                                                                      | HSYNC               |
| LCDVSYN       |                                                                                                      | VSYNC               |
| LCDDISP       |                                                                                                      | DEN                 |
| LCDDON        |                                                                                                      | INI                 |
| LCDVEPWC      |                                                                                                      | RESB                |
| LCDVCPWC      | 3.3 V                                                                                                | VCC                 |
|               | Power control<br>circuit<br>Note: When LCDVCPWC is hig<br>is supplied; when it is low<br>is cut off. | h, 3.3 V<br>, power |





### 4.2.2 Clock Setting

The TFT-LCD panel in this application needs 25-MHz dot clock supply when operating in VGA mode. As the SH7722 reference platform does not supply an external clock to the LCDLCLK pin, a 25-MHz clock should be generated from B $\phi$  or P $\phi$ . Under the conditions described in the "SH7722/SH7731 Group Application Note: SH7722/SH7731 Example of Initialization (REJ06B0942)", B $\phi$  = 66 MHz and P $\phi$  = 33 MHz, which cannot generate 25 MHz even after being divided. To generate a 25-MHz clock, this application example sets the operating frequencies as shown in section 1.3, Applicable Conditions, and selects P $\phi$  as the source for the dot clock.

### 4.2.3 Power Management Setting

The LCDC power management function is specified as follows according to the power control timing requirements of the TFT-LCD panel used in this application.

#### To Turn on the Power:

Requirement (1): VCC (+3.3 V) should settle within a 2-frame period:

 $\rightarrow$  Power-on sequence period A (ONA) is set to 2 to ensure two frames for the VCC settling period.

Requirement (2): The sync signals and RGB data should be output before INI is driven high:

 $\rightarrow$  Power-on sequence period B (ONB) + power-on sequence period C (ONC) should be 1 or larger. In this example, ONB is set to 1.

Requirement (3): The RESB signal should be kept low for at least 20  $\mu$ s after VCC (+3.3 V) has settled:  $\rightarrow$  ONB is set to 1.

Requirement (4): RESB should be driven high before INI:

 $\rightarrow$  ONC is set to 1.

### To Turn Off the Power

Requirement (5): The sync signal and RGB data output should be stopped and RESB should be driven low after 5frame period has passed since INI is driven low:

Power-off sequence period A (OFFD) is set to 5.

Requirement (6): Power-off sequence period B (OFFE) and power-off sequence period C (OFFF) are set to 1 in this application although the TFT-LCD panel specifications do not prescribe such requirements.





Figure 21 Example of Power Management Setting



# 4.3 Sample Program Specifications

This section describes the specifications of the sample program and shows the flowchart of each processing.

#### 4.3.1 Specifications

- (1) Displays in turn four gradation images (gray-scale, red, green, and blue) drawn by the CPU on the VGA portrait (W480 × H640) TFT-LCD panel.
- (2)Activates the LCDC, displays the images in turn with switching among four frame buffers, and then stops the LCDC.
- (3) Repeats step (2) infinitely.
- (4) Switches the planes by software.

### 4.3.2 Main Flowchart of the Sample Program

Figure 22 shows the main flowchart of the sample program.



Figure 22 Main Flowchart of Sample Program



### 4.3.3 Initial Setting of the LCDC

Figure 23 shows the flowchart for initial setting of the LCDC.











Figure 23 Flowchart for LCDC Initial Setting in Sample Program



## 4.3.4 Starting and Stopping LCDC Display

Figure 24 shows the flowchart for starting LCDC display.



Figure 24 Flowchart for LCDC Activation in Sample Program

Figure 25 shows the flowchart for stopping LCDC display.



Figure 25 Flowchart for LCDC Termination in Sample Program



## 4.3.5 LCDC Plane Switching Settings

Figure 26 shows the flowchart for switching LCDC planes. This processing only sets the plane switching flag. The settings necessary for LCDC plane switching are made in the frame end interrupt processing.



Figure 26 Flowchart for LCDC Plane Switching in Sample Program



## 4.3.6 LCDC Frame End Interrupt Settings

Figure 27 shows the flowchart for LCDC frame end interrupt processing. When the plane switching flag is set, this processing makes the necessary settings for plane switching in the LCDC. Plane switching is actually done at the end of the next frame. A wait is inserted for the INTC priority decision period (5 P $\phi$  clock cycles) so that clearing of end interrupt bit FS is reflected in the INTC.



Figure 27 Flowchart for LCDC Frame End Interrupt in Sample Program



## 4.3.7 Section Allocation

Table 19 shows the allocation of the sections used in this application.

### Table 19 Section Allocation

| Section Name | Description                                       | ion Area |            | Address (Virtual Address)           |  |
|--------------|---------------------------------------------------|----------|------------|-------------------------------------|--|
| Р            | Program area (with no specification)              |          | 0x00003000 | P0 area                             |  |
| С            | Constant area                                     |          | -          | (caching enabled and                |  |
| C\$BSEC      | Structure for uninitialized data area addresses   | ROM      | -          | MMU address<br>translation enabled) |  |
| C\$DSEC      | Structure for initialized data area addresses     | ROM      | -          |                                     |  |
| D            | Initialized data (initial values)                 |          | -          |                                     |  |
| PROMC        | ROMC Area for program stored in ROM               |          | -          |                                     |  |
| В            | Uninitialized data area                           |          | 0x0C000000 |                                     |  |
| R            | Initialized data area                             | RAM      | -          |                                     |  |
| PRAMC        | Area for copying program stored in ROM            | RAM      | -          |                                     |  |
| INTHRAM      | Area for copying interrupt and exception handlers | RAM      | -          |                                     |  |
| INTPRAM      | NTPRAM Area for copying interrupt functions       |          | -          |                                     |  |
| S            | Stack area                                        | RAM      | 0x0FFFF9F0 |                                     |  |
| PINTHandler  | Exception and interrupt handlers                  | ROM      | 0x80000800 | P1 area                             |  |
| VECTTBL      | Reset vector table                                |          | -          | (caching enabled and                |  |
|              | Interrupt vector table                            |          | _          | MMU address                         |  |
| INTTBL       | Interrupt mask table                              | ROM      | -          | translation disabled)               |  |
| PIntPRG      | Interrupt functions                               | ROM      | -          |                                     |  |
| B_LCD_BUFF   | LCDC frame buffers                                | RAM      | 0x8E000000 |                                     |  |
| SP_S         | Stack dedicated for TLB-miss handler              | RAM      | 0x8FFFFDF0 |                                     |  |
| RSTHandler   |                                                   |          | 0xA0000000 | P2 area                             |  |
| PResetPRG    |                                                   |          | -          | (caching disabled and               |  |
| PnonCACHE    | Program area<br>(cache-disabled access)           | ROM      | -          | MMU address translation disabled)   |  |



#### 5. Listing of the Sample Program

(1) Sample Program Listing: "main.c"

```
1
2
     * DISCLAIMER
3
     * This software is supplied by Renesas Electronics Corporation. and is only
4
5
     * intended for use with Renesas products. No other uses are authorized.
6
    * This software is owned by Renesas Electronics Corporation. and is protected under
7
     * all applicable laws, including copyright laws.
8
9
    * THIS SOFTWARE IS PROVIDED "AS IS" AND RENESAS MAKES NO WARRANTIES
10
11
    * REGARDING THIS SOFTWARE, WHETHER EXPRESS, IMPLIED OR STATUTORY,
    * INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
12
    * PARTICULAR PURPOSE AND NON-INFRINGEMENT. ALL SUCH WARRANTIES ARE EXPRESSLY
13
    * DISCLAIMED.
14
15
16
    * TO THE MAXIMUM EXTENT PERMITTED NOT PROHIBITED BY LAW, NEITHER RENESAS
17
    * ELECTRONICS CORPORATION. NOR ANY OF ITS AFFILIATED COMPANIES SHALL BE LIABLE
18
    * FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES
19
    * FOR ANY REASON RELATED TO THE THIS SOFTWARE, EVEN IF RENESAS OR ITS
    * AFFILIATES HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
20
21
    * Renesas reserves the right, without notice, to make changes to this
22
23
    * software and to discontinue the availability of this software.
    \,\,^{\star} By using this software, you agree to the additional terms and
2.4
25
    * conditions found by accessing the following link:
    * http://www.renesas.com/disclaimer
26
    27
                                                                           */
2.8
    /* Copyright (C) 2010. Renesas Electronics Corporation., All Rights Reserved.
29
    30
    * System Name : SH7722, SH7731 Sample Program
31
    * File Name : resetprg.c
    * Abstract
32
                 : Sample Program for Setting the SH7722, SH7731 LCDC
    * Version
33
                 : Ver 1.00
                 : SH7722,SH7731
34
    * Device
    * Tool-Chain : High-performance Embedded Workshop (Version 4.05.01.001)
35
36
                 : C/C++ Compiler Package for SuperH Family (V.9.03 release00)
    * OS
                 : None
37
    * H/W Platform : R0P7722TH001ARK for SH7722 Reference Platform
38
   * Description : Sample Program for Setting the SH7722, SH7731 LCDC
39
40
    * Operation
41
                 :
42
    * Limitation :
43
    44
               : 6.July.2009 Ver. 1.00 First Release
45
    * Historv
    46
47
     48
    /*
49
                                                               * /
               :SH7731_ini.c
    /* FILE
                                                               * /
50
                 :Wed, Apr 22, 2009
                                                               */
    /* DATE
51
                                                               * /
52
    /* DESCRIPTION :Main Program
    /* CPU TYPE :SH7722,SH7731
53
                                                               */
54
    /*
                                                               * /
55
    /* This file is generated by Renesas Project Generator (Ver.4.9).
                                                               */
56
     57
58
59
     #include <stdio.h>
```



60 #include <machine.h> #include "iodefine.h" 61 #include "lcdc.h" 62 #include "framebuf.h" 63 64 65 //#include "typedefine.h" 66 #ifdef cplusplus //#include <ios> // Remove the comment when you use ios
//\_SINT ios\_base::Init::init\_cnt; // Remove the comment when you use ios 67 //#include <ios> 68 69 #endif 70 71 void main(void); 72 #ifdef cplusplus extern "C" { 73 void abort(void); 74 75 } 76 #endif 77 78 // Section to be executed in RAM #pragma section ROMC 79 80 \* ID : 81 \* Outline : Sample program main 82 : (produces a display from the LCDC) \* Include 83 84 \* Declaration : void main (void) 85 \* Description : This program displays a VGA image on the main LCD and then, after a software 86 : wait defined by WAIT\_LCDC\_CHGSIDE followed by repeated switching of the : display between the A and B planes TIMES LCDC CHGSIDE times, stops the 87 88 display. 89 : The display is restarted after a software wait defined by WAIT LCDC STOP. 90 • 91 \* Limitation : 92 : \* Argument 93 : none \* Return Value 94 : none \* Calling Functions 95 : 96 97 void main(void) 98 { 99 unsigned long i; 100 unsigned long j; 101 102 /\* Draws the image in frame buffers \*/ 103 make\_gradation(); 104 /\* LCDC initialization : VGA display on the main LCD \*/ 105 106 lcdc init( pg tbl lcdc buf[D LCDC FRAME NUM-1] ); 107 108 109 while(1) 110 { /\* LCDC activation : Starts display on the main LCD \*/ 111 112 lcdc start(); 113 for(i=0;i<D LCDC FRAME NUM;i++)</pre> 114 115 { for(j=0;j<D LCDC WAIT CHGSIDE;j++)</pre> 116 117 { /\* Wait \*/ 118 119 } 120 121 /\* Changes display surface on the LCDC \*/ 122 lcdc chgadr( pg tbl lcdc buf[i] );



| 123 | }                                                                            |
|-----|------------------------------------------------------------------------------|
| 124 | /* Stopping the LCDC : Stops display on the main LCD */                      |
| 125 | <pre>lcdc_stop();</pre>                                                      |
| 126 | <pre>for(j=0;j<d_lcdc_wait_stop;j++)< pre=""></d_lcdc_wait_stop;j++)<></pre> |
| 127 | {                                                                            |
| 128 | /* Wait */                                                                   |
| 129 | }                                                                            |
| 130 | }                                                                            |
| 131 |                                                                              |
| 132 |                                                                              |
| 133 | }                                                                            |
| 134 | #pragma section                                                              |
| 135 |                                                                              |
| 136 | #ifdefcplusplus                                                              |
| 137 | void abort(void)                                                             |
| 138 | {                                                                            |
| 139 |                                                                              |
| 140 | }                                                                            |
| 141 | #endif                                                                       |
|     |                                                                              |



(2) Sample Program Listing: "framebuf.c"

```
1
2
     * DISCLAIMER
3
4
     * This software is supplied by Renesas Electronics Corporation. and is only
5
     * intended for use with Renesas products. No other uses are authorized.
6
    * This software is owned by Renesas Electronics Corporation. and is protected under
7
8
    * all applicable laws, including copyright laws.
9
    * THIS SOFTWARE IS PROVIDED "AS IS" AND RENESAS MAKES NO WARRANTIES
10
    * REGARDING THIS SOFTWARE, WHETHER EXPRESS, IMPLIED OR STATUTORY,
11
    * INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
12
    * PARTICULAR PURPOSE AND NON-INFRINGEMENT. ALL SUCH WARRANTIES ARE EXPRESSLY
13
14
    * DISCLAIMED.
15
16
     * TO THE MAXIMUM EXTENT PERMITTED NOT PROHIBITED BY LAW, NEITHER RENESAS
17
    * ELECTRONICS CORPORATION. NOR ANY OF ITS AFFILIATED COMPANIES SHALL BE LIABLE
18
    * FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES
19
    * FOR ANY REASON RELATED TO THE THIS SOFTWARE, EVEN IF RENESAS OR ITS
    * AFFILIATES HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
20
21
    * Renesas reserves the right, without notice, to make changes to this
22
    * software and to discontinue the availability of this software.
23
    * By using this software, you agree to the additional terms and
2.4
    * conditions found by accessing the following link:
25
    * http://www.renesas.com/disclaimer
2.6
    27
28
    /* Copyright (C) 2010. Renesas Electronics Corporation., All Rights Reserved.
                                                                               */
    29
    * System Name : SH7722, SH7731 Sample Program
30
    * File Name : resetprg.c
31
32
    * Abstract : Sample Program for Setting the SH7722, SH7731 LCDC
33
    * Version : Ver 1.00
34
    * Device
                 : SH7722,SH7731
    * Tool-Chain : High-performance Embedded Workshop (Version 4.05.01.001)
35
                : C/C++ Compiler Package for SuperH Family (V.9.03 release00)
36
    * OS
37
                 : None
    * H/W Platform : R0P7722TH001ARK for SH7722 Reference Platform
38
39
    * Description : Sample Program for Setting the SH7722, SH7731 LCDC
40
    * Operation
41
                  :
42
    * Limitation
                  :
43
    44
              : 21.Oct.2009 Ver. 1.00 First Release
45
    * History
    46
47
48
49
    #include <machine.h>
    #include "iodefine.h"
50
    #include "framebuf.h"
51
52
53
    /* ==== Frame buffers ==== */
54
     #pragma section LCD BUFF
    unsigned long g lcdc buf0[D LCDC HEIGHT][D LCDC WIDTH];
55
    unsigned long g lcdc buf1[D LCDC HEIGHT][D LCDC WIDTH];
56
57
    unsigned long g lcdc buf2[D LCDC HEIGHT][D LCDC WIDTH];
58
    unsigned long g_lcdc_buf3[D_LCDC_HEIGHT][D_LCDC_WIDTH];
59
     #pragma section
60
     /* ==== Frame buffer table ==== */
61
```



void\* pg tbl lcdc buf[4] = { 62 g\_lcdc\_buf0, 63 g lcdc buf1, 64 g lcdc buf2, 65 g\_lcdc\_buf3 66 67 }; 68 69 /\* ==== Prototype declaration ==== \*/ 70 void make\_gradation(void); 71 72 73 74 75 \* ID : \* Outline 76 : Sample program main 77 : (produces a display from the LCDC) \* Include 78 : \* Declaration : void make\_gradation(void) 79 \* Description 80 : This function creates a 24-bpp gradated image in RGB8888 format within the 81 frame buffer. 82 : 83 \* Limitation : 84 \* : 85 \* Argument : none 86 \* Return Value : none \* Calling Functions 87 : 88 89 void make gradation(void) 90 { 91 static unsigned long i; static unsigned long j; 92 93 unsigned long pixel0 = 0; 94 unsigned long pixel1 = 0; 95 unsigned long pixel2 = 0; 96 unsigned long pixel3 = 0; 97 98 for(i=0;i<D LCDC HEIGHT;i++)</pre> 99 { 100 for(j=0;j<D LCDC WIDTH;j++)</pre> 101 { 102 g lcdc buf0[i][j] = pixel0; 103 g\_lcdc\_buf1[i][j] = pixel1; 104 g\_lcdc\_buf2[i][j] = pixel2; 105 g\_lcdc\_buf3[i][j] = pixel3; 106 if( ( j != 0 ) && ( (j%60) == 0 ) ) 107 108 { pixel0 += D LCDC PATTERN0; 109 110 pixel1 += D LCDC PATTERN1; 111 pixel2 += D LCDC PATTERN2; 112 pixel3 += D LCDC PATTERN3; 113 } 114 } pixel0 = 0;115 pixell = 0; 116 pixel2 = 0;117 pixel3 = 0; 118 119 } 120 } 121 122 123 /\* End of File \*/



(3) Sample Program Listing: "framebuf.h"

```
1
2
     * DISCLAIMER
3
4
     * This software is supplied by Renesas Electronics Corporation. and is only
5
     * intended for use with Renesas products. No other uses are authorized.
6
     * This software is owned by Renesas Electronics Corporation. and is protected under
7
8
     * all applicable laws, including copyright laws.
9
     * THIS SOFTWARE IS PROVIDED "AS IS" AND RENESAS MAKES NO WARRANTIES
10
     * REGARDING THIS SOFTWARE, WHETHER EXPRESS, IMPLIED OR STATUTORY,
11
     * INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
12
     * PARTICULAR PURPOSE AND NON-INFRINGEMENT. ALL SUCH WARRANTIES ARE EXPRESSLY
13
14
     * DISCLAIMED.
15
16
     * TO THE MAXIMUM EXTENT PERMITTED NOT PROHIBITED BY LAW, NEITHER RENESAS
17
     * ELECTRONICS CORPORATION. NOR ANY OF ITS AFFILIATED COMPANIES SHALL BE LIABLE
18
    * FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES
19
    * FOR ANY REASON RELATED TO THE THIS SOFTWARE, EVEN IF RENESAS OR ITS
    * AFFILIATES HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
20
21
     * Renesas reserves the right, without notice, to make changes to this
22
    * software and to discontinue the availability of this software.
23
    * By using this software, you agree to the additional terms and
2.4
    * conditions found by accessing the following link:
25
    * http://www.renesas.com/disclaimer
2.6
     27
28
    /* Copyright (C) 2010. Renesas Electronics Corporation., All Rights Reserved.
                                                                                */
    29
     * System Name : SH7722,SH7731 Sample Program
30
     * File Name : resetprg.c
31
32
     * Abstract : Sample Program for Setting the SH7722, SH7731 LCDC
33
    * Version : Ver 1.00
34
     * Device
                 : SH7722,SH7731
    * Tool-Chain : High-performance Embedded Workshop (Version 4.05.01.001)
35
                : C/C++ Compiler Package for SuperH Family (V.9.03 release00)
36
    * OS
37
                 : None
     * H/W Platform : R0P7722TH001ARK for SH7722 Reference Platform
38
39
     * Description : Sample Program for Setting the SH7722, SH7731 LCDC
40
    * Operation
41
                  :
42
    * Limitation
                  :
43
     44
     * History : 21.Oct.2009 Ver. 1.00 First Release
45
     46
47
     #ifndef FRAMEBUF H
48
49
     #define FRAMEBUF H
50
51
    /* ==== Macro definition ==== */
52
    #define D LCDC FRAME NUM
53
   #define D_LCDC_WIDTH 480 /* Width of the image */
#define D_LCDC_HEIGHT 640 /* Hight of the image */
#define D_LCDC_BPD
54
55
56
    #define D LCDC BPP
                             4 /* Number of bytes per pixel */
57
    #define D LCDC STRIDE
                            ( D LCDC WIDTH * D LCDC BPP )
58
   #define D LCDC PATTERN0 0x00200000
59
     #define D LCDC PATTERN1 0x00002000
60
     #define D_LCDC_PATTERN2 0x0000020
61
```

62 #define D\_LCDC\_PATTERN3 0x00202020 63 64 /\* ==== Frame buffer ==== \*/ 65 extern void\* pg\_tbl\_lcdc\_buf[D\_LCDC\_FRAME\_NUM]; 66 67 #endif /\* \_FRAMEBUF\_H\_ \*/ 68 /\* End of File \*/



(4) Sample Program Listing: "lcdc.c"

```
1
2
     * DISCLAIMER
3
4
     * This software is supplied by Renesas Electronics Corporation. and is only
5
     * intended for use with Renesas products. No other uses are authorized.
6
    * This software is owned by Renesas Electronics Corporation. and is protected under
7
8
    * all applicable laws, including copyright laws.
9
    * THIS SOFTWARE IS PROVIDED "AS IS" AND RENESAS MAKES NO WARRANTIES
10
    * REGARDING THIS SOFTWARE, WHETHER EXPRESS, IMPLIED OR STATUTORY,
11
    * INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
12
    * PARTICULAR PURPOSE AND NON-INFRINGEMENT. ALL SUCH WARRANTIES ARE EXPRESSLY
13
14
    * DISCLAIMED.
15
16
     * TO THE MAXIMUM EXTENT PERMITTED NOT PROHIBITED BY LAW, NEITHER RENESAS
17
    * ELECTRONICS CORPORATION. NOR ANY OF ITS AFFILIATED COMPANIES SHALL BE LIABLE
18
    * FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES
19
    * FOR ANY REASON RELATED TO THE THIS SOFTWARE, EVEN IF RENESAS OR ITS
    * AFFILIATES HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
20
21
    * Renesas reserves the right, without notice, to make changes to this
22
    * software and to discontinue the availability of this software.
23
    * By using this software, you agree to the additional terms and
2.4
    * conditions found by accessing the following link:
25
    * http://www.renesas.com/disclaimer
2.6
    27
28
    /* Copyright (C) 2010. Renesas Electronics Corporation., All Rights Reserved.
                                                                            */
    29
    * System Name : SH7722, SH7731 Sample Program
30
    * File Name : resetprg.c
31
32
    * Abstract : Sample Program for Setting the SH7722, SH7731 LCDC
33
    * Version : Ver 1.00
34
    * Device
                : SH7722,SH7731
35
    * Tool-Chain : High-performance Embedded Workshop (Version 4.05.01.001)
               : C/C++ Compiler Package for SuperH Family (V.9.03 release00)
36
    * OS
37
                : None
    * H/W Platform : R0P7722TH001ARK for SH7722 Reference Platform
38
39
    * Description : Sample Program for Setting the SH7722, SH7731 LCDC
40
    * Operation
41
                 :
42
    * Limitation
                 :
43
    44
    * History : 21.Oct.2009 Ver. 1.00 First Release
45
    46
47
48
49
    #include <machine.h>
   #include "iodefine.h"
50
    #include "lcdc.h"
51
    #include "framebuf.h"
52
53
54
    long g flg chg = D LCDC SIDECHG OFF;
55
    56
57
    * ID
    * Outline
58
                           : Sample program main
59
                           : (produces a display from the LCDC)
    * Include
60
                           :
     * Declaration
                          : void lcdc init(void* framebuf adr)
61
```



```
62
      * Description
                                : Initializes the LCDC.
63
                                : Makes necessary settings to enable display on the main LCD.
64
65
66
67
     * Limitation
68
69
     * Argument
                               : none
     * Return Value
70
                              : none
71
     * Calling Functions
                              :
     72
     void lcdc init(void* framebuf adr)
73
74
    {
75
         unsigned long dummy;
76
         /* PFC setting */
77
78
         /* Specifies in the order of MSEL->PSEL->PCR->HiZ. */
         PFC.MSELCRB.BIT.MSELB8 = 0;
79
         PFC.PSELD.WORD = \sim 0 \times 000D;
80
         PFC.PHCR.WORD = 0;
81
         PFC.PLCR.WORD = 0;
82
83
         PFC.PMCR.WORD = 0;
84
         PFC.PRCR.WORD &= ~0x000F;
85
         PFC.HIZCRA.WORD &= ~0x01C0;
86
87
         /* Cancels the power-down mode. */
         LOWP.MSTPCR2 &= ~0x0000001;
88
89
         dummy = LOWP.MSTPCR2; /* Makes a dummy read to confirm that the power-down mode has been canceled. */
90
         /* Frame buffer setting */
91
         LCDCA.MLDSA1R = (unsigned long) D LCDC PHY ADR(framebuf adr);
92
93
         LCDCB.MLDSA1R = (unsigned long) D LCDC PHY ADR(framebuf adr);
94
95
         LCDCA.MLDMLSR = D LCDC STRIDE;
96
         LCDCB.MLDMLSR = D LCDC STRIDE;
97
98
        LCDCA.MLDDFR.BIT.CC = 0; /* Conversion from YCbCr to RGB is not performed. */
99
        LCDCA.MLDDFR.BIT.PKF = 0; /* RGB8888 24bpp */
100
        LCDCB.MLDDFR.BIT.CC = 0;
101
        LCDCB.MLDDFR.BIT.PKF = 0;
102
        /* Dot clock setting */
103
        LCDCA.LDDCKR.BIT.ICKSEL = 1;
                                              /* Po */
104
        LCDCA.LDDCKR.BIT.MOSEL = 1;
105
                                              /* Frequency division 1/1 */
        LCDCA.MLDDCKPAT1R = 0x00000000;
106
107
        LCDCA.MLDDCKPAT2R = 0x0000000;
108
       /* Sync signal setting */
LCDCA.MLDHCNR.BIT.HTCN
109
110
                                    = 81;
111
         LCDCA.MLDHCNR.BIT.HDCN
                                    = 60;
        LCDCA.MLDHSYNR.BIT.HSYNW
                                    = 1;
112
        LCDCA.MLDHSYNR.BIT.HSYNP
113
                                    = 71;
        LCDCA.MLDVLNR.BIT.VTLN
114
                                    = 648;
        LCDCA.MLDVLNR.BIT.VDLN
                                    = 640;
115
        LCDCA.MLDVSYNR.BIT.VSYNW
116
                                   = 1:
117
        LCDCA.MLDVSYNR.BIT.VSYNP
                                    = 646:
118
119
        LCDCB.MLDHCNR.BIT.HTCN
                                    = 81:
120
        LCDCB.MLDHCNR.BIT.HDCN
                                    = 60:
121
        LCDCB.MLDHSYNR.BIT.HSYNW = 1;
                                    = 71;
122
        LCDCB.MLDHSYNR.BIT.HSYNP
123
                                    = 648;
        LCDCB.MLDVLNR.BIT.VTLN
         LCDCB.MLDVLNR.BIT.VDLN
124
                                    = 640;
```



```
125
        LCDCB.MLDVSYNR.BIT.VSYNW
                                 = 1;
126
        LCDCB.MLDVSYNR.BIT.VSYNP
                                 = 646;
127
       /* LCD interface setting */
128
       LCDCA.MLDMT1R.LONG = 0x1C00000A;
                                        /* Main LCD:RGB interface/18bit/active low */
129
130
       LCDCB.MLDMT1R.LONG = 0x1C00000A;
131
132
       /* Data swapping setting */
       LCDCA.LDDDSR.LONG = 0x00000004; /* Longword swapping */
133
134
135
       /* Power management setting */
       LCDCA.MLDPMR.BIT.ONA = 2;
136
137
       LCDCA.MLDPMR.BIT.ONB = 1;
138
       LCDCA.MLDPMR.BIT.ONC = 1;
       LCDCA.MLDPMR.BIT.OFFD = 5;
139
       LCDCA.MLDPMR.BIT.OFFE = 1;
140
       LCDCA.MLDPMR.BIT.OFFF = 1;
141
       LCDCA.MLDPMR.BIT.VC = 1;
142
       LCDCA.MLDPMR.BIT.VE = 1;
143
144
        LCDCA.MLDPMR.BIT.DO = 1;
145
146
        /* Interrupt setting */
147
        /* Masks the LCDC interrupts. */
148
        INTCO.IMR4.BYTE |= D LCDC INT MASK;
149
        /* Enables the LCDC interrupt to be used. */
        INTCO.IPRB = 0x0100; /* Interrupt priority level 1 */
150
       LCDCA.LDINTR.LONG = D LCDC INT FE ON; /* Enables frame end interrupts. */
151
        /* Clears the LCDC interrupt source. */
152
       LCDCA.LDINTR.LONG &= ~D_LCDC_INT_FS_FLG;
153
        /* Clears the mask for the LCDC interrupts. */
154
       INTCO.IMCR4 = D_LCDC_INT_MASK;
155
156
        /* Enables the main LCD */
157
       LCDCA.LDCNT1R.LONG = 0x00000001; /* Enables display. */
158
       LCDCA.LDCNT2R.LONG = 0x00000002; /* Enables the main LCD. */
159
160 }
161
163 * ID
                            :
164 * Outline
                           : Sample program main
165
                           : (produces a display from the LCDC)
166 * Include
                            :
                           : void lcdc_start(void)
    * Declaration
167
    * Description
                           : Activates the LCDC.
168
169
                             :
    * Limitation
170
                             :
171
                            :
                            : none
    * Argument
172
    * Return Value
173
                            : none
174
    * Calling Functions
                            :
    175
    void lcdc start(void)
176
177
    {
178
        /*DO = 1*/
        LCDCA.LDCNT2R.LONG |= 0x00000001; /* Initializes the LCDC */
179
180
       /* Waits until the status changes to "displaying". */
181
       while( LCDCA.MLDPMR.BIT.LPS != 0x0000003 )
182
183
       {
            /* DO NOTHING */
184
185
        }
186
    }
187
```

```
188
   * ID
189
190 * Outline
                       : Sample program main
   *
                       : (produces a display from the LCDC)
191
                        :
192 * Include
                    : void lcdc_chgadr(unsigned long mirror_adr)
: Initializes the LCDC.
193 * Declaration
194 * Description
195
   *
196 * Limitation
197
   *
                        :
198* Argument199* Return Value: none199* Colling Functions:
202 void lcdc chgadr (void* mirror adr)
203 {
      /* Specifies the mirror addresses. */
204
      LCDCM.MLDSA1R = (unsigned long)D LCDC PHY ADR(mirror adr);
205
206
      g_flg_chg = D_LCDC_SIDECHG ON;
207
   }
208
    209
210
    * ID
                        :
                       : Sample program main
    * Outline
211
212
                        : (produces a display from the LCDC)
    * Include
213
                        :
   * Declaration* Description
                   : void lcdc_stop(void)
: Stops the LCDC.
214
215
216 *
   * Limitation
217
218 *
                        •
219 * Argument
                        : none
220 * Return Value
221 * Calling Functions
                       : none
                        •
223 void lcdc stop(void)
224 {
225
      /*DO = 0*/
226
      LCDCA.LDCNT2R.LONG &= ~0x00000001; /* Stops display on the main LCD. */
227
228
      /* Wwaits until the status changes to "stopped". */
229
      while( LCDCA.MLDPMR.BIT.LPS != 0x00000000 )
230
      {
231
          /* DO NOTHING */
232
       }
233
    }
234
235 /* End of File */
```



(5) Sample Program Listing: "lcdc.h"

```
1
2
     * DISCLAIMER
3
4
     * This software is supplied by Renesas Electronics Corporation. and is only
5
     * intended for use with Renesas products. No other uses are authorized.
6
     * This software is owned by Renesas Electronics Corporation. and is protected under
7
8
     * all applicable laws, including copyright laws.
9
     * THIS SOFTWARE IS PROVIDED "AS IS" AND RENESAS MAKES NO WARRANTIES
10
     * REGARDING THIS SOFTWARE, WHETHER EXPRESS, IMPLIED OR STATUTORY,
11
     * INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
12
     * PARTICULAR PURPOSE AND NON-INFRINGEMENT. ALL SUCH WARRANTIES ARE EXPRESSLY
13
14
     * DISCLAIMED.
15
16
     * TO THE MAXIMUM EXTENT PERMITTED NOT PROHIBITED BY LAW, NEITHER RENESAS
17
     * ELECTRONICS CORPORATION. NOR ANY OF ITS AFFILIATED COMPANIES SHALL BE LIABLE
18
     * FOR ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES
19
    * FOR ANY REASON RELATED TO THE THIS SOFTWARE, EVEN IF RENESAS OR ITS
    * AFFILIATES HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
20
21
     * Renesas reserves the right, without notice, to make changes to this
22
     * software and to discontinue the availability of this software.
23
     * By using this software, you agree to the additional terms and
2.4
    * conditions found by accessing the following link:
25
    * http://www.renesas.com/disclaimer
2.6
     27
28
    /* Copyright (C) 2010. Renesas Electronics Corporation., All Rights Reserved.
                                                                               */
    29
     * System Name : SH7722, SH7731 Sample Program
30
     * File Name : resetprg.c
31
32
     * Abstract : Sample Program for Setting the SH7722, SH7731 LCDC
33
    * Version : Ver 1.00
34
     * Device
                 : SH7722,SH7731
35
    * Tool-Chain : High-performance Embedded Workshop (Version 4.05.01.001)
                : C/C++ Compiler Package for SuperH Family (V.9.03 release00)
36
     * OS
37
                 : None
     * H/W Platform : R0P7722TH001ARK for SH7722 Reference Platform
38
39
     * Description : Sample Program for Setting the SH7722, SH7731 LCDC
40
41
    * Operation
                  :
42
     * Limitation
                  :
43
     44
     * History : 21.Oct.2009 Ver. 1.00 First Release
45
     46
47
     #ifndef LCDC H
48
     #define _LCDC_H
49
50
     /* ==== Macro definition ==== */
51
52
     #define D LCDC WAIT CHGSIDE
                                    (20000000/2*1) /* Frequency ÷(number of instructions in the for
53
                    loop)×seconds */
54
     #define D LCDC WAIT STOP
                                    (200000000/2*1) /* Frequency ÷ (number of instructions in the for
55
                   loop)×seconds */
56
57
     #define D LCDC PHY ADR(x)
                                    ( (unsigned long)(x) & ~0xE0000000 )
58
     #define D_LCDC_INT_FE_ON 0x00000400
59
     #define D_LCDC_INT_FS_FLG 0x0000004
60
     #define D_LCDC_INT_MASK 0x01
61
```



62 63 enum { D\_LCDC\_SIDECHG\_OFF = 0, D\_LCDC\_SIDECHG\_ON, 64 65 66 }; 67 68 /\* ==== Function declaration ==== \*/ 69 void lcdc\_init(void\* framebuf\_adr); 70 void lcdc start(void); 71 void lcdc\_chgadr(void\* mirror\_adr); 72 void lcdc stop(void); 73 void lcdc int(void); 74 75 /\* ==== Variable declaration ==== \*/ 76 extern long g flg chg; 77 78 #endif /\* \_LCDC\_H\_ \*/ 79 /\* End of File \*/



1

(6) Sample Program Listing: "vhandler.src"

The vhandler.src file is modified from that described in the "SH7722/SH7731 Group Application Note: SH7722/SH7731 Example of Initialization (REJ06B0942)" as follows.

- The CPG settings are modified so that the applicable conditions in section 1.3 are satisfied.
- As  $B3\phi = 80$  MHz, the timing settings in the SBSC are modified.

For details of the settings, refer to the source code.

```
2
      ...Omitted...
3
                   mov.l #H'A4150000,r0 ;set FRQCR address
4
                   mov.l #H'05022538,r1 ; * Clockin = 33.333MHz, CKIO = 66.6MHz,
5
                                         ; * I Clock = 200MHz, U Clock = 100MHz,
6
                                         ; * SH Clock = 100MHz, B Clock = 50MHz,
7
8
                                          ; * B3 Clock = 80MHz, P Clock = 25MHz
                   mov.l r1,@r0
9
10
11
     ...Omitted...
12
13
      SDRAM INIT:
                   mov.l #H'FE400008,r0 ;set SDCR0 address
14
15
                   mov.l #H'00020809,r1 ;set for SDRAM(Micron MT48LC8M16A2B475)
16
                                         ;64bit bus-width, row 12bit, column 9bit
17
                   mov.l r1,@r0
18
                   mov.l #H'FE40000C,r0 ;set SDWCR address
19
                   mov.l #H'0014248A,r1 ;tRRD 2cyc
20
21
                                         ;tRAS 4cyc
2.2
                                         ;tRP 2cyc
23
                                         ;tRCD 2cyc
24
                                         ;CL
                                              2cvc
25
                                         ;tWR 2cyc
26
                                         ;tRC 6cyc
27
                   mov.l r1,@r0
28
                   mov.l #H'FE400010,r0 ;set SDPCR address
29
                   mov.l #H'00000087,r1 ;default
30
                   mov.l r1,@r0
31
32
                   mov.l #H'FE400018,r0 ;set RTCNT address
33
                   mov.l #H'a55a0000,r1
34
35
                   mov.l r1,@r0
36
37
                   mov.l #H'FE40001C,r0 ;set RTCOR address
                   mov.l #H'a55a004C,r1 ;refresh rate
38
39
                   mov.l r1,@r0
40
41
                   mov.l #H'A4050186,r0 ;set SBSCR address
42
                   mov.W #H'0000,r1 ;Low speed
43
                   mov.W r1,@r0
44
45
                         #H'000030d4.r0
46
                   mov.l
47
     LOOP1:
48
                          r0
                   dt
49
                   bf
                          LOOP1 ;200µs wait
50
                   nop
51
                   nop
52
53
                   mov.l #H'FE400014,r0 ;set RTCSR address
                   mov.l #H'a55a0010,r1 ;B3φ/16
54
```



```
55
                    mov.l
                          r1,@r0
56
57
                   mov.l #H'FE500100,r0 ;set SDMR3(64bit bus-width, CL=2, burstR/W(burst length=1))
58
                   mov.b #H'00,r1
                   mov.b r1,@r0
59
60
                   mov.l #SDRAM_INIT_END,r0
61
62
                    jmp
                           0r0
63
                   nop
64
65
                    .pool
66
67
      ...Omitted...
```

(7) Sample Program Listing: "vecttbl.src"

This program specifies the interrupt priority level that can be accepted during LCDC interrupt processing execution.

As the LCDC interrupt priority level is set to 1, the acceptable priority level is also set to 1 so that another LCDC interrupt is not accepted during earlier LCDC interrupt processing.

```
1 ...Omitted...
3 ...Omitted...
5 ...Omitted...
6 ...Omitted...
```



(8) Sample Program Listing: "intprg.c"

This program registers the LCDC interrupt processing function as an interrupt handler.

```
1
2
     ...Omitted...
    #define I_DIV_P 8 /* I\u03c6:P\u03c6 = 8:1 */
#define INST_NUM 2 /* instruction number of for loop */
#define PCLK_5CYC (5 * I DIV P / 2)
3
4
5
6
7
8
     ...Omitted...
9
   /* H'580 LCD Controler interrupt */
10
* ID
12
                             :
     * Outline
13
                            : Sample program main
14
     *
                            : (produces a display from the LCDC)
     * Include
                            :
15
                        : void lcdc_int(void)
    * Declaration* Description
16
                            : Initializes LCDC.
17
18
                             : Makes necessary settings to enable display on the main LCD.
19
                              :
20
     *
                              :
21
                              :
    * Limitation
22
23
                              :
    * Argument
24
                             : none
    * Return Value :
* Calling Functions :
25
                             : none
26
    27
2.8
     void INT_LCDC_LCDCI(void)
    {
29
30
        unsigned long i;
31
32
       if ( LCDCA.LDINTR.LONG & D LCDC INT FS FLG)
33
        {
34
           LCDCA.LDINTR.LONG &= ~D LCDC INT FS FLG;
35
36
          if( g_flg_chg == D_LCDC_SIDECHG_ON )
37
           {
38
               LCDCA.LDRCNTR.LONG ^= 0x00000002; /* Inverts MRS. */
39
             g_flg_chg = D_LCDC_SIDECHG_OFF;
40
           }
41
42
          /* Waits for the INTC priority decision period. */
43
         for(i=0;i<PCLK 5CYC;i++)</pre>
         {
44
45
             /* DO NOTHING */
46
          }
47
        }
48
    }
49
50
     ...Omitted...
```



# 6. Execution Results

When the above sample application is executed, the following processes will be repeated.

- The power for the LCD module is turned on.
- The gray gradation pattern is displayed.
- The red gradation pattern is displayed.
- The green gradation pattern is displayed.
- The blue gradation pattern is displayed.
- The power for the LCD module is turned off.
- The power for the LCD module is turned on (the above steps are repeated infinitely).



## 7. Documents for Reference

 Software Manual SH-4A Software Manual (REJ09B0003) (The most up-to-date versions of the documents are available on the Renesas Electronics Website.)

 Hardware Manual SH7722 Group Hardware Manual (REJ09B0314) (The most up-to-date versions of the documents are available on the Renesas Electronics Website.)

#### Website and Support

Renesas Electronics Website <u>http://www.renesas.com/</u>

Inquiries

http://www.renesas.com/inquiry

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



# **Revision Record**

|      |              | Description |                                                                                |  |  |
|------|--------------|-------------|--------------------------------------------------------------------------------|--|--|
| Rev. | Date         | Page        | Summary                                                                        |  |  |
| 1.00 | Sep 21, 2010 | _           | First edition issued                                                           |  |  |
| 1.01 | Jun 09, 2011 | 26          | Sample calculation of the maximum data rate required by the LCDC is corrected. |  |  |
| -    |              |             |                                                                                |  |  |
|      |              |             |                                                                                |  |  |
|      |              |             |                                                                                |  |  |
|      |              |             |                                                                                |  |  |
|      |              |             |                                                                                |  |  |
|      |              |             |                                                                                |  |  |

# General Precautions in the Handling of MPU/MCU Products

The following usage notes are applicable to all MPU/MCU products from Renesas. For detailed usage notes on the products covered by this manual, refer to the relevant sections of the manual. If the descriptions under General Precautions in the Handling of MPU/MCU Products and in the body of the manual differ from each other, the description in the body of the manual takes precedence.

- 1. Handling of Unused Pins
  - Handle unused pins in accord 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 one with a different type number, confirm that the change will not lead to problems.

— The characteristics of MPU/MCU in the same group but having different type numbers may differ because of the differences in internal memory capacity and layout pattern. When changing to products of different type numbers, implement a system-evaluation test for each of the products.

#### Notice

- All information included in this document is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Renesas Electronics products listed herein, please confirm the latest product information with a Renesas Electronics sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website.
- Renesas Electronics does not assume any liability for infringement of 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. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 3. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part.
- 4. Descriptions 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 responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information.
- 5. When exporting the products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations. You should not use Renesas Electronics products or the technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. Renesas Electronics products and technology may 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.
- 6. Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein.
- 7. Renesas Electronics products are classified according to the following three quality grades: "Standard", "High Quality", and "Specific". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application categorized as "Specific" without the prior written consent of Renesas Electronics. Further, you may not use any Renesas Electronics product for any application categorized as "Specific" without the prior written consent of Renesas Electronics. Further, you may not use any Renesas Electronics product for any application consent of Renesas Electronics and using the prior written consent of Renesas Electronics and using from the use of any Renesas Electronics product for an application categorized as "Specific" or for which it is not intended where you have failed to obtain the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product for an application categorized as "Specific" or for which the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product is not intended where you have failed to obtain the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product is "Standard". Computers: office equipment; test and measurement equipment; audio and visual equipment; home electronic applicace; machine tools;
  - personal electronic equipment; and industrial robots.
  - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anti-crime systems; safety equipment; and medical equipment not specifically designed for life support.
  - "Specific": Aircraft; aerospace equipment; submersible repeaters; nuclear reactor control systems; medical equipment or systems for life support (e.g. artificial life support devices or systems), surgical implantations, or healthcare intervention (e.g. excision, etc.), and any other applications or purposes that pose a direct threat to human life.
- 8. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges.
- 9. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, 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 please evaluate the safety of the final products or system manufactured by you.
- 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 11. This document may not be 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, or if you have any other inquiries.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majority-owned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics



#### SALES OFFICES

#### **Renesas Electronics Corporation**

http://www.renesas.com

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

| Renesas Electronics America Inc.<br>2880 Scott Boulevard Santa Clara, CA 95050-2554, U.S.A.<br>Tel: +1-404-S88-8000, Fax: +1-408-588-6130                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Renesas Electronics Canada Limited<br>1101 Nicholson Road, Newmarket, Ontario L3Y 9C3, Canada<br>Tel: +1-905-898-5441, Fax: +1-905-898-3220                                                                                    |
| Renesas Electronics Europe Limited<br>Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K<br>Tel: +44-1628-585-100, Fax: +44-1628-585-900                                                                  |
| Renesas Electronics Europe GmbH           Arcadiastrasse 10, 40472 Düsseldorf, Germany           Tel: +49-211-65030, Fax: +49-211-6503-1327                                                                                    |
| Renesas Electronics (China) Co., Ltd.<br>7th Floor, Quantum Plaza, No.27 ZhiChunLu Haidian District, Beijing 100083, P.R.China<br>Tel: +86-10-8235-1155, Fax: +86-10-8235-7679                                                 |
| Renesas Electronics (Shanghai) Co., Ltd.<br>Unit 204, 205, AZIA Center, No. 1233 Lujiazui Ring Rd., Pudong District, Shanghai 200120, China<br>Tel: +86-21-5877-1818, Fax: +86-21-5887-7858 / -7898                            |
| Renesas Electronics Hong Kong Limited<br>Unit 1601-1613, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong<br>Tel: +852-2866-9318, Fax: +852 2868-9022/9044                        |
| Renesas Electronics Taiwan Co., Ltd.<br>13F, No. 363, Fu Shing North Road, Taipei, Taiwan<br>Tel: +886-2-8175-9600, Fax: +886 2-8175-9670                                                                                      |
| Renesas Electronics Singapore Pte. Ltd.<br>1 harbourFront Avenue, #06-10, keppel Bay Tower, Singapore 098632<br>Tel: +65-6213-0200, Fax: +65-6278-8001                                                                         |
| Renesas Electronics Malaysia Sdn.Bhd.<br>Unit 906, Block B, Menara Amcorp, Amcorp Trade Centre, No. 18, Jin Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia<br>Tel: +60-3-7955-9390, Fax: +60-3-7955-9510 |
| Renesas Electronics Korea Co., Ltd.<br>11F., Samik Lavied' or Bildg., 720-2 Yeoksam-Dong, Kangnam-Ku, Seoul 135-080, Korea<br>Tel: +62-2-558-3737, Fax: +82-2-558-5141                                                         |