

RL78/G13

R01AN0736EJ0100 Rev. 1.00 Feb. 22, 2012

# Safety Function (Flash Memory CRC Operation Function)

#### Introduction

This application note explains how to use the flash memory CRC operation function, which is one of the safety functions incorporated in the RL78/G13.

The high-speed CRC performs operation on and compares the data in the code flash memory (addresses 00000H to 0FFFBH) with the results of the operation performed by the object converter.

The general-purpose CRC performs operation on the data in a part of the on-chip RAM and compares their results with the results of the operation preformed again in the same area. The data to be operated on can be changed using by switch input.

Both of the high-speed CRC and general-purpose CRC turn on an LED when the results of the operation match.

## **Target Device**

RL78/G13

When applying the sample program covered in this application note to another microcomputer, modify the program according to the specifications for the target microcomputer and conduct an extensive evaluation of the modified program.

#### **Contents**

| 1.   | Sp   | pecifications                                      | 3  |
|------|------|----------------------------------------------------|----|
| 2.   | Oŗ   | peration Check Conditions                          | 5  |
| 3.   | Re   | elated Application Note                            | 5  |
| 4.   | De   | escription of the Hardware                         | 6  |
| 4.1  | На   | ardware Configuration Example                      | 6  |
| 4.2  | Li   | st of Pins to be Used                              | 6  |
| 5.   | De   | escription of the Software                         | 7  |
| 5.1  | Or   | peration Outline                                   | 7  |
| 5.2  | Li   | st of Option Byte Settings                         | 8  |
| 5.3  | Li   | st of Constants                                    | 8  |
| 5.4  | Li   | st of Variables                                    | 8  |
| 5.5  | Li   | st of Functions                                    | 9  |
| 5.6  | Fu   | nction Specifications                              | 9  |
| 5.7  | Flo  | owcharts                                           | 11 |
| 5.7. | 1    | Overall Flow                                       | 11 |
| 5.7. | 2    | Initialization Function                            | 12 |
| 5.7. | 3    | System Function                                    | 13 |
| 5.7. | 4    | I/O Port Setup                                     | 16 |
| 5.7. | 5    | CPU Clock Setup                                    | 19 |
| 5.7. | 6    | INTPO Initialization                               | 20 |
| 5.7. | 7    | Main Processing                                    | 21 |
| 5.7. | 8    | High-speed CRC Operation Processing                | 24 |
| 5.7. | 9    | Enabling High-speed CRC Operation                  | 28 |
| 5.7. | 10   | Performing High-speed CRC Operation                | 28 |
| 5.7. | 11   | Creating General-purpose CRC Operation Target Data | 29 |
| 5.7. | 12   | General-purpose CRC Operation Processing           | 30 |
| 5.7. | 13   | Starting INTP0 Operation                           | 32 |
| 6.   | Sa   | ample Code                                         | 34 |
| 7.   | Do   | ocuments for Reference                             | 34 |
| Revi | sioı | n Record                                           | 35 |
| Gana | ral  | Precautions in the Handling of MPII/MCII Products  | 36 |

#### 1. **Specifications**

This application note explains how to use the flash memory CRC operation function, which is one of the safety functions incorporated in the RL78/G13.

The high-speed CRC performs operation on and compares the data in the code flash memory (addresses 00000H to 0FFFBH) with the results of the operation performed by the object converter.

The general-purpose CRC performs operation on the data in a part of the on-chip RAM and compares their results with the results of the operation preformed again in the same area. The data to be operated on can be changed using switch input.

Both of the high-speed CRC and general-purpose CRC turn on an LED when the results of the operation match.

Table 1.1 lists the peripheral function to be used and its use. Figure 1.1 shows the outline of operation of the high-speed CRC. Figure 1.2 shows the outline of operation of the general-purpose CRC.

Table 1.1 Peripheral Functions to be Used and its Use

| Peripheral Function                                  | Use                                                       |  |  |
|------------------------------------------------------|-----------------------------------------------------------|--|--|
| Safety function: Flash memory CRC operation function | Performs high-speed CRC and general-purpose CRC           |  |  |
|                                                      | operation in a specified memory area and compares their   |  |  |
|                                                      | results with the separately prepared values to verify the |  |  |
|                                                      | validity of the data.                                     |  |  |



