# RL78/G12 # Initialization CC-RL #### Introduction This application note describes the basic setting items that are necessary for initializing the RL78/G12. The sample program discussed in this application note initializes the RL78/G12 and provides On/Off control of three LEDs according to the combination of two switch input states. ## **Target Device** RL78/G12 ## **Contents** | 1. | Specification | 2 | |----|--------------------------------------|----| | 2. | Operation Evaluate Conditions | 3 | | 3. | Description of the Hardware | 4 | | 4. | Description of the Software | 5 | | 5. | Selecting/Changing the Target Device | 21 | | 6. | Notes on Using the Sample Code | 23 | | 7. | Sample Code | 25 | | 8 | Documents for Reference | 25 | ## 1. Specification The sample program described in this application note performs basic initialization steps such as the setup of the clock frequency and input/output ports. After the initialization, the program controls, in its main processing routine, the On/Off of three LEDs according to the combination of two switch input states. Table 1.1 lists the peripheral functions to be used and their usage and figure 1.1 shows the outline of the processing. Table 1.1 Peripheral Functions to be Used and their Usage | Peripheral Function | Usage | |---------------------|-----------------------------------| | Port input/output | Switch input (SW1 and SW2) | | | LED On/Off control (LED0 to LED2) | Figure 1.1 Operation Processing Outline # 2. Operation Evaluate Conditions The sample code contained in this application note has been evaluated under the conditions listed in the table below. **Table 2.1 Operation Check Conditions** | Item | Description | |-------------------------------------|-------------------------------------------------------------------------| | Microcontroller used | RL78/G12 (R5F1026A) | | Operating frequency | High-speed on-chip oscillator (HOCO) clock: 24 MHz | | | CPU/peripheral hardware clock: 24 MHz | | Operating voltage | 5.0 V (can run on a voltage range of 2.9 V to 5.5 V.) | | | LVD operation (V <sub>LVD</sub> ): Reset mode 2.81 V (2.76 V to 2.87 V) | | Integrated development | CS+ for CC V3.01.00 from Renesas Electronics Corp. | | environment (CS+) | | | Assembler (CS+) | CC-RL V1.01.00 from Renesas Electronics Corp. | | Integrated development | e² studio V4.0.2.008 from Renesas Electronics Corp. | | environment (e <sup>2</sup> studio) | | | Assembler (e <sup>2</sup> studio) | CC-RL V1.01.00 from Renesas Electronics Corp. | | Integrated development | IAR Embedded Workbench for Renesas RL78 V4.21.3 from IAR Systems. | | environment (IAR) | | | Assembler (IAR) | IAR Assembler for Renesas RL78 V4.21.2.2420 from IAR Systems. | | Board used | RL78/G12 target board (QB-R5F1026A-TB) + SW and LED | ## 3. Description of the Hardware # 3.1 Hardware Configuration Example The example of configuration of the hardware that is used for this application note is shown below. Figure 3.1 Hardware Configuration - Notes 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 characteristics conditions are met (connect the input-dedicated ports separately to V<sub>DD</sub> or V<sub>SS</sub> via a resistor). - 2. V<sub>DD</sub> must be held at not lower than the LVD detection voltage (V<sub>LVD</sub>) that is specified as LVD. #### 3.2 List of Pins to be used Table 3.1 lists the pins to be used and their functions. Table 3.1 Pins to be Used and Their Functions | Pin Name | I/O | Description | |----------|--------|-------------------------| | P10 | Input | Switch input (SW1) port | | P11 | Input | Switch input (SW2) port | | P12 | Output | LED (LED0) control port | | P13 | Output | LED (LED1) control port | | P14 | Output | LED (LED2) control port | ## 4. Description of the Software #### 4.1 Operation Outline The sample program described in this application note initializes the CPU (e.g., selecting the CPU clock frequency) and sets up its I/O ports. After completing the hardware setup, the sample program controls the On/Off of three LEDs (LED0 to LED2) according to the combination of states of two switch inputs (SW1 and SW2). - 1. CPU initialization Note1 - Sets up the peripheral I/O redirection function. - Sets up the I/O ports. - Sets up the CPU clock. Note 1. The option bytes are referenced before the CPU is initialized. #### <Setup conditions> - Sets the reset value because the CPU does not use the peripheral I/O redirection function (PIOR register). - Makes the following configurations for the I/O ports: - 1. Configures the ports that are configured for analog input after the release of the reset state for digital I/O (ADPC register and port mode control registers). - 2. Configures P10 and P11 which are used as switch inputs (SW1 and SW2) for input and the other ports for output (port mode register). - 3. Connects on-chip pull-up resistors to P10 and P11 which are to be used as switch inputs (SW1 and SW2) (pull-up resistor option register). - 4. Sets P12 to P14 which are used for On/Off control of LEDs (LED0 to LED2) to 1 and the other unused pins to 0 (port register). - Sets up the CPU clock. - 1. Sets the reset value because the high-speed system clock is not to be in use (clock operation mode control (CMC) register and clock operation status control (CSC) register). - 2. Selects the HOCO (f<sub>IH</sub>) as the CPU/peripheral hardware clock (f<sub>CLK</sub>) (system clock control (CKC) register). - 2. Executes the main processing. - Performs the LED output control as summarized in table 4.1 according to the state of the switch inputs (SW1 and SW2). Table 4.1 Main Processing | Switch Input States | | LED Output | | | |---------------------|-----------|------------|------------|------------| | SW1 (P10) | SW2 (P11) | LED0 (P12) | LED1 (P13) | LED2 (P14) | | Off | Off | Off | Off | Off | | On | Off | On | Off | Off | | Off | On | Off | On | Off | | On | On | Off | Off | On | Note: Refer to RL78/G12 User's Manual Manual for notes on device use. # 4.2 List of Option Byte Settings Table 4.2 summarizes the settings of the option bytes. **Table 4.2 Option Byte Settings** | Address | Value | Description | |---------|-----------|--------------------------------------------------------| | 000C0H | 01101110B | Stops the watchdog timer operation. | | | | (Stops counting after the release of the reset state.) | | 000C1H | 01111111B | LVD reset mode 2.81 V (2.76 V to 2.87 V) | | 000C2H | 11100000B | HS mode, HOCO: 24 MHz | | 000C3H | 10000101B | Enables the on-chip debugging function. | # 4.3 List of Functions (Subroutine) Table 4.3 lists the functions that are used by this sample program. **Table 4.3 Functions (Subroutine)** | Function (Subroutine) Name | Outline | |----------------------------|------------------------------------------------------------| | RESET_START | Initializes the hardware settings and calls main function. | | SINIPORT | Initializes the I/O ports. | | SINICLK | Initializes the clock generator. | | main | Main function | ## 4.4 Function (Subroutine) Specifications This section describes the specifications for the functions that are used in the sample code. [Function Name] RESET\_START Synopsis Initialize CPU at reset start. Declaration - Explanation Sets the stack pointer and, after making initial hardware settings, calls the main processing routine. Arguments None Return value None Remarks None [Function Name] SINIPORT Synopsis Set I/O ports. Declaration — Explanation Sets P10 and P11 as input points (internal pull-up resistor enabled) and P12, P13, and P14 as output ports (high-level output). Sets all other I/O ports, except P40, as output ports (low-level output). Arguments None Return value None Remarks None [Function Name] SINICLK Synopsis Set clock generator circuit. Declaration — Explanation Initializes the registers related to the clock generator. Arguments None Return value None Remarks None [Function Name] main Synopsis Main function Declaration - Explanation The main processing function of the sample code. Outputs the following values to P1 according to the values of SW1 (P10) and SW2 (P11): SW2 : SW1 : PORT1 0 : 0 : 00001100B 0 : 1 : 00010100B 1 : 0 : 00011000B 1 : 1 : 00011100B Arguments None Return value None Remarks #### 4.5 Flowcharts Figure 4.1 shows the overall flow of the sample program described in this application note. Figure 4.1 Overall Flow #### **Option Byte Configuration Outline** The option bytes of the RL78/G12 are made up of user option bytes (000C0H-000C2H) and on-chip debugging option bytes (000C3H). The option bytes are automatically referred and the prespecified functions are set up when power is first supplied or after the release of the reset state. The option bytes cannot be set up by any user program. The option bytes can exercise the controls listed below. The settings of the option bytes are contained in the file opt.asm. - · User option bytes - Makes settings related to the watchdog timer (000C0H). - Makes LVD-related and RESET pin function settings (000C1H). - Sets up the HOCO and flash memory operation mode (000C2H). - On-chip debugging option bytes (000C3H) The option byte settings can be specified through "User Option Byte Values" in the "Device" panel of the "Link Option" tag in CS+. Settings made via the "Link Option" tag take precedence over settings specified in software programs. Therefore, "Set user option bytes" should be set to "No," as shown below. Note: For details on the procedure for setting up the CS+ link options, refer to the CS+ tutorial. # (1) 000C0H (Watchdog Timer Related Settings) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|--------|---------|---------|-------|-------|-------|-------|----------| | ĺ | WDTINT | WINDOW1 | WINDOW0 | WDTON | WDCS2 | WDCS1 | WDCS0 | WDSTBYON | | ĺ | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | ## Bit 0 | WDSTBYON | Control of Watchdog Timer Counter (HALT/STOP mode) | |----------|----------------------------------------------------| | 0 | Disables counter operation in HALT/STOP mode. | | 1 | Enables counter operation in HALT/STOP mode. | ## Bits 3 to 1 | WDCS2 to WDCS0 | Watchdog Timer Overflow Time | |----------------|----------------------------------| | 000 | 2 <sup>6</sup> /f <sub>IL</sub> | | 001 | 2 <sup>7</sup> /f <sub>IL</sub> | | 020 | 2 <sup>8</sup> /f <sub>IL</sub> | | 011 | 2 <sup>9</sup> /f <sub>IL</sub> | | 100 | 2 <sup>11</sup> /f <sub>IL</sub> | | 101 | 2 <sup>13</sup> /f <sub>IL</sub> | | 110 | 2 <sup>14</sup> /f <sub>IL</sub> | | 111 | 2 <sup>16</sup> /f <sub>IL</sub> | #### Bit 4 | WDTON | Control of Watchdog Timer Counter | | |-------|----------------------------------------------------------------------------------|--| | 0 | Disables counter operation. (Stops counter after the release of reset sequence.) | | | 1 | Enables counter operation. (Starts counter after the release of reset sequence.) | | ## Bits 6 and 5 | WINDOW1 and WINDOW0 | Watchdog Timer Window Open Period | |---------------------|-----------------------------------| | 00 | Setting prohibited | | 01 | 50% | | 10 | 75% | | 11 | 100% | #### Bit 7 | WDTINT | Use of Interval Interrupts of watchdog timer | |--------|----------------------------------------------------------------------------| | 0 | Interval interrupt is not used. | | 1 | An interval interrupt is generated when 75%+1/2f <sub>IL</sub> is reached. | June. 24, 2022 # (2) 000C1H (LVD-Related Settings) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|----------|-------|-------|---------|---------| | VPOC2 | VPOC1 | VPOC0 | PORTSELB | LVIS1 | LVIS0 | LVIMDS1 | LVIMDS0 | | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | # When Used as Interrupt and Reset Mode | Detection Voltage | | | Option By | Option Byte Setting Value | | | | | | | |-------------------|--------------|--------------|-------------|---------------------------|-------|-------|-------|-------|-------|--| | $V_{LVDH}$ | | $V_{LVDL}$ | | | | | | | | | | Rising edge | Falling edge | Falling edge | LVIMDS1 | LVIMDS0 | VPOC2 | VPOC1 | VPOC0 | LVIS1 | LVIS0 | | | 1.98 V | 1.94 V | 1.84 V | 1 | 0 | 0 | 0 | 1 | 1 | 0 | | | 2.09 V | 2.04 V | | | | | | | 0 | 1 | | | 3.13 V | 3.06 V | | | | | | | 0 | 0 | | | 2.61 V | 2.55 V | 2.45 V | | | 0 | 1 | 0 | 1 | 0 | | | 2.71 V | 2.65 V | | | | | | | 0 | 1 | | | 3.75 V | 3.67 V | | | | | | | 0 | 0 | | | 2.92 V | 2.86 V | 2.75 V | | | 0 | 1 | 1 | 1 | 0 | | | 3.02 V | 2.96 V | | | | | | | 0 | 1 | | | 4.06 V | 3.98 V | | | | | | | 0 | 0 | | | Other than | n above | | Setting pro | hibited | | | | | | | ## When Used as Reset Mode | Detection Voltage | | Option By | te Setting V | alue | | | | | | | | |-------------------|--------------|-------------|--------------|--------------------|-------|-------|-------|-------|--|--|--| | \ | $V_{LVD}$ | | | | | | | | | | | | Rising edge | Falling edge | LVIMDS1 | LVIMDS0 | VPOC2 | VPOC1 | VPOC0 | LVIS1 | LVIS0 | | | | | 1.88 V | 1.84 V | 1 | 1 | 0 | 0 | 1 | 1 | 1 | | | | | 1.98 V | 1.94 V | | | 0 | 0 | 1 | 1 | 0 | | | | | 2.09 V | 2.04 V | | | 0 | 0 | 1 | 0 | 1 | | | | | 2.50 V | 2.45 V | | | 0 | 1 | 0 | 1 | 1 | | | | | 2.61 V | 2.55 V | | | 0 | 1 | 0 | 1 | 0 | | | | | 2.71 V | 2.65 V | | | 0 | 1 | 0 | 0 | 1 | | | | | 2.81 V | 2.75 V | | | 0 | 1 | 1 | 1 | 1 | | | | | 2.92 V | 2.86 V | | | 0 | 1 | 1 | 1 | 0 | | | | | 3.02 V | 2.96 V | | | 0 | 1 | 1 | 0 | 1 | | | | | 3.13 V | 3.06 V | | | 0 | 0 | 1 | 0 | 0 | | | | | 3.75 V | 3.67 V | | | 0 | 1 | 0 | 0 | 0 | | | | | 4.06 V | 3.98 V | | | 0 | 1 | 1 | 0 | 0 | | | | | Other than abo | ve | Setting pro | hibited | Setting prohibited | | | | | | | | # When Used as Interrupt Mode | Detection Voltage | | Option By | Option Byte Setting Value | | | | | | | | |-------------------|--------------|-------------|---------------------------|-------|-------|-------|-------|-------|--|--| | $V_{LVD}$ | | | | | | | | | | | | Rising edge | Falling edge | LVIMDS1 | LVIMDS0 | VPOC2 | VPOC1 | VPOC0 | LVIS1 | LVIS0 | | | | 1.88 V | 1.84 V | 0 | 1 | 0 | 0 | 1 | 1 | 1 | | | | 1.98 V | 1.94 V | 1 | | 0 | 0 | 1 | 1 | 0 | | | | 2.09 V | 2.04 V | 1 | | 0 | 0 | 1 | 0 | 1 | | | | 2.50 V | 2.45 V | | | 0 | 1 | 0 | 1 | 1 | | | | 2.61V | 2.55 V | 1 | | 0 | 1 | 0 | 1 | 0 | | | | 2.71 V | 2.65 V | | | 0 | 1 | 0 | 0 | 1 | | | | 2.81 V | 2.75 V | 1 | | 0 | 1 | 1 | 1 | 1 | | | | 2.92 V | 2.86 V | 1 | | 0 | 1 | 1 | 1 | 0 | | | | 3.02 V | 2.96 V | | | 0 | 1 | 1 | 0 | 1 | | | | 3.13 V | 3.06 V | | | 0 | 0 | 1 | 0 | 0 | | | | 3.75 V | 3.67 V | | | 0 | 1 | 0 | 0 | 0 | | | | 4.06 V | 3.98 V | | | 0 | 1 | 1 | 0 | 0 | | | | Other than abov | е | Setting pro | hibited | • | • | • | • | • | | | #### When LVD Is Off | Detection Voltage | | Option Byte Setting Value | | | | | | | |-------------------|--------------|---------------------------|--------------------|-------|-------|-------|-------|-------| | $V_{LVD}$ | | | | | | | | | | Rising edge | Falling edge | LVIMDS1 | LVIMDS0 | VPOC2 | VPOC1 | VPOC0 | LVIS1 | LVIS0 | | | | × | 1 | 1 | × | X | × | × | | Other than above | | Setting pro | Setting prohibited | | | | | | Remarks: x = don't care | 1 | RESET input (PU125 = 1, internal pull-up resistor enabled) | |----------|------------------------------------------------------------| | 0 | Port function (P125/KR1/SI01) | | PORTSELB | P125/RESET pin control | # (3) 000C2H (HOCO and Flash Memory Operation Settings) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|---|---|---------|---------|---------|---------| | CMODE1 | CMODE0 | 1 | 0 | FRQSEL3 | FRQSEL2 | FRQSEL1 | FRQSEL0 | | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | #### Bits 7 and 6 | | | Setting of Flash Memory Operating Mode | | | | | | |------------|-------------------------------------|----------------------------------------|---------------------------|-------------------------|--|--|--| | CMODE1 | CMODE0 | | Operating Frequency Range | Operating Voltage Range | | | | | 1 | 0 | LV (low voltage main) mode | 1 MHz to 8 MHz | 1.8 V to 5.5 V | | | | | 1 | 1 | HS (high speed main) mode | 1 MHz to 16 MHz | 2.4 V to 5.5 V | | | | | | | | 1 MHz to 24 MHz | 2.7 V to 5.5 V | | | | | Other than | Other than above Setting prohibited | | | | | | | #### Bits 3 to 0 | FRQSEL3 | FRQSEL2 | FRQSEL1 | FRQSEL0 | HOCO Frequency | |----------------|---------|---------|---------|--------------------| | 0 | 0 | 0 | 0 | 24 MHz | | 1 | 0 | 0 | 1 | 16 MHz | | 0 | 0 | 0 | 1 | 12 MHz | | 1 | 0 | 1 | 0 | 8 MHz | | 1 | 0 | 1 | 1 | 4 MHz | | 1 | 1 | 0 | 1 | 1 MHz | | Other than abo | ove | | | Setting prohibited | # (4) 000C3H (On-Chip Debugging Option Bytes) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|---|---|---|---|---|---|---------| | OCDENSET | 0 | 0 | 0 | 0 | 1 | 0 | OCDERSD | | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | #### Bits 7 and 0 | | | security ID fails. | |----------|---------|------------------------------------------------------------------------------------------| | 1 | 1 | Enables operation but does not erase flash memory data when authentication of | | 1 | 0 | Enables operation and erases flash memory data when authentication of security ID fails. | | 0 | 1 | Setting prohibited | | 0 | 0 | Disables on-chip debugging. | | OCDENSET | OCDERSD | Control of On-chip Debugging Operation | R01AN2582EJ0210 Rev. 2.10 June. 24, 2022 ## 4.5.1 **CPU Initialization Function** Figure 4.2 shows a flowchart of the CPU initialization function. Figure 4.2 CPU Initialization Function # 4.5.2 Setting up the I/O Ports Figure 4.3 shows the flowchart for setting up the I/O ports. Figure 4.3 I/O Port Setup #### **Outline of I/O Port Setup** The RL78/G12 is equipped with digital I/O ports so that it can provide a variety of controls. The I/O ports serve multiple pin functions in addition to serving as digital I/O ports. The I/O ports are controlled by the registers listed below. They must be set up during the system initialization routine that is executed when power is first supplied or after the release of the reset state. Registers that are used to manipulate ports: - Port mode register (PMxx) - Port register (Pxx) - Pull-up resistor option register (PUxx) - Port input mode register (PIMx) - Port output mode register (POMx) - Port mode control register (PMCxx)Note1 - A/D port configuration register (ADPC)<sup>Note1</sup> Note 1. A register used to place port pins in digital I/O or analog input mode. Since the port pins are configured for analog input when a reset signal occurs, the pins that are to be used for digital I/O must always be set up with this register after the release of the reset state. For the sample program described in this application note, all port pins are configured for digital I/O. - Notes 1. Refer to RL78/G12 User's Manual Manual: Hardware for the procedure to set up registers to configure ports as alternate-function pins for peripheral functions. - 2. Provide proper treatment for unused pins so that their electrical specifications are observed. Connect each of any unused input-only ports to V<sub>DD</sub> or V<sub>SS</sub> via a resistor, independently. Given below is an example of manipulating ports that are used in this sample code. #### **Setting Up Ports for LEDs** • Port mode register 1 (PM1) P12: LED0 P13: LED1 P14: LED2 #### **Setting Up Ports for Switches** • Port mode register 1 (PM1) • Pull-up resistor option register 1 (PU1) P10: SW1 P11: SW2 Symbol: PM1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------------|----------------------|----------------------|------|------|------|------|------| | PM17 | PM16 | PM15 | PM14 | PM13 | PM12 | PM11 | PM10 | | 0/1 <sup>Note1</sup> | 0/1 <sup>Note1</sup> | 0/1 <sup>Note1</sup> | 0 | 0 | 0 | 1 | 1 | | PM1n | PM1n Pin I/O Mode Selection (n = 0 to 4) | |------|------------------------------------------| | 0 | Output mode (output buffer on) | | | | - Note 1. The setting differs depending on the product. These pins are not present on 20/24-pin products, so the setting is 1. On 30-pin products the setting is 0. - Notes 1. This sample code configures any unused ports for output to minimize the adverse influence of through current. - 2. For details on the procedure for setting up the registers, refer to RL78/G12 User's Manual: Hardware. Symbol: PU1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |------|------|------|------|------|------|------|------|---| | PU17 | PU16 | PU15 | PU14 | PU13 | PU12 | PU11 | PU10 | | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | l | | 1 | On-chip pull-up resistor connected. | |------|---------------------------------------------------| | 0 | On-chip pull-up resistor not connected. | | PU1n | Selection of On-Chip Pull-Up Resistor for P1n Pin | R01AN2582EJ0210 Rev. 2.10 June. 24, 2022 # 4.5.3 Clock Generator Circuit Settings Figure 4.4 shows a flowchart of the clock generator circuit settings. Figure 4.4 Clock Generator Circuit Settings #### **Outline of CPU Clock Setup** The RL78/G12 allows the user to select the system clock source from the high-speed on-chip oscillator (HOCO) and main system clock oscillator/external clock input. The system clock is controlled by the registers listed below. The CPU clock must be initialized during the system initialization routine that is executed when power is first supplied or after the release of the reset state. Registers that are used to initialize the clock generator: - Clock operation mode control register (CMC) - Clock operation status control register (CSC) - Operation speed mode control register (OSMC) - System clock control register (CKC) - High-speed on-chip oscillator frequency selection register (HOCODIV) - Peripheral enable register 0 (PER0) Given below is an example of setting up the clock generator for this sample code. #### **Setting Up the Clock Operating Mode** Clock operation mode control register (CMC) High-speed system clock pin's operating mode: Input port mode X1 clock oscillation frequency control: 1 MHz ≤ fx ≤ 10 MHz Symbol: CMC | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|--------|---|---|---|---|---|------| | EXCLK | OSCSEL | 0 | 0 | 0 | 0 | 0 | AMPH | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 0 | AMPH | Control of X1 Clock Oscillation Frequency | |------|-------------------------------------------| | 0 | 1 MHz ≤ fx ≤ 10 MHz | | 1 | 10 MHz < fx ≤ 20 MHz | #### Bit 7 and 6 | EXCLK | OSCSEL | High-speed System Clock Pin Operating Mode | X1/P121 Pin | X2/EXCLK/P122 Pin | | |-------|--------|--------------------------------------------|-----------------------------------------|----------------------|--| | 0 | 0 | Input port mode | Input port | | | | 0 | 1 | X1 oscillation mode | Connected to crystal/ceramic oscillator | | | | 1 | 0 | Input port mode | Input port | | | | 1 | 1 | External clock input mode Input port E | | External clock input | | Note: For details on the procedure for setting up the registers, refer to RL78/G12 User's Manual: Hardware. #### **Controlling Clock Operations** Clock operation status control register (CSC) High-speed system clock operation control: Stop X1 oscillator. HOCO clock operation control: HOCO operation Symbol: CSC | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|---|---|---|---|---|---|---------| | MSTOP | 1 | 0 | 0 | 0 | 0 | 0 | HIOSTOP | | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 0 | HIOSTOP | Control of HOCO Clock Operation | |---------|---------------------------------| | 0 | Runs HOCO. | | 1 | Stops HOCO. | #### Bit 7 | | Control of High-speed | | | |-------|-----------------------|---------------------------------------------|-----------------| | MSTOP | X1 Oscillation Mode | External Clock Input Mode | Input Port Mode | | 0 | Runs X1 oscillator. | Enables external clock from the EXCLKS pin. | Input port | | 1 | Stops X1 oscillator. | Disables external clock from the EXCLK pin. | | Note: For details on the procedure for setting up the registers, refer to RL78/G12 User's Manual: Hardware. #### Setting Up the CPU/Peripheral Hardware Clock (fclk) • System clock control register (CKC) $f_{CLK}$ status: Main system clock $f_{CLK}$ selection: HOCO clock $(f_{IH})$ Symbol: CKC | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-----|------|---|---|---|---| | 0 | 0 | MCS | MCM0 | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 4 | MCM0 | Control of Main System Clock (f <sub>MAIN</sub> ) Operation | | | | | |------|---------------------------------------------------------------------------------------------------|--|--|--|--| | 0 | Selects HOCO clock (f <sub>IH</sub> ) as the main system cock (f <sub>MAIN</sub> ). | | | | | | 1 | Selects high-speed system clock (f <sub>MX</sub> ) as the main system clock (f <sub>MAIN</sub> ). | | | | | #### Bit 5 | MCS | Main system clock (f <sub>MAIN</sub> ) state | | | | |-----|----------------------------------------------|--|--|--| | 0 | HOCO clock (f <sub>IH</sub> ) | | | | | 1 | High-speed system clock (f <sub>MX</sub> ) | | | | Note: For details on the procedure for setting up the registers, refer to RL78/G12 User's Manual: Hardware. ## **Setting Use/Disuse of Peripheral Hardware Macros** Peripheral enable register 0 (PER0) Hardware input clock control: Stop input clocks. Symbol: PER0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|-------|---------|-------------|--------|---|--------| | TMKAEN | 0 | ADCEN | IICA0EN | SAU1ENNote1 | SAU0EN | 0 | TAU0EN | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 0 | TAU0EN | Control of Timer Array Unit 0 Input Clock Supply | | | | |--------|---------------------------------------------------------|--|--|--| | 0 | Stops input clock supply. | | | | | | SFR used by timer array unit 0 cannot be written. | | | | | | Timer array unit 0 is in the reset status. | | | | | 1 | Enables input clock supply. | | | | | | SFR used by timer array unit 0 can be read and written. | | | | #### Bit 3 and 2 | SAUmEN | Control of Serial Array Unit m Input Clock Supply | | | | |--------|----------------------------------------------------------|--|--|--| | 0 | Stops input clock supply. | | | | | | SFR used by serial array unit m cannot be written. | | | | | | Serial array unit m is in the reset status. | | | | | 1 | Enables input clock supply. | | | | | | SFR used by serial array unit m can be read and written. | | | | RENESAS June. 24, 2022 #### Bit 4 | IICA0EN | Control of Serial Interface IICA0 Input Clock Supply | | | | |---------|-----------------------------------------------------------------|--|--|--| | 0 | Stops input clock supply. | | | | | | SFR used by the serial interface IICA0 cannot be written. | | | | | | Serial interface IICA0 is in the reset state. | | | | | 1 | Enables input clock supply. | | | | | | SFR used by the serial interface IICA0 can be read and written. | | | | #### Bit 5 | ADCEN | Control of A/D Converter Input Clock Supply | | | | |-------|----------------------------------------------------------------------------|--|--|--| | 0 | Stops input clock supply. | | | | | | SFR used by the A/D converter cannot be written. | | | | | | A/D converter is in the reset status. | | | | | 1 | Enables input clock supply. | | | | | | <ul> <li>SFR used by the A/D converter can be read and written.</li> </ul> | | | | #### Bit 7 | TMKAEN | Control of 12-Bit Interval Timer Input Clock Supply | | | | |--------|------------------------------------------------------------------------------------|--|--|--| | 0 | Stops input clock supply. | | | | | | SFR used by the 12-bit interval timer cannot be written. | | | | | | The 12-bit interval timer is in the reset status. | | | | | 1 | Enables input clock supply. | | | | | | <ul> <li>SFR used by the 12-bit interval timer can be read and written.</li> </ul> | | | | Note 1. For 30-pin products only. Note: Power saving and noise reduction are achieved by stopping the supply of clocks to any unused hardware macros. #### **Controlling the Operation Speed Mode** Operation speed mode control register (OSMC) Selection of interval timer operation clock: Clock supply stopped Symbol: OSMC | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|----------|---|---|---|---| | 0 | 0 | 0 | WUTMMCK0 | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 4 | WUTMMCK0 | Selection of Operation Clock for Realtime Clock and Interval Timer | |----------|--------------------------------------------------------------------| | 0 | Clock supply stopped. | | 1 | Enables LOCO Clock (f <sub>IL</sub> ) supply. | Note: The OSMC register is designed to reduce the operating current in STOP mode and thereby lower power consumption. For details on the procedure for setting up the registers, refer to RL78/G12 User's Manual: Hardware. # 4.5.4 Main Processing Figure 4.5 shows the flowchart for the main processing routine. Figure 4.5 Main Processing ## 5. Selecting/Changing the Target Device #### 5.1 Selecting the Target Device Depending on the pin count, the number of available pins differs. To accommodate this difference, the CPU initialization function of the sample program includes a file (r\_init.asm) that uses the assembler control instructions \$IF ... \$ENDIF to allow selection of the instructions appropriate to each product. The name of the product to be used is defined as shown below. For example, when using the 20-pin product without data flash memory, only R5F1026 should be preceded by (.set 1) and the other product names preceded by (.set 0) ``` R5F1026 .set 1 ; 20 pins with data flash memory ← This is the product to be used. R5F1036 .set 0 ; 20 pins without data flash memory R5F1027 .set 0 ; 24 pins with data flash memory R5F1037 .set 0 ; 24 pins without data flash memory R5F102A .set 0 ; 30 pins with data flash memory R5F103A .set 0 ; 30 pins without data flash memory ``` Figure 5.1 Specifying the Product to Be Used When the product version is defined in this way, among the P1-related settings (which differ depending on the product) only those for which the \$IF control instruction contains R5F1026 are true, and the subsequent lines up to \$ENDIF or \$ELSEIF are processed by the assembler. Figure 5.2 Program Example Note: **LIST/NOLIST** control instructions have been added so that device settings for other than the specified product version are not output to the assemble list file. This means that unnecessary information, including the \$IF control instructions, etc., are not visible. However, \$LIST/\$NOLIST is output. ## 5.2 Changing the Target Device To change the target device used with the sample program it is necessary to create a new project. The sample project should be used as the basis when doing this. Figure 5.3 Example of Creating a New Project in Order to Change the Target Device ## 6. Notes on Using the Sample Code The sample code is written entirely in assembly language. This means that the code generation function of CS+ cannot be used. As a consequence, care must be exercised with regard to certain settings. ## 6.1 CS+ Settings Since the sample code is written entirely in assembly language, some functions of CS+ must be disabled. • Set the link options in the CC-RL properties as shown below. If this setting is not made, the watchdog timer may reset the device at regular intervals. This will cause the following warning (W0403029 and W0403023) to appear in the output messages during code generation, but the warning can be ignored. Assemble Option Settings The setting shown below is recommended but not required. It enables output lists that addresses are determined after linking. Open the "Assemble List" settings and change the setting of the second item, "Output assemble list file," to "Yes." #### 6.2 **Debug Tool Settings** The sample code can be used to check the operation of the device simply by adding two switches and one LED to the RL78/G12 target board (QB-R5F1026A-TB). Power can be supplied to the target board from the emulator. This makes it possible to use a simple circuit to perform debugging. The necessary settings are as follows: - Open the RL78 E1 (Serial) (Debug Tool) properties. (1) - Under "Connection to target board," set "Supply power from emulator" to "Yes" and set the voltage to (2) "5.0 V." ## 7. Sample Code The sample code is available on the Renesas Electronics Website. #### 8. Documents for Reference RL78/G12 User's Manual Manual: Hardware (R01UH0200E) 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.) All trademarks and registered trademarks are the property of their respective owners. # **Revision History** | | | Description | | | |------|----------------|-------------|-------------------------------------------------|--| | Rev. | Date | Page | Summary | | | 1.00 | Mar. 20, 2015 | _ | First edition issued | | | 2.00 | Nov. 11, 2015 | 3 | Table 2.1: Added e <sup>2</sup> studio | | | | | 3 | Table 2.1:Change the version information of CS+ | | | 2.10 | June. 24. 2022 | 3 | Operation check condition is updated. | | # General Precautions in the Handling of Microprocessing Unit and Microcontroller Unit Products The following usage notes are applicable to all Microprocessing unit and Microcontroller unit products from Renesas. For detailed usage notes on the products covered by this document, refer to the relevant sections of the document as well as any technical updates that have been issued for the products. 1. Precaution against Electrostatic Discharge (ESD) A strong electrical field, when exposed to a CMOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop the generation of static electricity as much as possible, and quickly dissipate it when it occurs. Environmental control must be adequate. When it is dry, a humidifier should be used. This is recommended to avoid using insulators that can easily build up static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work benches and floors must be grounded. The operator must also be grounded using a wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions must be taken for printed circuit boards with mounted semiconductor devices. 2. Processing at power-on The state of the product is undefined at the time 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 time 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 time 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 time when power is supplied until the power reaches the level at which resetting is specified. - 3. Input of signal during power-off state - Do not input signals or an I/O pull-up power supply while the device is powered off. The current injection that results from input of such a signal or I/O pull-up power supply may cause malfunction and the abnormal current that passes in the device at this time may cause degradation of internal elements. Follow the guideline for input signal during power-off state as described in your product documentation. - 4. Handling of unused pins Handle unused pins in accordance with the directions given under handling of unused pins in the manual. The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of the 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. 5. Clock signals After applying a reset, only release the reset line after the operating clock signal becomes stable. When switching the clock signal during program execution, wait until the target clock signal is 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. Additionally, 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. - Voltage application waveform at input pin - Waveform distortion due to input noise or a reflected wave may cause malfunction. If the input of the CMOS device stays in the area between $V_{IL}$ (Max.) and $V_{IH}$ (Min.) due to noise, for example, the device may malfunction. Take care to prevent chattering noise from entering the device when the input level is fixed, and also in the transition period when the input level passes through the area between $V_{IL}$ (Max.) and $V_{IH}$ (Min.). - 7. Prohibition of access to reserved addresses Access to reserved addresses is prohibited. The reserved addresses are provided for possible future expansion of functions. Do not access these addresses as the correct operation of the LSI is not guaranteed. 8. Differences between products Before changing from one product to another, for example to a product with a different part number, confirm that the change will not lead to problems. The characteristics of a microprocessing unit or microcontroller unit products in the same group but having a different part number might differ in terms of internal memory capacity, layout pattern, and other factors, which can affect the ranges of electrical characteristics, such as characteristic values, operating margins, immunity to noise, and amount of radiated noise. When changing to a product with a different part number, implement a system-evaluation test for the given product. #### **Notice** - 1. 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 or any other use of the circuits, software, and information in the design of your product or system. Renesas Electronics disclaims any and all liability for any losses and damages incurred by you or third parties arising from the use of these circuits, software, or information. - 2. Renesas Electronics hereby expressly disclaims any warranties against and liability for infringement or any other claims involving patents, copyrights, or other intellectual property rights of third parties, by or arising from the use of Renesas Electronics products or technical information described in this document, including but not limited to, the product data, drawings, charts, programs, algorithms, and application examples. - 3. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others - 4. You shall be responsible for determining what licenses are required from any third parties, and obtaining such licenses for the lawful import, export, manufacture, sales, utilization, distribution or other disposal of any products incorporating Renesas Electronics products, if required. - 5. You shall not alter, modify, copy, or reverse engineer any Renesas Electronics product, whether in whole or in part. Renesas Electronics disclaims any and all liability for any losses or damages incurred by you or third parties arising from such alteration, modification, copying or reverse engineering. - 6. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The intended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; industrial robots; etc. - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control (traffic lights); large-scale communication equipment; key financial terminal systems; safety control equipment; etc. Unless expressly designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not intended or authorized for use in products or systems that may pose a direct threat to human life or bodily injury (artificial life support devices or systems; surgical implantations; etc.), or may cause serious property damage (space system; undersea repeaters; nuclear power control systems; aircraft control systems; key plant systems; military equipment; etc.). Renesas Electronics disclaims any and all liability for any damages or losses incurred by you or any third parties arising from the use of any Renesas Electronics product that is inconsistent with any Renesas Electronics data sheet, user's manual or other Renesas Electronics document. - 7. No semiconductor product is absolutely secure. Notwithstanding any security measures or features that may be implemented in Renesas Electronics hardware or software products, Renesas Electronics shall have absolutely no liability arising out of any vulnerability or security breach, including but not limited to any unauthorized access to or use of a Renesas Electronics product or a system that uses a Renesas Electronics product. RENESAS ELECTRONICS DOES NOT WARRANT OR GUARANTEE THAT RENESAS ELECTRONICS PRODUCTS, OR ANY SYSTEMS CREATED USING RENESAS ELECTRONICS PRODUCTS WILL BE INVULNERABLE OR FREE FROM CORRUPTION, ATTACK, VIRUSES, INTERFERENCE, HACKING, DATA LOSS OR THEFT, OR OTHER SECURITY INTRUSION ("Vulnerability Issues"). RENESAS ELECTRONICS DISCLAIMS ANY AND ALL RESPONSIBILITY OR LIABILITY ARISING FROM OR RELATED TO ANY VULNERABILITY ISSUES. FURTHERMORE, TO THE EXTENT PERMITTED BY APPLICABLE LAW, RENESAS ELECTRONICS DISCLAIMS ANY AND ALL WARRANTIES, EXPRESS OR IMPLIED, WITH RESPECT TO THIS DOCUMENT AND ANY RELATED OR ACCOMPANYING SOFTWARE OR HARDWARE, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE. - 8. When using Renesas Electronics products, refer to the latest product information (data sheets, user's manuals, application notes, "General Notes for Handling and Using Semiconductor Devices" in the reliability handbook, etc.), and ensure that usage conditions are within the ranges specified by Renesas Electronics with respect to maximum ratings, operating power supply voltage range, heat dissipation characteristics, installation, etc. Renesas Electronics disclaims any and all liability for any malfunctions, failure or accident arising out of the use of Renesas Electronics products outside of such specified ranges. - 9. Although Renesas Electronics endeavors to improve the quality and reliability of Renesas Electronics products, semiconductor products have specific characteristics, such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Unless designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not subject to radiation resistance design. You are responsible for implementing safety measures to guard against the possibility of bodily injury or damage caused by fire, and/or danger to the public in the event of a failure or malfunction of Renesas Electronics products, such as safety design for hardware and software, including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult and impractical, you are responsible for evaluating the safety of the final products or systems manufactured by you. - 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. You are responsible for carefully and sufficiently investigating applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive, and using Renesas Electronics products in compliance with all these applicable laws and regulations. Renesas Electronics disclaims any and all liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations. - 11. Renesas Electronics products and technologies shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You shall comply with any applicable export control laws and regulations promulgated and administered by the governments of any countries asserting jurisdiction over the parties or transactions. - 12. It is the responsibility of the buyer or distributor of Renesas Electronics products, or any other party who distributes, disposes of, or otherwise sells or transfers the product to a third party, to notify such third party in advance of the contents and conditions set forth in this document. - 13. This document shall not be reprinted, reproduced or duplicated in any form, in whole or in part, without prior written consent of Renesas Electronics. - 14. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products. - (Note1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its directly or indirectly controlled subsidiaries. - (Note2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics. (Rev.5.0-1 October 2020) #### **Corporate Headquarters** TOYOSU FORESIA, 3-2-24 Toyosu, Koto-ku, Tokyo 135-0061, Japan www.renesas.com #### **Trademarks** Renesas and the Renesas logo are trademarks of Renesas Electronics Corporation. All trademarks and registered trademarks are the property of their respective owners. #### Contact information For further information on a product, technology, the most up-to-date version of a document, or your nearest sales office, please visit: www.renesas.com/contact/.