Figure 1.1 **Outline of High-speed CRC Operation** 



Figure 1.2 Outline of General-purpose CRC Operation

## 2. Operation Check Conditions

The sample code described in this application note has been checked under the conditions listed in the table below.

**Table 2.1 Operation Check Conditions** 

| Item                               | Description                                                                        |  |  |  |
|------------------------------------|------------------------------------------------------------------------------------|--|--|--|
| Microcontroller used               | RL78/G13 (R5F100LEA)                                                               |  |  |  |
| Operating frequency                | High-speed on-chip oscillator (HOCO) clock: 32 MHz                                 |  |  |  |
|                                    | CPU/peripheral hardware clock: 32 MHz                                              |  |  |  |
| Operating voltage                  | 5.0 V (Operation is possible over a voltage range of 2.9 V to 5.5 V.)              |  |  |  |
|                                    | LVD operation (V <sub>LVI</sub> ): Reset mode which uses 2.81 V (2.76 V to 2.87 V) |  |  |  |
| Integrated development environment | CubeSuite+ V1.00.01 from Renesas Electronics Corp.                                 |  |  |  |
| C compiler                         | CA78K0R V1.20 from Renesas Electronics Corp.                                       |  |  |  |
| Flash memory programmer            | E1 (R0E000010KCE00) from Renesas Electronics Corp.                                 |  |  |  |
| Flash memory programming software  | Renesas Flash Programmer V1.01.00 from Renesas Electronics Corp.                   |  |  |  |

## 3. Related Application Note

The application note that is related to this application note is listed below for reference.

RL78/G13 Initialization (R01AN0451E) Application Note

## 4. Description of the Hardware

## 4.1 Hardware Configuration Example

Figure 4.1 shows an example of the hardware configuration used for this application note.



Figure 4.1 Hardware Configuration

Cautions:

- 1. The purpose of this circuit is only to provide the connection outline and the circuit is simplified accordingly. When designing and implementing an actual circuit, provide proper pin treatment and make sure that the hardware's electrical specifications are met (connect the input-only ports separately to  $V_{DD}$  or  $V_{SS}$  via a resistor).
- 2. Connect any pins whose name begins with  $EV_{SS}$  to  $V_{SS}$  and any pins whose name begins with  $EV_{DD}$  to  $V_{DD}$ , respectively.
- 3.  $V_{DD}$  must be held at not lower than the reset release voltage  $(V_{LVI})$  that is specified as LVD.

#### 4.2 List of Pins to be Used

Table 4.1 lists the pins to be used and their functions.

| Table 4.1 | Pins to be Used and their Functions |
|-----------|-------------------------------------|
|           |                                     |

| Pin Name                                                                    | I/O    | Description                                                                   |
|-----------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------|
| P50 Input General-purpose CRC operation target data switching input change) |        | General-purpose CRC operation target data switching input (changed/no change) |
| P62                                                                         | Output | LED1 lighting control port (high-speed CRC operation result output)           |
| P63                                                                         | Output | LED2 lighting control port (general-purpose CRC operation result output)      |
| P137/INTP0                                                                  | Input  | General-purpose CRC operation start trigger input                             |

## 5. Description of the Software

## 5.1 Operation Outline

The sample application covered in this application note uses the flash memory CRC operation function, which is one of the safety functions incorporated in the RL78/G13.

The high-speed CRC performs operation on and compares the data in the code flash memory (addresses 00000H to 0FFFBH) with the results of the operation performed by the object converter.

The general-purpose CRC performs operation on the data in a part of the on-chip RAM and compares their results with the results of the operation performed again in the same area. The data to be operated on can be changed by using switch input.

Both of the high-speed CRC and general-purpose CRC turn on an LED when the results of the operation match.

(1) Initialize the flash memory CRC operation function.

<Conditions for setting>

- Set the range of the area on which high-speed CRC operation is to be performed to the flash memory (addresses 00000H to 0FFFBH).
- Set the operation mode of the high-speed CRC to "Start operation on the execution of a HALT instruction."
- (2) Initialize the operation control ports.

<Conditions for setting>

- General-purpose CRC operation target data switching: Set up P50 as an input port (using an external pull-up resistor).
- LED1 /2 output (CRC operation true-false determination result): Set up P62 and P63 as output ports.
- General-purpose CRC operation start trigger button: Set up P137/INTP0 in INTP0 falling edge detection interrupt mode (using an external pull-up resistor).
- (3) Perform high-speed CRC operation on the flash memory (addresses 00000H to 0FFFBH).
- (4) Compare the results obtained in step (3) with the target values (specified in advance at build time) that are generated in the flash memory (addresses 0FFFCH to 0FFFDH) by the object converter and turns on LED1 if they match.
- (5) Store arbitrary data and the results of general-purpose CRC operation in the general-purpose CRC operation target area (part of the on-chip RAM).
- (6) Enter the HALT mode and waits for a general-purpose CRC operation start trigger (INTP0).
- (7) Exit the HALT mode on the occurrence of a CRC operation start trigger and update the general-purpose CRC operation target data if the state of the general-purpose CRC operation target data switch is "Changed."
- (8) Perform general-purpose CRC operation.
- (9) Turn on LED2 if the results obtained in step (8) match the ones obtained in step (5). Otherwise, turn off the LED2.
- (10) Repeat steps (5) to (9).
- Cautions: 1. When building the application, disable on-chip debugging with the link option. This is because addresses 0FFFCH to 0FFFDH which are to be used to store the results of high-speed CRC operation as the target of comparison are also reserved for the on-chip debugger and a conflict would otherwise occur.
  - 2. When checking the application for normal operation, write HEX data into the RL78/G13 using a flash memory programmer that is compatible with the RL78/G13.
  - 3. For detailed usage notes on the product, refer to RL78/G13 User's Manual: Hardware.



## 5.2 List of Option Byte Settings

Table 5.1 summarizes the settings of the option bytes.

Table 5.1 Option Byte Settings

| Address                 | Value     | Description                                               |  |  |
|-------------------------|-----------|-----------------------------------------------------------|--|--|
| 000C0H/010C0H 11101111B |           | Disables the watchdog timer.                              |  |  |
|                         |           | (Stops counting after the release from the reset status.) |  |  |
| 000C1H/010C1H           | 01111111B | LVD reset mode which uses 2.81 V (2.76 V to 2.87 V)       |  |  |
| 000C2H/010C2H           | 11101000B | HS mode, HOCO: 32 MHz                                     |  |  |
| 000C3H/010C3H           | 00000100B | Prohibits the on-chip debugger.                           |  |  |

#### 5.3 List of Constants

Table 5.2 lists the constants that are used in this sample program.

Table 5.2 Constants for the Sample Program

| Constant            | Setting | Description                                                                                                          |
|---------------------|---------|----------------------------------------------------------------------------------------------------------------------|
| HIGHSPEED_CALC_ADDR | 0x0FFFC | Address at which the results of the high-speed CRC operation generated by the object converter are to be stored      |
| GP_CALC_BUFF_SIZE   | 254     | Size of the general-purpose CRC operation target buffer (excluding the 2 bytes in the area storing operation result) |

## 5.4 List of Variables

Table 5.3 lists the global variable that is used by this sample program.

Table 5.3 Global Variable

| Type Variable Name         |              | Contents                      | Function Used             |
|----------------------------|--------------|-------------------------------|---------------------------|
| uint8_t calc_data[GP_CALC_ |              | Area for storing the          | main                      |
|                            | BUFF_SIZE+2] | general-purpose CRC operation | R_CreateDataForComparison |
|                            |              | target data                   | R_GeneralPurposeCRCProc   |

#### 5.5 List of Functions

Table 5.4 lists the global functions that are used by this sample program.

#### Table 5.4 Functions

| Function Name             | Outline                                               |  |  |
|---------------------------|-------------------------------------------------------|--|--|
| R_HighSpeedCRCProc        | High-speed CRC operation processing                   |  |  |
| R_ExecHighSpeedCRC        | Execution of high-speed CRC operation                 |  |  |
| R_CreateDataForComparison | Creation of general-purpose CRC operation target data |  |  |
| R_GeneralPurposeCRCProc   | General-purpose CRC operation processing              |  |  |

## 5.6 Function Specifications

Shown below are the functions that are used in this sample program.

#### [Function Name]] R\_HighSpeedCRCProc

Synopsis High-speed CRC operation processing

Header —

Declaration uint16 t R HighSpeedCRCProc(void)

Explanation This function performs high-speed CRC operation and returns the results.

Arguments None

Return value Results of high-speed CRC operation

Remarks None

#### [Function Name] R\_ExecHighSpeedCRC

Synopsis Execution of high-speed CRC operation

Header —

Declaration void R\_ExecHighSpeedCRC(void)

Explanation This function expands the HALT and RET instructions in the on-chip RAM (stack area) to start

high-speed CRC operation. This function also executes the HALT and RET instructions that

are expanded in the on-chip RAM.

Arguments None Return value None Remarks None

#### [Function Name] R\_CreateDataForComparison

Synopsis Creation of general-purpose CRC operation target data

Header —

 $\label{eq:comparison} \mbox{Declaration} \qquad \mbox{void R\_CreateDataForComparison( uint8\_t *data, uint8\_t size )}$ 

Explanation This function creates the target data to be subjected to general-purpose CRC operation.

Performs general-purpose CRC operation on that data and places the results in the given

area.

Arguments \*data Pointer to the area storing the target data

Return value size Size of the area storing the target data

Remarks None Synopsis None



## [Function Name] R\_GeneralPurposeCRCProc

Synopsis General-purpose CRC operation processing

Header —

Declaration uint16\_t R\_GeneralPurposeCRCProc( uint8\_t \*data, uint8\_t size )

Explanation This function performs general-purpose CRC operation and returns the results.

Arguments \*data Pointer to the target data

size Size of the target data

Return value Result of the general-purpose CRC operation

Remarks None

## 5.7 Flowcharts

## 5.7.1 Overall Flow

Figure 5.1 shows the overall flow of the sample program described in this application note.



Figure 5.1 Overall Flow

## 5.7.2 Initialization Function

Figure 5.2 shows the flowchart for the initialization function.



Figure 5.2 Initialization Function

## 5.7.3 System Function

Figure 5.3 shows the flowchart for the system function.



Figure 5.3 System Function

Controlling the operation of the CRC circuit and specifying the operation range

Flash memory CRC control register (CRC0CTL)
 Specifies the CRC circuit operation trigger.
 Specifies the CRC operation range.

Symbol: CRC0CTL

| 7      | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|--------|---|------|------|------|------|------|------|
| CRC0EN | 0 | FEA5 | FEA4 | FEA3 | FEA2 | FEA1 | FEA0 |
| 1      | 0 | 0    | 0    | 0    | 0    | 1    | 1    |

#### Bit 7

| CRC0EN | Control of CRC circuit operation                             |
|--------|--------------------------------------------------------------|
| 0      | Stop the operation.                                          |
| 1      | Start the operation according to HALT instruction execution. |

Bits 5 to 0

| FEA5 | FEA4 | FEA3       | FEA2               | FEA1 | FEA0 | CRC Operation Range                 |
|------|------|------------|--------------------|------|------|-------------------------------------|
| 0    | 0    | 0          | 0                  | 0    | 0    | 00000H to 03FFBH (16 K to 4 bytes)  |
| 0    | 0    | 0          | 0                  | 0    | 1    | 00000H to 07FFBH (32 K to 4 bytes)  |
| 0    | 0    | 0          | 0                  | 1    | 0    | 00000H to 0BFFBH (48 K to 4 bytes)  |
| 0    | 0    | 0          | 0                  | 1    | 1    | 00000H to 0FFFBH (64 K to 4 bytes)  |
| 0    | 0    | 0          | 1                  | 0    | 0    | 00000H to 13FFBH (80 K to 4 bytes)  |
| 0    | 0    | 0          | 1                  | 0    | 1    | 00000H to 17FFBH (96 K to 4 bytes)  |
| 0    | 0    | 0          | 1                  | 1    | 0    | 00000H to 1BFFBH (112 K to 4 bytes) |
| 0    | 0    | 0          | 1                  | 1    | 1    | 00000H to 1FFFBH (128 K to 4 bytes) |
| 0    | 0    | 1          | 0                  | 0    | 0    | 00000H to 23FFBH (144 K to 4 bytes) |
| 0    | 0    | 1          | 0                  | 0    | 1    | 00000H to 27FFBH (160 K to 4 bytes) |
| 0    | 0    | 1          | 0                  | 1    | 0    | 00000H to 2BFFBH (176 K to 4 bytes) |
| 0    | 0    | 1          | 0                  | 1    | 1    | 00000H to 2FFFBH (192 K to 4 bytes) |
| 0    | 0    | 1          | 1                  | 0    | 0    | 00000H to 33FFBH (208 K to 4 bytes) |
| 0    | 0    | 1          | 1                  | 0    | 1    | 00000H to 37FFBH (224 K to 4 bytes) |
| 0    | 0    | 1          | 1                  | 1    | 0    | 00000H to 3BFFBH (240 K to 4 bytes) |
| 0    | 0    | 1          | 1                  | 1    | 1    | 00000H to 3FFFBH (256 K to 4 bytes) |
| 0    | 1    | 0          | 0                  | 0    | 0    | 00000H to 43FFBH (272 K to 4 bytes) |
| 0    | 1    | 0          | 0                  | 0    | 1    | 00000H to 47FFBH (288 K to 4 bytes) |
| 0    | 1    | 0          | 0                  | 1    | 0    | 00000H to 4BFFBH (304 K to 4 bytes) |
| 0    | 1    | 0          | 0                  | 1    | 1    | 00000H to 4FFFBH (320 K to 4 bytes) |
| 0    | 1    | 0          | 1                  | 0    | 0    | 00000H to 53FFBH (336 K to 4 bytes) |
| 0    | 1    | 0          | 1                  | 0    | 1    | 00000H to 57FFBH (352 K to 4 bytes) |
| 0    | 1    | 0          | 1                  | 1    | 0    | 00000H to 5BFFBH (368 K to 4 bytes) |
| 0    | 1    | 0          | 1                  | 1    | 1    | 00000H to 5FFFBH (384 K to 4 bytes) |
| 0    | 1    | 1          | 0                  | 0    | 0    | 00000H to 63FFBH (400 K to 4 bytes) |
| 0    | 1    | 1          | 0                  | 0    | 1    | 00000H to 67FFBH (416 K to 4 bytes) |
| 0    | 1    | 1          | 0                  | 1    | 0    | 00000H to 6BFFBH (432 K to 4 bytes) |
| 0    | 1    | 1          | 0                  | 1    | 1    | 00000H to 6FFFBH (448 K to 4 bytes) |
| 0    | 1    | 1          | 1                  | 0    | 0    | 00000H to 73FFBH (464 K to 4 bytes) |
| 0    | 1    | 1          | 1                  | 0    | 1    | 00000H to 77FFBH (480 K to 4 bytes) |
| 0    | 1    | 1          | 1                  | 1    | 0    | 00000H to 7BFFBH (496 K to 4 bytes) |
| 0    | 1    | 1          | 1                  | 1    | 1    | 00000H to 7FFFBH (512 K to 4 bytes) |
|      |      | Other that | Setting prohibited |      |      |                                     |

Caution: For details on the register setup procedures, refer to RL78/G13 User's Manual: Hardware.

Remarks: Input the expected CRC operation value to be used for comparison in the lowest 4 bytes of the

flash memory. Note that the operation range will thereby be reduced by 4 bytes.

## 5.7.4 I/O Port Setup

Figure 5.4 shows the flowchart for setting up the I/O ports.



Figure 5.4 I/O Port Setup

Note: Refer to the section entitled "Flowcharts" in RL78/G13 Initialization Application Note (R01AN0451E) for the configuration of the unused ports.

Caution: Provide proper treatment for unused pins so that their electrical specifications are met. Connect each of any unused input-only ports to  $V_{DD}$  or  $V_{SS}$  via a separate resistor.

## Setting up LED ports

• Port register (P6) Select the output level of P62 and P63.

• Port mode register (PM6)
Select the I/O mode of the ports for PM62 and PM63.

#### Symbol: P6

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| P67 | P66 | P65 | P64 | P63 | P62 | P61 | P60 |
| Х   | Х   | Х   | Х   | 1   | 1   | Х   | Х   |

#### Bit 3

| P63 | P63 output level selection |
|-----|----------------------------|
| 0   | Low-level output           |
| 1   | High-level output          |

#### Bit 2

| P62 | P62 output level selection |
|-----|----------------------------|
| 0   | Low-level output           |
| 1   | High-level output          |

#### Symbol: PM6

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|
| PM67 | PM66 | PM65 | PM64 | PM63 | PM62 | PM61 | PM60 |
| Х    | Х    | Х    | Х    | 0    | 0    | Х    | Х    |

#### Bit 2

| PM62 | P62 I/O mode selection         |
|------|--------------------------------|
| 0    | Output mode (output buffer on) |
| 1    | Input mode (output buffer off) |

#### Bit 3

| PM63 | P63 I/O mode selection         |
|------|--------------------------------|
| 0    | Output mode (output buffer on) |
| 1    | Input mode (output buffer off) |

Setting up the general-purpose CRC operation target data switch

• Port mode register (PM5) Select the I/O mode of P50.

## Symbol: PM5

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|
| PM57 | PM56 | PM55 | PM54 | PM53 | PM52 | PM51 | PM50 |
| Х    | Х    | Х    | Х    | Х    | Х    | Х    | 1    |

#### Bit 0

| PM50 | P50 I/O mode selection         |
|------|--------------------------------|
| 0    | Output mode (output buffer on) |
| 1    | Input mode (output buffer off) |

## 5.7.5 CPU Clock Setup

Figure 5.5 shows the flowchart for setting up the CPU clock.



Figure 5.5 CPU Clock Setup

Caution: For details on the procedure for setting up the CPU clock (R\_CGC\_Create ()), refer to the section entitled "Flowcharts" in RL78/G13 Initialization Application Note (R01AN0451E).

#### 5.7.6 INTPO Initialization

Figure 5.6 shows the flowchart for initializing INTP0.



Figure 5.6 INTP0 Initialization

Setting up the INTP0 pin edge detection

- External interrupt rising edge enable register (EGP0)
- External interrupt falling edge enable register (EGN0) Enable edge of INTP0: Falling edge

Symbol: EGP0

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|
| EGP7 | EGP6 | EGP5 | EGP4 | EGP3 | EGP2 | EGP1 | EGP0 |
| Х    | Х    | Х    | Х    | Х    | Х    | Х    | 0    |

Symbol: EGN0

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|
| EGN7 | EGN6 | EGN5 | EGN4 | EGN3 | EGN2 | EGN1 | EGN0 |
| Х    | Х    | Х    | Х    | Х    | Х    | Х    | 1    |

Bit 0

| EGP0 | EGN0 | INTP0 pin enable edge selection |
|------|------|---------------------------------|
| 0    | 0    | Edge detection disabled         |
| 0    | 1    | Falling edge                    |
| 1    | 0    | Rising edge                     |
| 1    | 1    | Both rising and falling edges   |

## 5.7.7 Main Processing

Figures 5.7 and 5.8 show the flowcharts for main processing.



Figure 5.7 Main Processing (1/2)



Figure 5.7 Main Processing (2/2)

Object converter option settings

CRC operation

Do CRC operation: Yes

CRC result output address: 0FFFCH

CRC operation range: Addresses 00000H to 0FFFBH

CRC operation mode: High-speed CRC

Object Converter Option Settings (Properties window of CubeSuite+ CA78K0R build tool)



## 5.7.8 High-speed CRC Operation Processing

Figure 5. 9 shows the flowchart for the high-speed CRC operation processing.



Figure 5.9 High-speed CRC Operation Processing

MK2L

## Masking on all interrupts

• Interrupt mask flag registers (MK0, MK1, and MK2) Set interrupt masks.





Symbol: MK0L

| 7    | 6    | 5    | 4    | 3    | 2    | 1     | 0      |
|------|------|------|------|------|------|-------|--------|
| PMK5 | PMK4 | PMK3 | PMK2 | PMK1 | PMK0 | LVIMK | WDTIMK |
| 1    | 1    | 1    | 1    | 1    | 1    | 1     | 1      |

MK2H

## Symbol: MK0H

| 7       | 6       | 5       | 4      | 3      | 2       | 1       | 0       |
|---------|---------|---------|--------|--------|---------|---------|---------|
| SREMK0  | SRMK0   | STMK0   |        |        | SREMK2  | SRMK2   | STMK2   |
| TMMK01H | CSIMK01 | CSIMK00 | DMAMK1 | DMAMK0 | TMMK11H | CSIMK21 | CSIMK20 |
|         | IICMK01 | IICMK00 |        |        |         | IICMK21 | IICMK20 |
| 1       | 1       | 1       | 1      | 1      | 1       | 1       | 1       |

## Symbol: MK1L

| 7      | 6      | 5      | 4      | 3       | 2       | 1       | 0       |
|--------|--------|--------|--------|---------|---------|---------|---------|
|        |        |        |        |         | SREMK1  | SRMK1   | STMK1   |
| TMMK03 | TMMK02 | TMMK01 | TMMK00 | IICAMK0 | TMMK03H | CSIMK11 | CSIMK10 |
|        |        |        |        |         |         | IICMK11 | IICMK10 |
| 1      | 1      | 1      | 1      | 1       | 1       | 1       | 1       |

## Symbol: MK1H

| 7      | 6      | 5       | 4       | 3    | 2    | 1     | 0    |
|--------|--------|---------|---------|------|------|-------|------|
|        |        | SRMK3   | STMK3   |      |      |       |      |
| TMMK04 | TMMK13 | CSIMK31 | CSIMK30 | KRMK | ITMK | RTCMK | ADMK |
|        |        | IICMK31 | IICMK30 |      |      |       |      |
| 1      | 1      | 1       | 1       | 1    | 1    | 1     | 1    |

## Symbol: MK2L

|   | 7     | 6    | 5    | 4    | 3    | 2      | 1      | 0      |
|---|-------|------|------|------|------|--------|--------|--------|
|   | PMK10 | PMK9 | PMK8 | PMK7 | PMK6 | TMMK07 | TMMK06 | TMMK05 |
| Г | 1     | 1    | 1    | 1    | 1    | 1      | 1      | 1      |

## Symbol: MK2H

| 7    | 6       | 5    | 4                 | 3      | 2      | 1      | 0     |
|------|---------|------|-------------------|--------|--------|--------|-------|
| FLMK | IICAMK1 | MDMK | SREMK3<br>TMMK13H | TMMK12 | TMMK11 | TMMK10 | PMK11 |
| 1    | 1       | 1    | 1                 | 1      | 1      | 1      | 1     |

Bits 7 to 0

| XXMKX | Interrupt processing control  |  |  |  |  |  |
|-------|-------------------------------|--|--|--|--|--|
| 0     | Interrupt processing enabled  |  |  |  |  |  |
| 1     | Interrupt processing disabled |  |  |  |  |  |

Flash memory CRC operation results

Flash memory CRC operation result register (PGCRCL)
 Store the high-speed CRC operation results.

Symbol: PGCRCL



Bits 15 to 0

| PGCRC15 to 0 | High-speed CRC operation results            |
|--------------|---------------------------------------------|
| 0000H to     | Store the high aread CDC energtion regults  |
| FFFFH        | Store the high-speed CRC operation results. |

## 5.7.9 Enabling High-speed CRC Operation

Figure 5.10 shows the flowchart for enabling high-speed CRC operation.



Figure 5.10 Enabling High-speed CRC Operation

#### 5.7.10 Performing High-speed CRC Operation

Figure 5.11 shows the flowchart for performing high-speed CRC operation.



Figure 5.11 Performing High-speed CRC Operation

## 5.7.11 Creating General-purpose CRC Operation Target Data

Figure 5.12 shows the flowchart for creating general-purpose CRC operation target data.



Figure 5.12 Creating General-purpose CRC Operation Target Data

## 5.7.12 General-purpose CRC Operation Processing

Figure 5.13 shows the flowchart for the general-purpose CRC operation processing.



Figure 5.13 General-purpose CRC Operation Processing

#### General-purpose CRC operation results

• CRC data register (CRCD)
Store general-purpose CRC operation results.

Symbol: CRCD



Caution: For details on the register setup procedures, refer to RL78/G13 User's Manual: Hardware.

## General-purpose CRC calculation data

• CRC input register (CRCIN)
Store the data to be subject to calculation by the general-purpose CRC.

Symbol: CRCIN



Bits 7 to 0

| Bits 7 to 0 | Description |
|-------------|-------------|
| 00H to FFH  | Input data  |

## 5.7.13 Starting INTP0 Operation

Figure 5.14 shows the flowchart for starting INTPO operation.



Figure 5.14 Starting INTP0 Operation

## Making INTP0 interrupt settings

- Interrupt request flag register (IF0L) Clear interrupt request flag.
- Interrupt mask flag register (MK0L) Clear interrupt mask

## Symbol: IF0L

| 7    | 6    | 5    | 4    | 3    | 2    | 1     | 0      |
|------|------|------|------|------|------|-------|--------|
| PIF5 | PIF4 | PIF3 | PIF2 | PIF1 | PIF0 | LVIIF | WDTIIF |
| Х    | Х    | Х    | Х    | Х    | 0    | Х     | Х      |

#### Bit 2

| PIF0 | Interrupt request flag                                          |  |  |  |  |  |
|------|-----------------------------------------------------------------|--|--|--|--|--|
| 0    | lo interrupt request signal is generated                        |  |  |  |  |  |
| 1    | Interrupt request signal is generated, interrupt request status |  |  |  |  |  |

#### Symbol: MK0L

| 7    | 6    | 5    | 4    | 3    | 2    | 1     | 0      |
|------|------|------|------|------|------|-------|--------|
| PMK5 | PMK4 | PMK3 | PMK2 | PMK1 | PMK0 | LVIMK | WDTIMK |
| Х    | х    | х    | х    | х    | 0    | х     | х      |

#### Bit 2

| PMK0 | Interrupt processing control  |  |  |  |  |  |
|------|-------------------------------|--|--|--|--|--|
| 0    | nterrupt processing enabled   |  |  |  |  |  |
| 1    | Interrupt processing disabled |  |  |  |  |  |

## 6. Sample Code

The sample code is available on the Renesas Electronics Website.

#### 7. Documents for Reference

RL78/G13 User's Manual: Hardware (R01UH0146E)

RL78 Family User's Manual: Software (R01US0015E)

(The latest versions of the documents are available on the Renesas Electronics Website.)

Technical Updates/Technical Brochures

(The latest versions of the documents are available on the Renesas Electronics Website.)

## **Website and Support**

Renesas Electronics Website

• http://www.renesas.com/index.jsp

#### Inquiries

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

| Revision Record |
|-----------------|
|-----------------|

| Rev. | Date          | Description |                      |
|------|---------------|-------------|----------------------|
|      |               | Page        | Summary              |
| 1.00 | Feb. 22, 2012 | _           | First edition issued |
|      |               |             |                      |

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

#### **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 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 part number, confirm that the change will not lead to problems.
  - The characteristics of MPU/MCU in the same group but having different part numbers may differ because of the differences in internal memory capacity and layout pattern. When changing to products of different part numbers, implement a system-evaluation test for each of the products.

#### Notice

- 1. 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.
- 2. 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 for which it is not intended without the prior written consent of Renesas Electronics. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an application categorized as "Specific" or for which the 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" unless otherwise expressly specified in a Renesas Electronics data sheets or data books, etc.
  - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; 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
  - 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 "Specific": 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. 2880 Scott Boulevard Santa Clara, CA 95050-2554, U.S.A. Tel: +1-408-588-6000, Fax: +1-408-588-6130

Renesas Electronics Canada Limited 1101 Nicholson Road, Newmarket, Ontario L3Y 9C3, Canada Tel: +1-905-898-5441, Fax: +1-905-898-3220

Renesas Electronics Europe Limited
Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K
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.
7th Floor, Quantum Plaza, No.27 ZhiChunLu Haidian District, Beijing 100083, P.R.China Tel: +86-10-8235-1155, Fax: +86-10-8235-7679

Renesas Electronics (Shanghai) Co., Ltd.
Unit 204, 205, AZIA Center, No.1233 Lujiazui Ring Rd., Pudong District, Shanghai 200120, China Tel: +86-21-5877-1818, Fax: +86-21-6887-7858 / -7898

Renesas Electronics Hong Kong Limited
Unit 1801-1613, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong
Tel: +852-2868-9318, Fax: +852-2868-9022/9044

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

Renesas Electronics Singapore Pte. Ltd.
1 harbourFront Avenue, #06-10, keppel Bay Tower, Singapore 098632 Tel: +65-6213-0200, Fax: +65-6278-8001

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

Renesas Electronics Korea Co., Ltd. 11F., Samik Lavied' or Bidg., 720-2 Yeoksam-Dong, Kangnam-Ku, Seoul 135-080, Korea Tel: +82-2-558-3737, Fax: +82-2-558-5141