Renesas Network Card RJJ10J1643 0101 User Guide

REJ10J1502-0101  
Renesas Embedded  
Application Programming Interface  
Reference manual  
Rev.1.01  
Feb 16, 2007  
www.renesas.com  
 
Description of third argument in __CreateInputCapture corrected  
Wording “specified” unified to “specified”  
RAPI_BOTH deleted from the description of timer B1 count edges of H8/300H in  
__CreateEventCounter  
RAPI_FTIOA and RAPI_FTIOB added to __CreatePulsePeriodMeasurementMode and  
__CreatePulseWidthMeasurementMode  
All occurrences of the word “Tiny” deleted  
Description of second argument added to __GetPulsePeriodMeasurementMode,  
__GetPulseWidthMeasurementMode, and __GetEventCounter  
Description regarding timer V trigger of H8 in __CreateTimer, __CreateEventCounter,  
and __CreatePulseWidthMeasurementMode corrected  
Explanation of H8 interrupt settings and interrupt control register settings in  
__SetSerialInterrupt corrected  
Remarks on timer V of H8/300H in __EnableTimerRegister added  
Specification of timer RA input pins of R8C in __CreatePulsePeriodMeasurementMode  
and __CreatePulseWidthMeasurementMode as well as RAPI_TIOSEL_P1_7 and  
RAPI_TIOSEL_P1_5 added  
File name in program example corrected  
Item “Reference” in __BasicSetSerialFormat deleted  
__BasicSetSerialFormat added to “Reference” in __SetSerialFormat and  
__SetSerialInterrupt  
Error in writing of __CreateInput Capture and __CreateOutputCapture corrected  
Explanation added to Section 2.1, “Overview”  
Causes of clearing of timer W and timer RC counters in __CreateInputCapture deleted  
RAPI_COMPARE_MATCH_A_STOP and RAPI_STOP added to the item for the R8C in  
__CreateOutputCompare  
Changed to RAPI_INT_LV_0 and RAPI_INT_LV_1 for H8/300H in __SetSerialInterrupt  
Description relating to clock in __CreateTimer corrected  
RAPI_TRC_FILTER and RAPI_TRD_FILTER added to filter specification for H8 in  
__CreatePulsePeriodMeasurementMode and __CreatePulseWidthMeasurementMode  
RAPI_TIMER_RD2 and RAPI_TIMER_RD3 added to timer RD of H8/36109  
Description relating to timer V trigger input for H8/300H in __CreateTimer deleted  
Description of pulse output function added to the item for R8C in  
__CreateEventCounter  
Description of timer RE usage added to items data3 and data5 for R8C in  
__CreateOutputCompare  
Filter function of timer RC and timer RD in __CreatePulsePeriodMeasurementMode,  
__CreatePulseWidthMeasurementMode, and __CreateInputCapture corrected  
Description that multiple defined values can be set for data1 in __EnableInterrupt  
added  
Description that RAPI_WITHOUT_SAMPLE_HOLD is specifiable in delay trigger  
modes 0 and 1 of M16C in __CreateADC corrected  
Description that RAPI_FOCOF is specifiable in repeat mode of R8C in __CreateADC  
corrected  
Rev.1.01  
2007.02.16  
3
RJJ10J1643-0101  
 
RAPI_AN30, RAPI_AN31, RAPI_AN32, and RAPI_P9_GROUP added to the item for  
data1 of M16C in __CreateADC  
RAPI_AN30, RAPI_AN31, RAPI_AN32, and RAPI_P9_GROUP added to the item for  
data1 of M16C in __EnableADC  
Error in writing of H8/300H interrupt set values in __CreateOutputCompare corrected  
Error in writing of timer RD and timer RD symbol name corrected  
Description of gate function of M16C in __CreateEventCounter deleted  
Description of H8/300H noise rejection function in __BasicSetSerialFormat added  
Description  
of  
timer  
W
input  
pins  
of  
H8/300H  
in  
__CreatePulsePeriodMeasurementMode and __CreatePulseWidthMeasurementMode  
deleted  
Rev.1.01  
2007.02.16  
4
RJJ10J1643-0101  
 
Table of Contents  
Table of Contents ................................................................ 5  
1. Introduction................................................................... 8  
2. Driver ....................................................................... 9  
2.1 Overview.................................................................. 9  
2.2 Driver Features ............................................................ 10  
2.3 Serial Interface Driver....................................................... 11  
2.4 Timer Driver .............................................................. 12  
2.4.1 Timer Mode ........................................................... 12  
2.4.2 Event Counter Mode .................................................... 12  
2.4.3 Pulse Width Modulation Mode (PWM Mode)................................. 12  
2.4.4 Pulse Period Measurement Mode .......................................... 12  
2.4.5 Pulse Width Measurement Mode ........................................... 12  
2.4.6 Input Capture Mode..................................................... 12  
2.4.7 Output Compare Mode .................................................. 13  
2.5 I/O Port Driver ............................................................ 14  
2.6 External Interrupt Driver..................................................... 15  
2.7 A/D Converter Driver ....................................................... 16  
3. Standard Types ...............................................................18  
4. Library Reference ............................................................. 19  
4.1 API List by Peripheral Facility ................................................ 19  
4.2 Description of Each API ..................................................... 21  
4.2.1 Serial I/O ............................................................. 22  
__BasicOpenSerialDriver ................................................... 22  
__BasicCloseSerialDriver................................................... 23  
__BasicSetSerialFormat .................................................... 24  
__BasicStartSerialReceiving................................................. 29  
__BasicStartSerialSending .................................................. 30  
__BasicReceivingStatusRead ................................................ 31  
__BasicSendingStatusRead.................................................. 33  
__BasicStopSerialReceiving................................................. 34  
__BasicStopSerialSending .................................................. 35  
__OpenSerialDriver ....................................................... 36  
__CloseSerialDriver ....................................................... 37  
__ConfigSerialDriverNotify ................................................. 38  
__SetSerialFormat......................................................... 41  
__SetSerialInterrupt ....................................................... 42  
__StartSerialReceiving ..................................................... 45  
__StartSerialSending....................................................... 47  
__StopSerialReceiving ..................................................... 49  
__StopSerialSending....................................................... 50  
__PollingSerialReceiving ................................................... 51  
__PollingSerialSending..................................................... 52  
4.2.2 Timer ................................................................ 54  
Rev.1.01  
2007.02.16  
5
RJJ10J1643-0101  
 
__CreateTimer ........................................................... 54  
__EnableTimer ........................................................... 60  
__DestroyTimer .......................................................... 62  
__CreateEventCounter ..................................................... 64  
__EnableEventCounter ..................................................... 69  
__DestroyEventCounter .................................................... 71  
__GetEventCounter........................................................ 73  
__CreatePulseWidthModulationMode ......................................... 75  
__EnablePulseWidthModulationMode......................................... 80  
__DestroyPulseWidthModulationMode ........................................ 82  
__CreatePulsePeriodMeasurementMode ....................................... 83  
__EnablePulsePeriodMeasurementMode ....................................... 88  
__DestroyPulsePeriodMeasurementMode ...................................... 90  
__GetPulsePeriodMeasurementMode.......................................... 92  
__CreatePulseWidthMeasurementMode........................................ 94  
__EnablePulseWidthMeasurementMode ....................................... 99  
__DestroyPulseWidthMeasurementMode ..................................... 101  
__GetPulseWidthMeasurementMode ......................................... 103  
__CreateInputCapture..................................................... 105  
__EnableInputCapture .................................................... 115  
__DestroyInputCapture.................................................... 117  
__GetInputCapture ....................................................... 119  
__CreateOutputCompare .................................................. 121  
__EnableOutputCompare .................................................. 133  
__DestroyOutputCompare ................................................. 135  
__SetTimerRegister ...................................................... 137  
__EnableTimerRegister.................................................... 143  
__ClearTimerRegister..................................................... 145  
__GetTimerRegister ...................................................... 147  
4.2.3 I/O Port ............................................................. 153  
__SetIOPort ............................................................ 153  
__ReadIOPort ........................................................... 158  
__WriteIOPort........................................................... 162  
__SetIOPortRegister ...................................................... 166  
__ReadIOPortRegister .................................................... 168  
__WriteIOPortRegister .................................................... 170  
4.2.4 External interrupt ...................................................... 172  
__SetInterrupt ........................................................... 172  
__EnableInterrupt ........................................................ 176  
__GetInterruptFlag ....................................................... 178  
__ClearInterruptFlag...................................................... 180  
4.2.5 A/D converter......................................................... 182  
__CreateADC ........................................................... 182  
__EnableADC........................................................... 191  
__DestroyADC .......................................................... 196  
Rev.1.01  
2007.02.16  
6
RJJ10J1643-0101  
 
__GetADC ............................................................. 197  
__GetADCAll ........................................................... 198  
__GetADCStatus......................................................... 199  
__ClearADCStatus ....................................................... 200  
Rev.1.01  
2007.02.16  
7
RJJ10J1643-0101  
 
1. Introduction  
The Renesas Embedded Application Programming Interface (API) is a unified API for  
the microcomputers made by Renesas Technology Corporation.  
Rev.1.01  
2007.02.16  
8
RJJ10J1643-0101  
 
2. Driver  
2.1 Overview  
The library described herein provides a peripheral facility control program (peripheral  
driver) for microcomputers. Use of the Renesas API permits the peripheral driver to be  
built into a user program.  
Configuration of Renesas APIs is shown below.  
File name  
rapi_xxx_yyy.lib  
Description  
This is the Renesas API library file. To use  
Renesas APIs, specify this file as input file  
for the linker.  
(xxx = family name, yyy = series name)  
rapi_ad_xxx_yyy.h  
This is the header file for A/D converter  
driver APIs. To use A/D converter driver  
APIs, be sure to include this file.  
This is the header file for I/O port driver  
APIs. To use I/O port driver APIs, be sure  
to include this file.  
(xxx = family name, yyy = series name)  
rapi_io_port_xxx_yyy.h  
(xxx = family name, yyy= series name)  
rapi_sif_xxx_yyy.h  
This is the header file for serial I/F driver  
APIs. To use serial I/F driver APIs, be sure  
to include this file.  
(xxx = family name, yyy= series name)  
rapi_timer_xxx_yyy.h  
This is the header file for timer driver  
APIs. To use timer driver APIs, be sure to  
include this file.  
(xxx = family name, yyy= series name)  
Interrupt_xxx_yyy.h  
This is the interrupt function source file for  
Renesas APIs. To use Renesas APIs that  
use interrupts, add this file to the user  
program.  
(xxx = family name, yyy= series name)  
rapi_io_xxx_yyy.h  
This is the CPU control register definition  
header file for Renesas APIs.  
(xxx = family name, yyy= series name)  
Rev.1.01  
2007.02.16  
9
RJJ10J1643-0101  
 
2.2 Driver Features  
The library described herein has the following features available as a peripheral driver.  
(1) Serial I/O control feature  
It comprises a serial interface driver, which sets or clears the conditions of serial  
communication, as well as controls and manages the transmission/reception of  
communication data.  
(2) Timer control feature  
It comprises a timer driver, which sets or clears the operating conditions of timers,  
as well as controls the timer operation.  
(3) I/O port control feature  
It comprises an I/O port driver, which sets or clears the usage conditions of I/O ports, as  
well as control data read/write operation.  
(4) External interrupt control feature  
It comprises an external interrupt driver, which sets or clears the usage conditions of  
external interrupts, as well as controls interrupt operation.  
(5) A/D converter control feature  
It comprises an A/D converter driver, which sets or clears the usage conditions of A/D  
converters, as well as controls A/D converter operation.  
Rev.1.01  
2007.02.16  
10  
RJJ10J1643-0101  
 
2.3 Serial Interface Driver  
The serial interface driver sets serial communication, clears settings, transmit/receives  
data, and controls the status of serial communication.  
There are two kinds of serial interface driver: a single-data transmission/reception API  
and a multi-data transmission/reception API.  
Rev.1.01  
2007.02.16  
11  
RJJ10J1643-0101  
 
2.4 Timer Driver  
The timer driver sets the timer, clears timer settings, controls timer operation, and  
acquires a counter value with respect to the following modes:  
Timer mode  
Event counter mode  
Pulse width modulation mode (PWM mode)  
Pulse period measurement mode  
Pulse width measurement mode  
Input capture mode  
Output compare mode  
2.4.1 Timer Mode  
In this mode, the timer counts the internally generated count source. When an  
underflow or an overflow interrupt occurs, it calls a preset callback function.  
2.4.2 Event Counter Mode  
In this mode, the timer counts the external signal fed in from an input pin or an  
overflow or underflow from other timer. When an underflow or an overflow interrupt  
occurs, it calls a preset callback function.  
2.4.3 Pulse Width Modulation Mode (PWM Mode)  
In this mode, the timer outputs pulses in a given width successively. When an  
underflow or an overflow interrupt occurs, it calls a preset callback function.  
2.4.4 Pulse Period Measurement Mode  
In this mode, the timer measures the pulse period of an external signal fed in from an  
input pin. When an underflow or an overflow interrupt occurs, it calls a preset callback  
function.  
2.4.5 Pulse Width Measurement Mode  
In this mode, the timer measures the pulse width of an external signal fed in from an  
input pin. When an underflow or an overflow interrupt occurs, it calls a preset callback  
function.  
2.4.6 Input Capture Mode  
In this mode, the timer latches the timer value upon an active signal edge or clock  
pulse at an input pin, thereby generating an interrupt request. When an input capture  
interrupt or an underflow or an overflow interrupt occurs, it calls a preset callback  
function.  
Rev.1.01  
2007.02.16  
12  
RJJ10J1643-0101  
 
2.4.7 Output Compare Mode  
In this mode, the timer generates an interrupt request when the timer counter and a  
comparison value match. When a compare match interrupt or an underflow or an  
overflow interrupt occurs, it calls a preset callback function.  
Rev.1.01  
2007.02.16  
13  
RJJ10J1643-0101  
 
2.5 I/O Port Driver  
The I/O port driver sets the I/O port for input or output, writes data to the I/O port, and  
reads data from the I/O port.  
Rev.1.01  
2007.02.16  
14  
RJJ10J1643-0101  
 
2.6 External Interrupt Driver  
The external interrupt driver sets external interrupts, controls external interrupts,  
acquires the status of external interrupt flags, and clears external interrupt flags.  
Rev.1.01  
2007.02.16  
15  
RJJ10J1643-0101  
 
2.7 A/D Converter Driver  
The A/D converter driver sets the A/D converter, controls the A/D converter, clears  
settings of the A/D converter, acquires the A/D converter value, acquires the status of the  
A/D converter, and clears the status of the A/D converter.  
[A/D converter driver usage example (single-shot mode)]  
Here, a program example is shown for the A/D converter operating in single-shot mode  
under the conditions given below.  
CPU  
:
:
:
:
:
:
R8C  
Operating clock  
Resolution  
fAD divided by 2  
10 bits  
Analog input pin  
A/D conversion start condition  
Sample-and-hold  
AN0 pin  
Software trigger  
Enabled  
A program flow and a program example are shown below.  
(Program flow)  
main()  
Set the A/D converter in  
__CreateADC()  
single-shot mode  
Start A/D conversion  
__EnableADC()  
__GetADCStatus()  
__GetADC()  
No  
A/D interrupt?  
Yes  
Read out the A/D conversion value  
Clear the A/D interrupt flag  
__ClearADCStatus()  
Rev.1.01  
2007.02.16  
16  
RJJ10J1643-0101  
 
Program example  
#include "rapi_ad_r8c_13.h"  
void main( void )  
{
unsigned int status, data;  
/* Set up A/D converter as one short mode */  
__CreateADC(  
RAPI_ONE_SHOT|RAPI_AN0|RAPI_FAD2|  
RAPI_WITH_SAMPLE_HOLD|  
RAPI_AD_OFF|RAPI_10BIT, 1, 0, 0 );  
while( 1 ){  
/* Disable A/D converter */  
__EnableADC( RAPI_AN0| RAPI_AD_ON, 1 );  
/* Check a flag bit of A/D converter interrupt */  
do{  
__GetADCStatus( &status );  
} while( (*status & 0x0001) == 0 )  
/* Get A/D convertered datas of A/D register */  
__GetADC( &data );  
/* Clear status of A/D convertered */  
__ClearADCStatus( 0 );  
}
}
Rev.1.01  
2007.02.16  
17  
RJJ10J1643-0101  
 
3. Standard Types  
This section describes the standard types defined in the library. For details about the  
set values, refer to the description of each API.  
Standard type  
Description  
Boolean  
The Boolean type represents the enum-type data that indicates  
whether successful (RAPI_TRUE (= 1)) or failed (RAPI_FALSE (=  
0)).  
VoidFuncNotify  
The VoidFuncNotify type represents the type of the notification  
function to be registered.  
Rev.1.01  
2007.02.16  
18  
RJJ10J1643-0101  
 
4. Library Reference  
4.1 API List by Peripheral Facility  
The table below lists the Renesas Embedded APIs classified by peripheral facility.  
NO  
Facility  
API  
API operation  
classification  
Opens serial port  
Single-data  
serial I/O  
1
2
__BasicOpenSerialDriver  
__BasicCloseSerialDriver  
__BasicSetSerialFormat  
__BasicStartSerialReceiving  
__BasicStartSerialSending  
__BasicReceivingStatusRead  
__BasicSendingStatusRead  
__BasicStopSerialReceiving  
__BasicStopSerialSending  
__OpenSerialDriver  
Closes serial port  
Sets serial communication  
Receives 1 data  
3
4
Transmits 1 data  
5
Reads receive status  
Reads transmit status  
Stops reception  
6
7
8
Stops transmission  
9
Opens serial port  
Multi-data  
serial I/O  
10  
11  
12  
13  
14  
15  
16  
17  
18  
19  
20  
21  
22  
23  
24  
25  
Closes serial port  
__CloseSerialDriver  
Registers notification function  
Sets serial communication  
Sets transmit/receive interrupt  
Starts reception  
__ConfigSerialDriverNotify  
__SetSerialFormat  
__SetSerialInterrupt  
__StartSerialReceiving  
__StartSerialSending  
__StopSerialReceiving  
__StopSerialSending  
__PollingSerialReceiving  
__PollingSerialSending  
__CreateTimer  
Starts transmission  
Stops reception  
Stops transmission  
Receives by polling  
Transmits by polling  
Sets timer mode  
Timer  
Controls timer mode operation  
Clears timer mode setting  
Sets event counter mode  
__EnableTimer  
__DestroyTimer  
__CreateEventCounter  
__EnableEventCounter  
Controls operation of event counter  
mode  
Clears setting of event counter  
mode  
Gets event counter mode counter  
value  
26  
27  
__DestroyEventCounter  
__GetEventCounter  
Sets pulse width modulation mode  
28  
29  
__CreatePulseWidthModulationMode  
__EnablePulseWidthModulationMode  
Controls operation of pulse width  
modulation mode  
Clears setting of pulse width  
modulation mode  
Sets pulse period measurement  
mode  
Controls operation of pulse period  
measurement mode  
Clears setting of pulse width  
measurement mode  
30  
31  
32  
33  
34  
__DestroyPulseWidthModulationMode  
__CreatePulsePeriodMeasurementMode  
__EnablePulsePeriodMeasurementMode  
__DestroyPulsePeriodMeasurementMode  
__GetPulsePeriodMeasurementMode  
Acquires measured value of pulse  
period measurement mode  
Rev.1.01  
2007.02.16  
19  
RJJ10J1643-0101  
 
Sets pulse width measurement  
mode  
Controls operation of pulse width  
measurement mode  
Clears setting of pulse width  
measurement mode  
Acquires measured value of pulse  
width measurement mode  
Sets input capture mode  
35  
36  
37  
38  
__CreatePulseWidthMeasurementMode  
__EnablePulseWidthMeasurementMode  
__DestroyPulseWidthMeasurementMode  
__GetPulseWidthMeasurementMode  
Timer  
39  
40  
__CreateInputCapture  
__EnableInputCapture  
Controls operation of input capture  
mode  
Clears setting of input capture mode  
41  
42  
__DestroyInputCapture  
__GetInputCapture  
Acquires counter value of input  
capture mode  
Sets output compare mode  
43  
44  
__CreateOutputCompare  
__EnableOutputCompare  
Controls operation of output  
compare mode  
Clears setting of output compare  
mode  
45  
__DestroyOutputCompare  
Sets timer register  
46  
47  
48  
49  
50  
51  
52  
53  
54  
55  
56  
57  
58  
59  
60  
61  
62  
63  
__SetTimerRegister  
__EnableTimerRegister  
__ClearTimerRegister  
__GetTimerRegister  
__SetIOPort  
Controls operation of timer register  
Clears timer register  
Gets timer register value  
Sets I/O port  
I/O port  
Reads from I/O port  
__ReadIOPort  
Writes to I/O port  
__WriteIOPort  
Sets I/O port register  
__SetIOPortRegister  
__ReadIOPortRegister  
__WriteIOPortRegister  
__SetInterrupt  
Reads from I/O port register  
Writes to I/O port register  
Sets external interrupt  
External  
interrupt  
Controls external interrupt  
Gets flag status of external interrupt  
Clears flag of external interrupt  
Sets A/D converter  
__EnableInterrupt  
__GetInterruptFlag  
__ClearInterruptFlag  
__CreateADC  
A/D converter  
Controls operation of A/D converter  
Discards settings of A/D converter  
__EnableADC  
__DestroyADC  
Gets A/D conversion value (register  
specified)  
__GetADC  
Gets A/D conversion value (all  
registers)  
64  
__GetADCAll  
Gets status of A/D converter  
65  
66  
__GetADCStatus  
__ClearADCStatus  
Clears status of A/D converter  
Rev.1.01  
2007.02.16  
20  
RJJ10J1643-0101  
 
4.2 Description of Each API  
This section describes each API and explains how to use them, showing a program  
example for each.  
The description of each API is divided into the following items.  
• Synopsis  
:
Outlines the content of processing performed by the function. It  
also shows the syntax of the function, followed by a brief  
explanation of arguments.  
• Description  
• Return value  
• Functionality  
• Reference  
:
:
:
:
:
:
Describes the function and how to use it in detail.  
Explains the returned value of the function.  
Indicates the functional classification of the function.  
Indicates the related functions.  
• Remark  
Describes the precautions to be taken when using the API.  
Presents a program showing how to use the function.  
• Program example  
Rev.1.01  
2007.02.16  
21  
RJJ10J1643-0101  
 
4.2.1 Serial I/O  
__BasicOpenSerialDriver  
Synopsis  
<Open a serial port>  
Boolean __BasicOpenSerialDriver(unsigned long data)  
data  
Setup data  
Description  
Opens and initializes a specified serial port.  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
If the serial port specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__BasicCloseSerialDriver  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
When used for the H8/300H, this API opens and initializes a specified serial port  
when freeing it from module standby state.  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
/* Open serial driver */  
return __BasicOpenSerialDriver( RAPI_COM1 );  
}
Rev.1.01  
2007.02.16  
22  
RJJ10J1643-0101  
 
__BasicCloseSerialDriver  
Synopsis  
<Close a serial port>  
Boolean __BasicCloseSerialDriver(unsigned long data)  
data  
Setup data  
Description  
Closes a specified serial port. For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
If the serial port specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__BasicOpenSerialDriver  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
When used for the H8/300H, this API places a specified serial port into module  
standby state after closing it.  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
/* Close serial driver */  
return Rapi_BasicCloseSerialDriver( RAPI_COM1 );  
}
Rev.1.01  
2007.02.16  
23  
RJJ10J1643-0101  
 
__BasicSetSerialFormat  
Synopsis  
<Set serial communication>  
Boolean __BasicSetSerialFormat(unsigned long data1, unsigned char data2)  
data1  
data2  
Setup data 1  
Setup data 2  
Description  
Sets serial communication according to specified parameters.  
[data1]  
For data1, the following values can be set. To set multiple definition values at the same  
time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
For serial communication mode, the following values can be set.  
(M16C) (UART0, UART1, UART2)  
RAPI_SM_SYNC  
RAPI_SM_ASYNC  
Clock synchronous serial communication mode  
Clock asynchronous serial communication mode  
(M16C)(SI/O3, SI/O4)  
RAPI_SIO_SM_SYNC  
Clock synchronous serial communication mode  
For the data length format of clock asynchronous serial communication, the following  
values can be set.  
If the API is used in clock synchronous serial communication mode, do not set these  
values.  
(M16C) (UART0, UART1, UART2)  
RAPI_BIT_7  
RAPI_BIT_9  
Transfer data length 7 bits RAPI_BIT_8  
Transfer data length 9 bits  
Transfer data length 8 bits  
For the clock source of serial communication, the following values can be set.  
(M16C) (UART0, UART1, UART2)  
RAPI_CKDIR_INT  
RAPI_CKDIR_EXT  
Internal clock is used as the clock source of serial communication.  
External clock is used as the clock source of serial communication.  
(M16C) (SI/O3, SI/O4)  
RAPI_SIO_CKDIR_INT  
Internal clock is used as the clock source of serial communication.  
RAPI_SIO_CKDIR_EXT External clock is used as the clock source of serial communication.  
For the stop bit length of clock asynchronous serial communication, the following  
values can be set.  
If the API is used in clock synchronous serial communication mode, do not set these  
values.  
(M16C) (UART0, UART1, UART2)  
RAPI_STPB_1  
1 stop bit  
RAPI_STPB_2  
2 stop bits  
For the parity bit of clock asynchronous serial communication, the following values can  
be set.  
Rev.1.01  
2007.02.16  
24  
RJJ10J1643-0101  
 
If the API is used in clock synchronous serial communication mode, do not set these  
values.  
(M16C) (UART0, UART1, UART2)  
RAPI_PARITY_NON No parity bit  
RAPI_PARITY_ODD Odd parity bit  
RAPI_PARITY_EVEN  
Even parity bit  
For the clock polarity of serial communication, the following values can be set.  
If the API is used in clock asynchronous serial communication mode, do not set these  
values.  
(M16C) (UART0, UART1, UART2)  
RAPI_DPOL_NON  
Polarity not inverted  
RAPI_DPOL_INV  
Polarity inverted  
(M16C) (SI/O3, SI/O4)  
RAPI_SIO_DPOL_NON Polarity not inverted  
RAPI_SIO_DPOL_INV  
Polarity inverted  
For the count source of the built-in baud rate generator, the following values can be set.  
(M16C) (UART0, UART1, UART2)  
RAPI_BCSS_F1  
RAPI_BCSS_F8  
f1SIO  
f8SIO  
RAPI_BCSS_F2  
RAPI_BCSS_F32  
f2SIO  
f32SIO  
(M16C) (SI/O3, SI/O4)  
RAPI_SIO_BCSS_F1  
RAPI_SIO_BCSS_F8  
f1SIO  
f8SIO  
RAPI_SIO_BCSS_F2  
f2SIO  
RAPI_SIO_BCSS_F32 f32SIO  
For the _CTS/_RTS function, the following values can be set.  
If the internal clock is selected for use in clock synchronous serial communication  
mode, the _RTS function has no effect.  
(M16C) (UART0, UART1, UART2)  
RAPI_CTSRTS_DIS  
RAPI_CTS_SEL  
RAPI_RTS_SEL  
_CTS/_RTS functions are not used.  
_CTS function is selected.  
_RTS function is selected.  
For the transfer format, the following values can be set.  
If the data length selected for use in clock asynchronous serial communication mode is  
7 or 9 bits long, do not set these values.  
(M16C) (UART0, UART1, UART2)  
RAPI_LSB_SEL  
LSB first  
RAPI_MSB_SEL  
MSB first  
MSB first  
(M16C) (SI/O3, SI/O4)  
RAPI_SIO_LSB_SEL  
LSB first  
RAPI_SIO_MSB_SEL  
For serial data logic switchover, the following values can be set.  
(M16C) (UART2)  
RAPI_LOGIC_NO_REV The value written in the transmit buffer register does not have its  
logic inverted.  
RAPI_LOGIC_REV  
The value written in the transmit buffer register is inverted before  
being transmitted.  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
UART1  
For serial communication mode, the following values can be set.  
Rev.1.01  
2007.02.16  
25  
RJJ10J1643-0101  
 
(R8C) (UART0, UART1)  
RAPI_SM_SYNC  
Clock synchronous serial communication mode  
Clock asynchronous serial communication mode  
RAPI_SM_ASYNC  
For the data length format of clock asynchronous serial communication, the following  
values can be set.  
If the API is used in clock synchronous serial communication mode, do not set these  
values.  
(R8C) (UART0, UART1)  
RAPI_BIT_7  
RAPI_BIT_9  
Transfer data length 7 bits  
Transfer data length 9 bits  
RAPI_BIT_8  
Transfer data length 8 bits  
For the clock source of serial communication, the following values can be set.  
(R8C) (UART0, UART1)  
RAPI_CKDIR_INT  
RAPI_CKDIR_EXT  
Internal clock is used as the clock source of serial communication.  
External clock is used as the clock source of serial communication.  
For the stop bit length of clock asynchronous serial communication, the following  
values can be set.  
If the API is used in clock synchronous serial communication mode, do not set these  
values.  
(R8C) (UART0, UART1)  
RAPI_STPB_1  
1 stop bit  
RAPI_STPB_2  
2 stop bits  
For the parity bit of clock asynchronous serial communication, the following values can  
be set.  
If the API is used in clock synchronous serial communication mode, do not set these  
values.  
(R8C) (UART0, UART1)  
RAPI_PARITY_NON  
RAPI_PARITY_ODD  
No parity bit  
RAPI_PARITY_EVEN  
Even parity bit  
Odd parity bit  
For the clock polarity of serial communication, the following values can be set.  
If the API is used in clock asynchronous serial communication mode, do not set these  
values.  
(R8C) (UART0, UART1)  
RAPI_DPOL_NON  
Polarity not inverted  
RAPI_DPOL_INV  
Polarity inverted  
For the count source of the built-in baud rate generator, the following values can be set.  
(R8C) (UART0, UART1)  
RAPI_BCSS_F1  
RAPI_BCSS_F32  
f1SIO  
RAPI_BCSS_F8  
f8SIO  
f32SIO  
For the transfer format, the following values can be set.  
If the data length selected for use in clock asynchronous serial communication mode is  
7 or 9 bits long, do not set these values.  
(R8C) (UART0, UART1)  
RAPI_LSB_SEL  
LSB first  
RAPI_MSB_SEL  
RAPI_COM2  
MSB first  
(H8/300H)  
RAPI_COM1  
SCI3 channel 1  
SCI3 channel 2  
Rev.1.01  
2007.02.16  
26  
RJJ10J1643-0101  
 
RAPI_COM3  
SCI3 channel 3  
For serial communication mode, the following values can be set.  
(H8/300H) (SCI3 channel 1, SCI3 channel 2, SCI3 channel 3)  
RAPI_SM_SYNC  
RAPI_SM_ASYNC  
Clock synchronous serial communication mode  
Clock asynchronous serial communication mode  
For the data length format of clock asynchronous serial communication, the following  
values can be set.  
If the API is used in clock synchronous serial communication mode, do not set these  
values.  
(H8/300H) (SCI3 channel 1, SCI3 channel 2, SCI3 channel 3)  
RAPI_BIT_7  
Transfer data length 7 bits  
RAPI_BIT_8  
Transfer data length 8 bits  
For the clock source of serial communication, the following values can be set.  
(H8/300H) (SCI3 channel 1, SCI3 channel 2)  
RAPI_CKDIR_INT  
RAPI_CKDIR_EXT  
Internal clock is used as the clock source of serial communication.  
External clock is used as the clock source of serial communication.  
For the stop bit length of clock asynchronous serial communication, the following  
values can be set.  
If the API is used in clock synchronous serial communication mode, do not set these  
values.  
(H8/300H) (SCI3 channel 1, SCI3 channel 2, SCI3 channel 3)  
RAPI_STPB_1  
1 stop bit  
RAPI_STPB_2  
2 stop bits  
For the parity bit of clock asynchronous serial communication, the following values can  
be set.  
If the API is used in clock synchronous serial communication mode, do not set these  
values.  
(H8/300H) (SCI3 channel 1, SCI3 channel 2, SCI3 channel 3)  
RAPI_PARITY_NON  
RAPI_PARITY_ODD  
No parity bit  
RAPI_PARITY_EVEN  
Even parity bit  
Odd parity bit  
For the count source of the built-in baud rate generator, the following values can be set.  
(H8/300H) (SCI3 channel 1, SCI3 channel 2 SCI3 channel 3)  
RAPI_BCSS_F1  
RAPI_BCSS_F16  
Φ clock  
RAPI_BCSS_F4  
RAPI_BCSS_F32  
φ/4 clock  
φ/16 clock  
φ/64 clock  
The noise rejection function can be set to be turned on or turned off.  
When used in clock synchronous serial communication mode, the noise rejection  
function has no effect.  
(H8/300H) (SCI3 channel 3)  
RAPI_NOISE_CANCEL_ON  
RAPI_NOISE_CANCEL_OFF  
[data2]  
Noise rejection function turned on  
Noise rejection function turned off  
Sets the divide-by-N value of a communication speed.  
Return value  
If serial communication was successfully set, RAPI_TRUE is returned; if settings failed,  
RAPI_FALSE is returned.  
Rev.1.01  
2007.02.16  
27  
RJJ10J1643-0101  
 
Functionality  
Remark  
Serial I/O  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
Boolean func( void )  
{
/* Set the data of RAPI_COM1 to serial driver */  
return _BasicSetSerialFormat(RAPI_COM1 | RAPI_SM_SYNC | RAPI_CKDIR_INT  
|
RAPI_BCSS_F1 | RAPI_DPOL_NON | RAPI_LSB_SEL,  
20);  
}
Rev.1.01  
2007.02.16  
28  
RJJ10J1643-0101  
 
__BasicStartSerialReceiving  
Synopsis  
<Receive 1 data>  
Boolean __BasicStartSerialReceiving(unsigned long data)  
data  
Setup data  
Description  
Starts receiving 1 data of serial communication.  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
If data reception in serial communication was successfully started, RAPI_TRUE is  
returned; if failed, RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__BasicReceivingStatusRead, __BasicStopSerialReceiving  
For the H8/300H, wait for at least a 1-bit period before calling this API after  
__BasicSetSerialFormat was called.  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
..........  
__BasicStartSerialReceiving( RAPI_COM1 );  
..........  
}
Rev.1.01  
2007.02.16  
29  
RJJ10J1643-0101  
 
__BasicStartSerialSending  
Synopsis  
<Transmit 1 data>  
Boolean _BasicStartSerialSending(unsigned long data1, unsigned int data2)  
data  
data  
Setup data  
Transmit data  
Description  
Starts sending 1 data of serial communication.  
For data1, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SIC3 channel 3  
SCI3 channel 2  
Return value  
If data transmission in serial communication was successfully started, RAPI_TRUE is  
returned; if failed, RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__BasicSendingStatusRead, __BasicStopSerialSending  
For the H8/300H, wait for at least a 1-bit period before calling this API after  
__BasicSetSerialFormat was called.  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
Void func( void )  
{
..........  
__BasicStartSerialSending( RAPI_COM1, 0x00AA );  
..........  
}
Rev.1.01  
2007.02.16  
30  
RJJ10J1643-0101  
 
__BasicReceivingStatusRead  
Synopsis  
<Read receive status>  
unsigned int __BasicReceivingStatusRead(unsigned long data)  
data  
Setup data  
Description  
Returns the receive status of serial communication.  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
The receive status of serial communication is returned. The returned value is one of  
the following.  
(M16C) (UART0, UART1, UART2)  
RAPI_RX_INCOMPLETE Reception not complete yet.  
Other than above  
Reception complete. The value read from the UARTi receive  
buffer register (i = 0 to 2).  
(M16C) (SI/O3, SI/O4)  
RAPI_RX_INCOMPLETE Reception not complete yet.  
Other than above Reception complete. Low-order 8 bits: The value read from the  
SI/Oi transmit/receive register (i = 3, 4).  
(R8C)  
RAPI_RX_INCOMPLETE Reception not complete yet.  
Other than above Reception complete. The value read from the UARTi receive  
buffer register (i = 0, 1).  
(H8/300H)  
RAPI_RX_INCOMPLETE Reception not complete yet.  
Other than above  
Reception complete.  
High-order 8 bits: The value read from the serial status register.  
Low-order 8 bits: The value read from the receive data register.  
(Not read if an error occurred.)  
Functionality  
Reference  
Serial I/O  
__BasicStartSerialReceiving, __BasicStopSerialReceiving  
Rev.1.01  
2007.02.16  
31  
RJJ10J1643-0101  
 
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Remark  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
unsigned int rcv_data;  
..........  
rcv_data = __BasicReceivingStatusRead( RAPI_COM1 );  
..........  
}
Rev.1.01  
2007.02.16  
32  
RJJ10J1643-0101  
 
__BasicSendingStatusRead  
Synopsis  
<Read transmit status>  
Boolean __BasicSendingStatusRead(unsigned long data)  
data  
Setup data  
Description  
Returns the transmit status of serial communication. For data, the following values can  
be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
If no data exists in the transmit buffer, RAPI_TRUE is returned; if data exists,  
RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__BasicStartSerialSending, __BasicStopSerialSending  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
..........  
if (__BasicSendingStatusRead( RAPI_COM1 ) == RAPI_TRUE) {  
/* Transmission completion */  
}
..........  
}
Rev.1.01  
2007.02.16  
33  
RJJ10J1643-0101  
 
__BasicStopSerialReceiving  
Synopsis  
<Stop reception>  
Boolean Rapi_BasicStopSerialReceiving(unsigned long data)  
data  
Setup data  
Description  
Stops receiving data in serial communication  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
UART0  
UART2  
RAPI_COM2  
UART1  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
If data reception in serial communication was successfully stopped, RAPI_TRUE is  
returned; if failed, RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__BasicStartSerialReceiving  
For the M16C SI/03 and SI/04, this API cannot be used.  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
………………  
/* Stop receiving data in serial communication */  
__BasicStopSerialReceiving ( RAPI_COM1 );  
………………  
}
Rev.1.01  
2007.02.16  
34  
RJJ10J1643-0101  
 
__BasicStopSerialSending  
Synopsis  
<Stop transmission>  
Boolean __BasicStopSerialSending(unsigned long data)  
data  
Setup data  
Description  
Stops transmitting data in serial communication.  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
UART0  
UART2  
RAPI_COM2  
UART1  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
SIO3_COM3  
SCI3 channel 1  
SIO3 channel 3  
SCI3 channel 2  
Return value  
If data transmission in serial communication was successfully stopped, RAPI_TRUE is  
returned; if failed, RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__BasicStartSerialSending  
For the M16C SI/03 and SI/04, this API cannot be used.  
The specifiable serial ports differ with each CPU used.  
When operating in clock synchronous serial communication mode, data reception is  
stopped at the same time by this API.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
………………  
/* Stop sending data in serial communication */  
__BasicStopSerialSending ( RAPI_COM1 );  
………………  
}
Rev.1.01  
2007.02.16  
35  
RJJ10J1643-0101  
 
__OpenSerialDriver  
Synopsis  
<Open a serial port>  
Boolean __OpenSerialDriver(unsigned long data)  
data  
Setup data  
Description  
Opens and initializes a specified serial port.  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
SIO3_COM3  
SCI3 channel 1  
SIO3 channel 3  
SCI3 channel 2  
Return value  
If the serial port specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__CloseSerialDriver  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
When used for the H8/300H, this API opens and initializes a specified serial port  
when freeing it from module standby state.  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
………………  
/* Open serial driver */  
return __OpenSerialDriver( RAPI_COM1 );  
………………  
}
Rev.1.01  
2007.02.16  
36  
RJJ10J1643-0101  
 
__CloseSerialDriver  
Synopsis  
<Close a serial port>  
Boolean __CloseSerialDriver(unsigned long data)  
data  
Setup data  
Description  
Closes a specified serial port.  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
SIO3_COM3  
SCI3 channel 1  
SIO3 channel 3  
SCI3 channel 2  
Return value  
If the serial port specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__OpenSerialDriver  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
When used for the H8/300H, this API places a specified serial port into module  
standby state after closing it.  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
………………  
/* Close serial driver */  
return __CloseSerialDriver( RAPI_COM1 );  
………………  
}
Rev.1.01  
2007.02.16  
37  
RJJ10J1643-0101  
 
__ConfigSerialDriverNotify  
Synopsis  
<Register a notification function>  
Boolean __ConfigSerialDriverNotify(unsigned long data, VoidFuncNotify *func)  
data  
func  
Setup data  
Function pointer to be registered  
Description  
Registers the notification function necessary to get various transmit/receive information  
of serial communication.  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
[func]  
The function to be registered in func must be supplied to the serial I/O driver by the  
user.  
The serial I/O driver calls the function registered in func.  
The serial I/O driver notifies the user of the transmit/receive status by an argument.  
The type of the function to be registered is shown below.  
void “any function name” (unsigned char notify);  
The argument is detailed below.  
(M16C) (UART0, UART1, UART2)  
b7 b6 b5 b4 b3 b2 b1 b0  
0
0 X  
X
0 X  
X
X
0 No error  
1 Error occurred  
Overrun error  
Framing error  
Parity error  
0 No error  
1 Error occurred  
0 No error  
1 Error occurred  
0 Not completed  
1 Completed  
Transmission completed  
Reception completed  
0 Not completed  
1 Completed  
(M16C) (SI/O3,SI/O4)  
Rev.1.01  
2007.02.16  
38  
RJJ10J1643-0101  
 
b7 b6 b5 b4 b3 b2 b1 b0  
0 X X 0  
0
0
0
0
0 Not completed  
1 Completed  
Transmission completed  
Reception completed  
0 Not completed  
1 Completed  
(R8C)  
0
0 X  
X
0 X  
X
X
0 No error  
1 Error occurred  
Overrun error  
Framing error  
Parity error  
0 No error  
1 Error occurred  
0 No error  
1 Error occurred  
0 Not completed  
1 Completed  
Transmission completed  
Reception completed  
0 Not completed  
1 Completed  
(H8/300H)  
b7 b6 b5 b4 b3 b2 b1 b0  
0 X 0 X  
0
X
X
X
0 No error  
1 Error occurred  
Parity error  
0 No error  
1 Error occurred  
Framing error  
Overrun error  
0 No error  
1 Error occurred  
0 Not completed  
1 Completed  
Transmission completed  
Reception completed  
0 Not completed  
1 Completed  
Return value  
If the serial port specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__StartSerialReceiving, __StartSerialSending  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
Rev.1.01  
2007.02.16  
39  
RJJ10J1643-0101  
 
Program example  
#include ”rapi_sif_r8c_13.h”  
void Notify(unsigned char result) {  
if ((result&RAPI_OVER_ERR) == RAPI_OVER_ERR) {  
/* Overrun error */  
}
if ((result&RAPI_FRAMING_ERR) == RAPI_FRAMING_ERR) {  
/* Framing error */  
}
if ((result&RAPI_PARITY_ERR) == RAPI_PARITY_ERR) {  
/* Parity error */  
}
if ((result&RAPI_TX_END) == RAPI_TX_END) {  
/* Transmission completion */  
}
if ((result&RAPI_RX_END) == RAPI_RX_END) {  
/* Reception completion */  
}
}
Boolean func( void )  
{
………………  
/* Set callback functions of RAPI_COM1 to serial driver */  
return __ConfigSerialDriverNotify( RAPI_COM1, Notify );  
………………  
}
Rev.1.01  
2007.02.16  
40  
RJJ10J1643-0101  
 
__SetSerialFormat  
Synopsis  
<Set serial communication>  
Boolean __SetSerialFormat(unsigned long data1, unsigned char data2)  
data1  
data2  
Setup data 1  
Setup data 2  
Description  
Sets serial communication according to specified parameters.  
For details about parameters, refer to the description of __BasicSetSerialFormat.  
Return value  
If serial communication was successfully set, RAPI_TRUE is returned; if settings failed,  
RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__BasicSetSerialFormat  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
Boolean func( void )  
{
………………  
/* Set the data of RAPI_COM1 to serial driver */  
return __SetSerialFormat(RAPI_COM1 | RAPI_SM_SYNC | RAPI_CKDIR_INT |  
RAPI_BCSS_F1|RAPI_DPOL_NON|RAPI_LSB_SEL,20);  
………………  
}
Rev.1.01  
2007.02.16  
41  
RJJ10J1643-0101  
 
__SetSerialInterrupt  
Synopsis  
<Set serial interrupts>  
Boolean __SetSerialInterrupt(unsigned long data)  
data  
Setup data  
Description  
Sets serial interrupts according to specified parameters.  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
For interrupt settings, the following values can set.  
(M16C) (UART0, UART1, UART2)  
RAPI_INT_TX_DIS  
RAPI_INT_TX_LV_1  
RAPI_INT_TX_LV_2  
RAPI_INT_TX_LV_3  
RAPI_INT_TX_LV_4  
RAPI_INT_TX_LV_5  
RAPI_INT_TX_LV_6  
RAPI_INT_TX_LV_7  
RAPI_INT_RX_DIS  
RAPI_INT_RX_LV_1  
RAPI_INT_RX_LV_2  
RAPI_INT_RX_LV_3  
RAPI_INT_RX_LV_4  
RAPI_INT_RX_LV_5  
RAPI_INT_RX_LV_6  
RAPI_INT_RX_LV_7  
(M16C) (SI/O3, SI/O4)  
RAPI_INT_SIO_DIS  
Transmit interrupt disabled  
Transmit interrupt priority level 1  
Transmit interrupt priority level 2  
Transmit interrupt priority level 3  
Transmit interrupt priority level 4  
Transmit interrupt priority level 5  
Transmit interrupt priority level 6  
Transmit interrupt priority level 7  
Receive interrupt disabled  
Receive interrupt priority level 1  
Receive interrupt priority level 2  
Receive interrupt priority level 3  
Receive interrupt priority level 4  
Receive interrupt priority level 5  
Receive interrupt priority level 6  
Receive interrupt priority level 7  
SI/O interrupt disabled  
RAPI_INT_SIO_LV_1 SI/O interrupt priority level 1  
RAPI_INT_SIO_LV_2 SI/O interrupt priority level 2  
RAPI_INT_SIO_LV_3 SI/O interrupt priority level 3  
RAPI_INT_SIO_LV_4 SI/O interrupt priority level 4  
RAPI_INT_SIO_LV_5 SI/O interrupt priority level 5  
RAPI_INT_SIO_LV_6 SI/O interrupt priority level 6  
RAPI_INT_SIO_LV_7 SI/O interrupt priority level 7  
(R8C)  
Rev.1.01  
2007.02.16  
42  
RJJ10J1643-0101  
 
RAPI_COM1  
UART0  
RAPI_COM2  
UART1  
For interrupt settings, the following values can set.  
RAPI_INT_TX_DIS  
RAPI_INT_TX_LV_1  
RAPI_INT_TX_LV_2  
RAPI_INT_TX_LV_3  
RAPI_INT_TX_LV_4  
RAPI_INT_TX_LV_5  
RAPI_INT_TX_LV_6  
RAPI_INT_TX_LV_7  
RAPI_INT_RX_DIS  
RAPI_INT_RX_LV_1  
RAPI_INT_RX_LV_2  
RAPI_INT_RX_LV_3  
RAPI_INT_RX_LV_4  
RAPI_INT_RX_LV_5  
RAPI_INT_RX_LV_6  
RAPI_INT_RX_LV_7  
Transmit interrupt disabled  
Transmit interrupt priority level 1  
Transmit interrupt priority level 2  
Transmit interrupt priority level 3  
Transmit interrupt priority level 4  
Transmit interrupt priority level 5  
Transmit interrupt priority level 6  
Transmit interrupt priority level 7  
Receive interrupt disabled  
Receive interrupt priority level 1  
Receive interrupt priority level 2  
Receive interrupt priority level 3  
Receive interrupt priority level 4  
Receive interrupt priority level 5  
Receive interrupt priority level 6  
Receive interrupt priority level 7  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
RAPI_COM2  
SCI3 channel 2  
For interrupt settings, the following values can set.  
RAPI_INT_TX_DIS  
Transmit interrupt disabled  
RAPI_INT_TX_ENA  
RAPI_INT_RX_ENA  
Transmit interrupt enabled  
Receive interrupt enabled  
RAPI_INT_RX_DIS Receive interrupt disabled  
For the CPUs that have an interrupt control register, following values can be set to  
specify interrupt priority, in addition to ordinary interrupt settings.  
RAPI_INT_LV_0  
Transmit/Receive interrupt priority level0  
RAPI_INT_LV_1  
Transmit/Receive interrupt priority level1  
Return value  
If the serial port specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Remark  
Serial I/O  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
Rev.1.01  
2007.02.16  
43  
RJJ10J1643-0101  
 
Boolean func( void )  
{
………………  
/* Set interrupt of RAPI_COM1 to serial driver */  
return  
__SetSerialInterrupt(  
RAPI_COM1  
|
RAPI_INT_TX_LV_1  
|
RAPI_INT_RX_LV_2 );  
………………  
}
Rev.1.01  
2007.02.16  
44  
RJJ10J1643-0101  
 
__StartSerialReceiving  
Synopsis  
<Start reception>  
Boolean __StartSerialReceiving(unsigned long data, unsigned char wordNum,  
unsigned int *RcvDtBuf)  
data  
Setup data  
wordNum  
RcvDtBuf  
Number of words received  
Pointer to the buffer in which received data is stored  
Description  
Starts reception of serial communication and gets received data by a specified number  
of words. When acquisition of received data is complete, this API calls a notification  
function (if a notification function is registered).  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
If reception of serial communication was successfully started, RAPI_TRUE is returned;  
if failed, RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__ConfigSerialDriverNotify, __StopSerialReceiving  
For the H8/300H, wait for at least a 1-bit period before calling this API after  
__SetSerialFormat was called.  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
For the H8/300H, the following values are stored in the receive buffer.  
High-order 8 bits: The value read from the serial status register.  
Low-order 8 bits: The value read from the receive data register.  
(Not read if an error occurred.)  
Program example  
#include ”rapi_sif_r8c_13.h”  
Rev.1.01  
2007.02.16  
45  
RJJ10J1643-0101  
 
unsigned int buffer[10];  
void func( void )  
{
………………  
/* Get 5 word data received in serial communication */  
__StartSerialReceiving( RAPI_COM1, 5, buffer );  
………………  
}
Rev.1.01  
2007.02.16  
46  
RJJ10J1643-0101  
 
__StartSerialSending  
Synopsis  
<Start transmission>  
Boolean __StartSerialSending(unsigned long data, unsigned char wordNum,  
unsigned int *SndDtBuf)  
data  
Setup data  
wordNum  
SndDtBuf  
Number of words transmitted  
Pointer to the transmit data  
Description  
Starts transmission of serial communication and writes transmit data to the transmit  
buffer by a specified number of words. When transmission of all transmit data is  
complete, this API calls a notification function (if a notification function is registered).  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
(H8/300H)  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
If transmission of serial communication was successfully started, RAPI_TRUE is  
returned; if failed, RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__ConfigSerialDriverNotify, __StopSerialSending  
For the H8/300H, wait for at least a 1-bit period before calling this API after  
__SetSerialFormat was called.  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
Rev.1.01  
2007.02.16  
47  
RJJ10J1643-0101  
 
unsigned int buffer[10];  
void func( void )  
{
………………  
/* Set 5 word data to transmit buffer of serial communication */  
__StartSerialSending( RAPI_COM1, 5, buffer );  
………………  
}
Rev.1.01  
2007.02.16  
48  
RJJ10J1643-0101  
 
__StopSerialReceiving  
Synopsis  
<Stop reception>  
Boolean __StopSerialReceiving(unsigned long data)  
data  
Setup data  
Description  
Stops reception of serial communication.  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
UART0  
UART2  
RAPI_COM2  
UART1  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
If reception of serial communication was successfully stopped, RAPI_TRUE is  
returned; if failed, RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__StartSerialSending  
For the M16C SI/03 and SI/04, this API cannot be used.  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
………………  
/* Stop receiving data in serial communication */  
__StopSerialReceiving ( RAPI_COM1 );  
………………  
}
Rev.1.01  
2007.02.16  
49  
RJJ10J1643-0101  
 
__StopSerialSending  
Synopsis  
<Stop transmission>  
Boolean __StopSerialSending(unsigned long data)  
data  
Setup data  
Description  
Stops transmission of serial communication.  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
UART0  
UART2  
RAPI_COM2  
UART1  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
If transmission of serial communication was successfully stopped, RAPI_TRUE is  
returned; if failed, RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__StartSerialReceiving  
For the M16C SI/03 and SI/04, this API cannot be used.  
The specifiable serial ports differ with each CPU used.  
When operating in clock synchronous serial communication mode, data reception is  
stopped at the same time by this API.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
void func( void )  
{
………………  
/* Stop sending data in serial communication */  
__StopSerialSending ( RAPI_COM1 );  
………………  
}
Rev.1.01  
2007.02.16  
50  
RJJ10J1643-0101  
 
__PollingSerialReceiving  
Synopsis  
<Polling reception>  
unsigned int __PollingSerialReceiving(unsigned long data)  
data  
Setup data  
Description  
Performs reception of serial communication by polling. This API gets received data by  
an amount specified by __StartSerialReceiving. When acquisition of received data is  
complete, it calls a notification function (if a notification function is registered).  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
Functionality  
Reference  
Remark  
Out of the receive data counts requested, the number of unreceived data is returned.  
Serial I/O  
__ConfigSerialDriverNotify, __SetSerialInterrupt, __StartSerialReceiving  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
unsigned int buffer[10], count;  
void func( void )  
{
………………  
/* Reception interrupt disable */  
__SetSerialInterrupt( RAPI_COM1 | RAPI_INT_TX_DIS | RAPI_INT_RX_DIS );  
/* Start reception */  
__StartSerialReceiving( RAPI_COM1, 5, buffer );  
do{  
count = __PollingSerialReceiving( RAPI_COM1 );  
}while(count)  
………………  
}
Rev.1.01  
2007.02.16  
51  
RJJ10J1643-0101  
 
__PollingSerialSending  
Synopsis  
<Polling transmission>  
Unsigned __PollingSerialSending(unsigned long data)  
data  
Setup data  
Description  
Performs transmission of serial communication by polling. This API sends transmit data  
by an amount specified by __StartSerialSending from the transmit data buffer specified  
by __StartSerialSending. When transmission of all transmit data is complete, it calls a  
notification function (if a notification function is registered).  
[data]  
For data, the following values can be set.  
(M16C)  
RAPI_COM1  
RAPI_COM3  
RAPI_COM5  
UART0  
UART2  
SI/O4  
RAPI_COM2  
RAPI_COM4  
UART1  
SI/O3  
(R8C)  
RAPI_COM1  
UART0  
RAPI_COM2  
RAPI_COM2  
UART1  
(H8/300H)  
RAPI_COM1  
RAPI_COM3  
SCI3 channel 1  
SCI3 channel 3  
SCI3 channel 2  
Return value  
Out of the transmit data counts requested, the number of untransmitted data is  
returned.  
Functionality  
Reference  
Remark  
Serial I/O  
__ConfigSerialDriverNotify, __SetSerialInterrupt, __StartSerialReceiving  
The specifiable serial ports differ with each CPU used.  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Program example  
#include ”rapi_sif_r8c_13.h”  
Rev.1.01  
2007.02.16  
52  
RJJ10J1643-0101  
 
unsigned int buffer[10],count;  
void func( void )  
{
………………  
/* Transmission interrupt disable */  
__SetSerialInterrupt( RAPI_COM1 | RAPI_INT_TX_DIS | RAPI_INT_RX_DIS );  
/* Start transmission */  
__StartSerialSending( RAPI_COM1, 5, buffer );  
do{  
count = __PollingSerialSending( RAPI_COM1 );  
}while(count)  
………………  
}
Rev.1.01  
2007.02.16  
53  
RJJ10J1643-0101  
 
4.2.2 Timer  
__CreateTimer  
Synopsis  
<Set timer mode>  
Boolean __CreateTimer(unsigned long data1, unsigned int data2, unsigned int  
data3, unsigned int data4, void* func)  
data1  
data2  
data3  
data4  
func  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Setup data 3 (content differs with MCU type)  
Setup data 4 (content differs with MCU type)  
Callback function pointer  
(Specify 0 if no callback functions are set.)  
Description  
Sets a specified timer to timer mode.  
[data1]  
For data1, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_F1  
Uses timer A channel 0.  
Uses timer A channel 1.  
Uses timer A channel 2.  
Uses timer A channel 3.  
Uses timer A channel 4.  
Uses timer B channel 0.  
Uses timer B channel 1.  
Uses timer B channel 2.  
Selects f1 for the count source.  
Selects f2 for the count source.  
Selects f8 for the count source.  
Selects f32 for the count source.  
Selects fc32 for the count source.  
Sets the timer to start operating in __CreateTimer.  
Sets the timer to stop operating in __CreateTimer.  
Selects a gate facility that counts a period during which input at  
TAiIN pin remains low.  
RAPI_F2  
RAPI_F8  
RAPI_F32  
RAPI_FC32  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_GATE_L  
RAPI_GATE_H  
Selects a gate facility that counts a period during which input at  
TAiIN pin remains high.  
RAPI_PULSE_ON  
RAPI_PULSE_OFF  
Selects that pulses are output from TAiIN pin.  
Selects that no pulses are output from TAiIN pin.  
• Specifiable definition values when timer A is used (RAPI_TIMER_A0 to  
RAPI_TIMER_A4 specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F2, RAPI_F8, RAPI_F32,  
RAPI_FC32 }. The default value is RAPI_F2.  
Rev.1.01  
2007.02.16  
54  
RJJ10J1643-0101  
 
(Operating states set)  
(Pulse output state)  
(Gate facility)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
Specify one from { RAPI_PULSE_ON, RAPI_PULSE_OFF }. The  
default value is RAPI_PULSE_OFF.  
Specify one from { RAPI_GATE_L, RAPI_GATE_H }. If omitted,  
“No gate facility” is set.  
Specifiable definition values when timer B is used (RAPI_TIMER_B0 to  
RAPI_TIMER_B2 specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F2, RAPI_F8, RAPI_F32,  
RAPI_FC32 }. The default value is RAPI_F2.  
(Operating states set)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
(R8C)  
RAPI_TIMER_X  
RAPI_TIMER_Y  
RAPI_TIMER_Z  
RAPI_TIMER_RA  
RAPI_TIMER_RB  
RAPI_F1  
Uses timer X.  
Uses timer Y.  
Uses timer Z.  
Uses timer RA.  
Uses timer RB.  
Selects f1 for the count source.  
Selects f2 for the count source.  
Selects f8 for the count source.  
Selects f32 for the count source.  
Selects fRING for the count source.  
Selects foco for the count source.  
Selects fC32 for the count source.  
Selects the underflow of timer Y for the count source.  
RAPI_F2  
RAPI_F8  
RAPI_F32  
RAPI_FRING  
RAPI_FOCO  
RAPI_FC32  
RAPI_TIMER_Y_  
UNDERFLOW  
RAPI_TIMER_RA_UN  
DERFLOW  
Selects the underflow of timer RA for the count source.  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_WRITE_  
RELOAD_ONLY  
Sets the timer to start operating in __CreateTimer.  
Sets the timer to stop operating in __CreateTimer.  
Selects operation mode in which writing to the primary register and  
prescaler causes the set data to be written to only the reload  
register.  
RAPI_WRITE_  
Selects operation mode in which writing to the primary register and  
prescaler causes the set data to be written to both the reload  
register and the counter, respectively.  
RELOAD_BOTH  
Specifiable definition values when timer X is used (RAPI_TIMER_X specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F2, RAPI_F8, RAPI_F32 }. The  
default value is RAPI_F1.  
(Operating states set)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
Specifiable definition values when timer Y is used (RAPI_TIMER_Y specified)  
Rev.1.01  
2007.02.16  
55  
RJJ10J1643-0101  
 
(Count source)  
Specify one from { RAPI_F1, RAPI_F8, RAPI_FRING }. The default  
value is RAPI_F1.  
(Operating states set)  
(Write control)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
Specify one from { RAPI_WRITE_RELOAD_ONLY,  
RAPI_WRITE_RELOAD_BOTH }. The default value is  
RAPI_WRITE_RELOAD_BOTH.  
Specifiable definition values when timer Z is used (RAPI_TIMER_Z specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F2, RAPI_F8,  
RAPI_TIMER_Y_UNDERFLOW}. The default value is RAPI_F1.  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
(Operating states set)  
(Write control)  
Specify one from {RAPI_WRITE_RELOAD_ONLY,  
RAPI_WRITE_RELOAD_BOTH}. The default value is  
RAPI_WRITE_RELOAD_BOTH.  
Specifiable definition values when timer RA is used (RAPI_TIMER_RA specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F2, RAPI_F8, RAPI_FOCO,  
RAPI_FC32}. The default value is RAPI_F1.  
(Operating states set)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
Specifiable definition values when timer RB is used (RAPI_TIMER_RB specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F2, RAPI_F8,  
RAPI_TIMER_RA_UNDERFLOW}. The default value is RAPI_F1.  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
(Operating states set)  
(Write control)  
Specify one from {RAPI_WRITE_RELOAD_ONLY,  
RAPI_WRITE_RELOAD_BOTH}. The default value is  
RAPI_WRITE_RELOAD_BOTH.  
(H8/300H)  
RAPI_TIMER_A  
RAPI_TIMER_B1  
RAPI_TIMER_V  
RAPI_TA_F8  
Uses timer A.  
Uses timer B1.  
Uses timer V  
Supplies φ/8 clock to timer A.  
Supplies φ/32 clock to timer A.  
Supplies φ/128 clock to timer A.  
Supplies φ/256 clock to timer A.  
Supplies φ/512 clock to timer A.  
Supplies φ/2048 clock to timer A.  
Supplies φ/4096 clock to timer A.  
Supplies φ/8192 clock to timer A.  
Timer B1 counts with internal clock φ/4.  
Timer B1 counts with internal clock φ/16.  
Timer B1 counts with internal clock φ/64.  
RAPI_TA_F32  
RAPI_TA_F128  
RAPI_TA_F256  
RAPI_TA_F512  
RAPI_TA_F2048  
RAPI_TA_F4096  
RAPI_TA_F8192  
RAPI_TB1_F4  
RAPI_TB1_F16  
RAPI_TB1_F64  
Rev.1.01  
2007.02.16  
56  
RJJ10J1643-0101  
 
RAPI_TB1_F256  
RAPI_TB1_F512  
RAPI_TB1_F2048  
RAPI_TB1_F8192  
RAPI_TV_F4  
Timer B1 counts with internal clock φ/256.  
Timer B1 counts with internal clock φ/512.  
Timer B1 counts with internal clock φ/2048.  
Timer B1 counts with internal clock φ/8192.  
Timer V counts on falling edges of internal clock φ/4.  
Timer V counts on falling edges of internal clock φ/8.  
Timer V counts on falling edges of internal clock φ/16.  
Timer V counts on falling edges of internal clock φ/32.  
Timer V counts on falling edges of internal clock φ/64.  
Timer V counts on falling edges of internal clock φ/128.  
Sets the timer to start operating in __CreateTimer.  
Sets the timer to stop operating in __CreateTimer.  
Enables overflow interrupt.  
RAPI_TV_F8  
RAPI_TV_F16  
RAPI_TV_F32  
RAPI_TV_F64  
RAPI_TV_F128  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_OVERFLOW  
RAPI_OUT_F4  
RAPI_OUT_F8  
RAPI_OUT_F16  
RAPI_OUT_F32  
RAPI_OUT_8192  
RAPI_OUT_4096  
RAPI_OUT_2048  
RAPI_OUT_1024  
Outputs φ/4 clock.  
Outputs φ/8 clock.  
Outputs φ/16 clock.  
Outputs φ/32 clock.  
Outputs φW/4 clock.  
Outputs φW/8 clock.  
Outputs φW/16 clock.  
Outputs φW/32 clock.  
RAPI_AUTO_RELOAD Uses auto reload facility.  
• Specifiable definition values when timer A is used (RAPI_TIMER_A specified)  
(Clock)  
Specify one from { RAPI_TA_F8, RAPI_TA_F32, RAPI_TA_F128,  
RAPI_TA_F256, RAPI_TA_F512, RAPI_TA_F2048, RAPI_TA_F4096,  
RAPI_TA_F8192 }. The default value is RAPI_TA_F8192.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
no interrupts are specified, “No interrupt request” is set.  
Specify one from { RAPI_OUT_F4, RAPI_OUT_F8, RAPI_OUT_F16,  
RAPI_OUT_F32, RAPI_OUT_8192, RAPI_OUT_4096,  
RAPI_OUT_2048, RAPI_OUT_1024 }. If this specification is omitted,  
“Clock output” is set.  
(Interrupt)  
(Output)  
• Specifiable definition values when timer B1 is used (RAPI_TIMER_B1 specified)  
(Clock)  
Specify one from { RAPI_TB1_F4, RAPI_TB1_F16, RAPI_TB1_F64,  
RAPI_TB1_F256, RAPI_TB1_F512, RAPI_TB1_F2048,  
RAPI_TB1_F8192 }. The default value is RAPI_TB1_F8192.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
no interrupts are specified, “No interrupt request” is set.  
(Interrupt)  
(Reload)  
To select the auto reload facility, specify RAPI_AUTO_RELOAD. If  
RAPI_AUTO_RELOAD is not specified, “Select interval facility” is set.  
• Specifiable definition values when timer V is used (RAPI_TIMER_V specified)  
(Clock) Specify one from RAPI_TV_F4, RAPI_TV_F8, RAPI_TV_F16,  
{
RAPI_TV_F32, RAPI_TV_F64, RAPI_TV_F128}. If this specification is  
omitted, “Disable clock input” is set.  
Rev.1.01  
2007.02.16  
57  
RJJ10J1643-0101  
 
(Interrupt)  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
no interrupts are specified, “No interrupt request” is set.  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(Operating  
states set)  
[data2]  
(M16C) (R8C)  
Specify the interrupt priority level (07) to be set in the interrupt control register.  
(H8/300H)  
Specify the interrupt priority level (0–1) to be set in the interrupt control register.  
For the CPUs that do not have an interrupt control register, specify 0.  
[data3]  
(M16C)  
Specify the value to be set in the timer register in 16 bits.  
(R8C)  
When using timer X, specify the set value for the timer register; when using timer Y  
or timer Z, specify the set value for the primary register in 8 bits.  
(H8/300H)  
Specify the set value for the timer reload register in 8 bits. This setting is effective  
only when timer B1 is used. If any timer other than B1 is used, specify 0.  
[data4]  
(M16C) (H8/300H)  
Specify 0.  
(R8C)  
Specify the set value for the prescaler register in 8 bits.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (timer mode)  
__EnableTimer, __DestroyTimer  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable timers differ with each CPU used.  
When used for the H8/300H, this API specify when freeing it from module stanby.  
Program example  
#include "rapi_timer_r8c_13.h"  
void TimerIntFunc( void ){}  
Rev.1.01  
2007.02.16  
58  
RJJ10J1643-0101  
 
void func( void )  
{
/* Set up timer X as timer mode */  
__CreateTimer( RAPI_TIMER_X|RAPI_TIMER_ON|RAPI_F8, 5, 0x80, 0x80,  
TimerIntFunc );  
}
Rev.1.01  
2007.02.16  
59  
RJJ10J1643-0101  
 
__EnableTimer  
Synopsis  
<Control operation of timer mode>  
Boolean __EnableTimer(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Controls operation of the timer that is set to specified timer mode by starting or  
stopping it.  
[data]  
For data, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_TIMER_ON  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2.  
Selects timer A channel 3.  
Selects timer A channel 4.  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
Sets the timer that is set to timer mode to start operating.  
RAPI_TIMER_OFF Sets the timer that is set to timer mode to stop operating.  
(R8C)  
RAPI_TIMER_X  
Selects timer X.  
RAPI_TIMER_Y  
RAPI_TIMER_Z  
RAPI_TIMER_RA  
RAPI_TIMER_RB  
RAPI_TIMER_ON  
Selects timer Y.  
Selects timer Z.  
Selects timer RA.  
Selects timer RB.  
Sets the timer that is set to timer mode to start operating.  
RAPI_TIMER_OFF Sets the timer that is set to timer mode to stop operating.  
(H8/300H)  
RAPI_TIMER_V  
Selects timer V.  
RAPI_TIMER_ON  
Sets the timer that is set to timer mode to start operating.  
RAPI_TIMER_OFF Sets the timer that is set to timer mode to stop operating.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
Timer (timer mode)  
__CreateTimer, __DestroyTimer  
Rev.1.01  
2007.02.16  
60  
RJJ10J1643-0101  
 
Remark  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
/* Disable timer Y as timer mode */  
__EnableTimer( RAPI_TIMER_Y| RAPI_TIMER_OFF );  
}
Rev.1.01  
2007.02.16  
61  
RJJ10J1643-0101  
 
__DestroyTimer  
Synopsis  
<Discard settings of timer mode>  
Boolean __DestroyTimer(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Discards settings of the timer that is set to specified timer mode.  
[data]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2  
Selects timer A channel 3.  
Selects timer A channel 4.  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
(R8C)  
RAPI_TIMER_X  
RAPI_TIMER_Y  
RAPI_TIMER_Z  
RAPI_TIMER_RA  
RAPI_TIMER_RB  
Selects timer X.  
Selects timer Y.  
Selects timer Z.  
Selects timer RA.  
Selects timer RB.  
(H8/300H)  
RAPI_TIMER_A  
RAPI_TIMER_B1  
RAPI_TIMER_V  
Selects timer A.  
Selects timer B1.  
Selects timer V.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (timer mode)  
__CreateTimer, __EnableTimer  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
When used for the H8/300H, this API places a specified timer into module stanby  
state after discarding it.  
Program example  
#include "rapi_timer_r8c_13.h"  
Rev.1.01  
2007.02.16  
62  
RJJ10J1643-0101  
 
void func( void )  
{
/* Destroy the setting of timer Z as timer mode */  
__DestroyTimer( RAPI_TIMER_Z );  
}
Rev.1.01  
2007.02.16  
63  
RJJ10J1643-0101  
 
__CreateEventCounter  
Synopsis  
<Set event counter mode>  
Boolean __CreateEventCounter(unsigned long data1, unsigned int data2,  
unsigned int data3, unsigned int data4, void* func)  
data1  
data2  
data3  
data4  
func  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Setup data 3 (content differs with MCU type)  
Setup data 4 (content differs with MCU type)  
Callback function pointer  
(Specify 0 if no callback functions are set.)  
Description  
Sets a specified timer to event counter mode.  
[data1]  
For data1, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_EV_EXTERNAL  
Uses timer A channel 0.  
Uses timer A channel 1.  
Uses timer A channel 2  
Uses timer A channel 3.  
Uses timer A channel 4.  
Uses timer B channel 0.  
Uses timer B channel 1.  
Uses timer B channel 2.  
Selects the external signal input to TAiIN pin (when using timer Ai)  
or TBiIN pin (when using timer Bi) for the count source.  
Selects overflow or underflow of timer Aj (j = i 1, however j = 4 if i =  
0) for the count source.  
RAPI_EV_TIMER_AJ  
RAPI_EV_TIMER_AK  
Selects overflow or underflow of timer Ak (k = i 1, however k = 0 if i  
= 4) for the count source.  
RAPI_EV_TIMER_B2  
RAPI_EV_TIMER_BJ  
Selects overflow or underflow of timer B2 for the count source.  
Selects overflow or underflow of timer Bj (j = i – 1, however j = 2 if i  
= 0) for the count source.  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_PULSE_ON  
RAPI_PULSE_OFF  
RAPI_AUTO_RELOAD  
RAPI_FREE_RUN  
RAPI_UP_COUNT  
RAPI_DOWN_COUNT  
Sets the timer to start operating in __CreateEventCounter.  
Sets the timer to stop operating in __CreateEventCounter.  
Selects that pulses are output from TAiIN pin.  
Selects that no pulses are output from TAiIN pin.  
Selects reload type for the count type.  
Selects free-run type for the count type.  
Selects up-count for the count operation.  
Selects down-count for the count operation.  
Rev.1.01  
2007.02.16  
64  
RJJ10J1643-0101  
 
RAPI_UDF_REGISTER Selects the UDF register for the cause of up/down switching.  
RAPI_TAIOUT  
Selects the input signal at TAiOUT pin for the cause of up/down  
switching.  
RAPI_RISING  
RAPI_FALLING  
RAPI_BOTH  
Selects the rising edge of count source as active edge.  
Selects the falling edge of count source as active edge.  
Selects both rising and falling edges of count source as active  
edges.  
• Specifiable definition values when timer A is used (RAPI_TIMER_A0 to RAPI_TIMER_A4  
specified)  
(Count source)  
Specify one from  
{
RAPI_EV_EXTERNAL, RAPI_EV_TIMER_AJ,  
RAPI_EV_TIMER_AK, RAPI_EV_TIMER_B2 }. The default value is  
RAPI_EV_EXTERNAL.  
(Operating  
states set)  
(Pulse output  
facility)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
Specify one from { RAPI_PULSE_ON, RAPI_PULSE_OFF }. The default  
value is RAPI_PULSE_OFF.  
(Gate facility)  
Specify one from { RAPI_GATE_L, RAPI_GATE_H }. If omitted, “No gate  
facility” is set.  
(Count type)  
Specify one from { RAPI_AUTO_RELOAD, RAPI_FREE_RUN }. The  
default value is RAPI_AUTO_RELOAD.  
(Count  
Specify one from { RAPI_UP_COUNT, RAPI_DOWN_COUNT }. The  
default value is RAPI_DOWN_COUNT. The count direction can only be set  
when the UDF register is used.  
direction)  
(Count direction Specify one from { RAPI_UDF_REGISTER, RAPI_TAIOUT }. The default  
switching)  
value is RAPI_UDF_REGISTER.  
(Count edge)  
Specify one from { RAPI_RISING, RAPI_FALLING }. The default value is  
RAPI_FALLING.  
• Specifiable definition values when timer B is used (RAPI_TIMER_B0 to RAPI_TIMER_B2  
specified)  
(Count source)  
Specify one from { RAPI_EV_EXTERNAL, RAPI_EV_TIMER_BJ }. The  
default value is RAPI_EV_EXTERNAL.  
(Operating  
states set)  
(Count edge)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
Specify one from { RAPI_RISING, RAPI_FALLING, RAPI_BOTH }. The  
default value is RAPI_FALLING.  
(R8C)  
RAPI_TIMER_X  
RAPI_TIMER_Y  
RAPI_TIMER_RA  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_WRITE_  
Uses timer X.  
Uses timer Y.  
Uses timer RA.  
Sets the timer to start operating in __CreateEventCounter.  
Sets the timer to stop operating in __CreateEventCounter.  
Selects operation mode in which writing to the primary register and  
prescaler causes the set data to be written to only the reload  
register.  
RELOAD_ ONLY  
Rev.1.01  
2007.02.16  
65  
RJJ10J1643-0101  
 
RAPI_WRITE_  
Selects operation mode in which writing to the primary register and  
prescaler causes the set data to be written to both the reload  
register and the counter, respectively.  
RELOAD_ BOTH  
RAPI_RISING  
Selects the rising edge of count source as active edge.  
Selects the falling edge of count source as active edge.  
Use sampling frequency f1 for digital filter function  
Use sampling frequency f8 for digital filter function  
Use sampling frequency f32 for digital filter function  
Sets count source input pin to P1_7.  
RAPI_FALLING  
RAPI_FILTER_F1  
RAPI_FILTER_F8  
RAPI_FILTER_F32  
RAPI_TIOSEL_P1_7  
RAPI_TIOSEL_P1_5  
RAPI_PULSE_ON  
RAPI_PULSE_OFF  
Sets count source input pin to P1_5.  
Selects that pulses are output from TRA0 pin.  
Selects that no pulses are output from TRA0 pin.  
• Specifiable definition values when timer X is used (RAPI_TIMER_X specified)  
(Operating  
states set)  
(Count edge)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
Specify one from { RAPI_RISING, RAPI_FALLING }. The default value is  
RAPI_FALLING.  
• Specifiable definition values when timer Y is used (RAPI_TIMER_Y specified)  
(Operating  
states set)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(Write control)  
Specify one from { RAPI_WRITE_RELOAD_ONLY,  
RAPI_WRITE_RELOAD_BOTH }.  
The default value is RAPI_WRITE_RELOAD_BOTH.  
Specify one from { RAPI_RISING, RAPI_FALLING }. The default value is  
RAPI_FALLING.  
(INT2/CNTR1  
input)  
• Specifiable definition values when timer RA is used (RAPI_TIMER_RA specified)  
(Operating  
states set)  
(Count edge)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
Specify one from { RAPI_RISING, RAPI_FALLING }. The default value is  
RAPI_FALLING.  
(Filter)  
Specify one from { RAPI_FILTER_F1, RAPI_FILTER_F8,  
RAPI_FILTER_F32}. The default value is no filter.  
Specify one from { RAPI_TIOSEL_P1_7, RAPI_TIOSEL_P1_5 }. The  
default value is RAPI_TIOSEL_P1_7.  
(Input pin)  
(Pulse  
output Specify one from { RAPI_PULSE_ON, RAPI_PULSE_OFF }. The default  
value is RAPI_PULSE_OFF.  
function)  
(H8/300H)  
RAPI_TIMER_B1  
RAPI_TIMER_V  
Uses timer B1.  
Uses timer V.  
RAPI_TIMER_ON  
Sets the timer to start operating in __CreateEventCounter.  
Sets the timer to stop operating in __CreateEventCounter.  
Enables overflow interrupt.  
RAPI_TIMER_OFF  
RAPI_OVERFLOW  
RAPI_AUTO_RELOAD  
Uses auto reload facility.  
Rev.1.01  
2007.02.16  
66  
RJJ10J1643-0101  
 
RAPI_RISING  
RAPI_FALLING  
RAPI_BOTH  
Selects the rising edge of count source as active edge.  
Selects the falling edge of count source as active edge.  
Selects both rising and falling edges of count source as active  
edges.  
RAPI_TRGV_RISING  
Selects the rising edge of TRGV pin input signal as active edge.  
RAPI_ TRGV_FALLING Selects the falling edge of TRGV pin input signal as active edge.  
RAPI_ TRGV_BOTH  
Selects both rising and falling edges of TRGV pin input signal as  
active edges.  
RAPI_TRGV_PROHIBI  
TED  
Selects that trigger input from TRGV pin is disabled.  
• Specifiable definition values when timer B1 is used (RAPI_TIMER_B1 specified)  
(Interrupt)  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
RAPI_OVERFLOW is not specified, “No overflow interrupt request” is set.  
To select the auto reload facility, specify RAPI_AUTO_RELOAD. If no  
interrupts are specified, “No interrupt request” is set.  
(Reload)  
(Count edge)  
Specify one from { RAPI_RISING, RAPI_FALLING }. The default value is  
RAPI_FALLING.  
• Specifiable definition values when timer V is used (RAPI_TIMER_V specified)  
(Interrupt)  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If no  
interrupts are specified, “No interrupt request” is set.  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(Operating  
states set)  
(Count edge)  
Specify one from { RAPI_RISING, RAPI_FALLING, RAPI_BOTH }. The  
default value is RAPI_FALLING.  
(TRGV  
input)  
pin Specify one from { RAPI_TRGV_RISING, RAPI_ TRGV_FALLING, RAPI_  
TRGV_BOTH, RAPI_TRGV_PROHIBIT }. The default value is RAPI_T  
RGV_PROHIBIT.  
[data2]  
(M16C) (R8C)  
Specify the interrupt priority level (07) to be set in the interrupt control register.  
(H8/300H)  
Specify the interrupt priority level (0–1) to be set in the interrupt control register. For  
the CPUs that do not have an interrupt control register, specify 0.  
[data3]  
(M16C)  
Specify the value to be set in the timer register in 16 bits.  
(R8C)  
When using timer X, specify the set value for the timer register; when using timer Y,  
specify the set value for the primary register in 8 bits.  
(H8/300H)  
Specify the set value for the timer reload register in 8 bits. This setting is effective  
only when timer B1 is used. If any timer other than B1 is used, specify 0.  
Rev.1.01  
2007.02.16  
67  
RJJ10J1643-0101  
 
[data4]  
(M16C) (H8/300H)  
Specify 0.  
(R8C)  
Specify the set value for the prescaler register in 8 bits.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (event counter mode)  
__EnableEventCounter, __DestroyEventCounter, __GetEventCounter  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable timers differ with each CPU used.  
When used for the H8/300H, this API specify when freeing it from module stanby  
state.  
Program example  
#include "rapi_timer_r8c_13.h"  
void TimerIntFunc( void ){}  
void func( void )  
{
/* Set up timer Y as event counter mode */  
__CreateEventCounter( RAPI_TIMER_Y|RAPI_TIMER_ON|RAPI_FALLING, 5,  
0x80, 0x80, TimerIntFunc );  
}
Rev.1.01  
2007.02.16  
68  
RJJ10J1643-0101  
 
__EnableEventCounter  
Synopsis  
<Control operation of event counter mode>  
Boolean __EnableEventCounter(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Controls operation of the timer that is set to specified timer mode by starting or  
stopping it.  
[data]  
For data, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_TIMER_ON  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2.  
Selects timer A channel 3.  
Selects timer A channel 4.  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
Sets the timer that is set to event counter mode to start  
operating.  
RAPI_TIMER_OFF  
Sets the timer that is set to event counter mode to stop  
operating.  
(R8C)  
RAPI_TIMER_X  
RAPI_TIMER_Y  
RAPI_TIMER_RA  
RAPI_TIMER_ON  
Selects timer X.  
Selects timer Y.  
Selects timer RA.  
Sets the timer that is set to event counter mode to start  
operating.  
RAPI_TIMER_OFF  
Sets the timer that is set to event counter mode to stop  
operating.  
(H8/300H)  
RAPI_TIMER_V  
Selects timer V.  
RAPI_TIMER_ON  
Sets the timer that is set to event counter mode to start  
operating.  
RAPI_TIMER_OFF  
Sets the timer that is set to event counter mode to stop  
operating.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Rev.1.01  
2007.02.16  
69  
RJJ10J1643-0101  
 
Functionality  
Reference  
Remark  
Timer (event counter mode)  
__CreateEventCounter, __DestroyEventCounter, __GetEventCounter  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c.h"  
void func( void )  
{
/* Disable timer Y as event counter mode */  
__EnableEventCounter( RAPI_TIMER_Y|RAPI_TIMER_OFF );  
}
Rev.1.01  
2007.02.16  
70  
RJJ10J1643-0101  
 
__DestroyEventCounter  
Synopsis  
<Discard settings of event counter mode>  
Boolean __DestroyEventCounter(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Discards settings of the timer that is set to specified timer mode.  
[data]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2.  
Selects timer A channel 3.  
Selects timer A channel 4.  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
(R8C)  
RAPI_TIMER_X  
RAPI_TIMER_Y  
RAPI_TIMER_RA  
Selects timer X.  
Selects timer Y.  
Selects timer RA.  
(H8/300H)  
RAPI_TIMER_B1  
RAPI_TIMER_V  
Selects timer B1.  
Selects timer V.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (event counter mode)  
__CreateEventCounter, __EnableEventCounter, __GetEventCounter  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
When used for the H8/300H, this API places a specified timer into module stanby  
state after discarding it.  
Program example  
#include "rapi_timer_r8c.h"  
Rev.1.01  
2007.02.16  
71  
RJJ10J1643-0101  
 
void func( void )  
{
/* Destroy the setting of timer Y as event counter mode */  
__DestroyEventCounter( RAPI_TIMER_Y );  
}
Rev.1.01  
2007.02.16  
72  
RJJ10J1643-0101  
 
__GetEventCounter  
Synopsis  
<Get event counter mode counter value>  
Boolean __GetEventCounter(unsigned long data1, unsigned int *data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Pointer to the buffer in which counter value is stored  
Description  
Gets the counter value of the timer that is set to specified event counter mode.  
[data1]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2.  
Selects timer A channel 3.  
Selects timer A channel 4.  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
(R8C)  
RAPI_TIMER_X  
RAPI_TIMER_Y  
RAPI_TIMER_RA  
Selects timer X.  
Selects timer Y.  
Selects timer RA.  
(H8/300H)  
RAPI_TIMER_B1  
RAPI_TIMER_V  
Selects timer B1.  
Selects timer V.  
[data2]  
Specify a pointer to the array in which the acquired counter value is stored.  
(M16C)  
• When using timer A (RAPI_TIMER_A0 to RAPI_TIMER_A4 specified)  
[0]: The value of timer Ai register (i = 0–4) is stored.  
• When using timer B (RAPI_TIMER_B0 to RAPI_TIMER_B2 specified)  
[0]: The value of timer Bi register (i = 0–2) is stored.  
(R8C)  
• When using timer X (RAPI_TIMER_X specified)  
[0]: The value of prescaler X register is stored.  
[1]: The value of timer X register is stored.  
• When using timer Y (RAPI_TIMER_Y specified)  
[0]: The value of prescaler Y is stored.  
[1]: The value of timer Y primary register is stored.  
• When using timer RA (RAPI_TIMER_RA specified)  
[0]: The value of timer RA prescaler register is stored.  
Rev.1.01  
2007.02.16  
73  
RJJ10J1643-0101  
 
[1]: The value of timer RA register is stored.  
(H8/300H)  
• When using timer B1 (RAPI_TIMER_B1 specified)  
[0]: The value of timer counter B1 is stored.  
• When using timer V (RAPI_TIMER_V specified)  
[0]: The value of timer counter V is stored.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (event counter mode)  
__CreateEventCounter, __EnableEventCounter, __DestroyEventCounter  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
unsigned int data[2];  
/* Get the counter of timer Y as event counter mode */  
__GetEventCounter(RAPI_TIMER_Y, data );  
}
Rev.1.01  
2007.02.16  
74  
RJJ10J1643-0101  
 
__CreatePulseWidthModulationMode  
Synopsis  
<Set pulse width modulation mode>  
Boolean __CreatePulseWidthModulationMode(unsigned long data1, unsigned int  
data2, unsigned int* data3, void* data4)  
data1  
data2  
data3  
func  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Setup data 3 (content differs with MCU type)  
Callback function pointer  
(Specify 0 if no callback functions are set.)  
Description  
Sets a specified timer to pulse width modulation mode.  
[data1]  
For data1, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_F1  
Uses timer A channel 0.  
Uses timer A channel 1.  
Uses timer A channel 2.  
Uses timer A channel 3.  
Uses timer A channel 4.  
Selects f1 for the count source.  
Selects f2 for the count source.  
Selects f8 for the count source.  
Selects f32 for the count source.  
Selects fC32 for the count source.  
Sets the timer to start operating in __CreatePulseWidthModulationMode.  
RAPI_F2  
RAPI_F8  
RAPI_F32  
RAPI_FC32  
RAPI_TIMER_ON  
RAPI_TIMER_OFF Sets the timer to stop operating in __CreatePulseWidthModulationMode.  
RAPI_TG_TAIIN  
RAPI_EV_  
Selects external trigger input from TAiIN pin for the count start condition.  
Selects overflow or underflow of timer Aj (j = i – 1, however j = 4 if i = 0)  
as the trigger for the timer to start counting.  
TIMER_AJ  
RAPI_EV_TIMER_ Selects overflow or underflow of timer Ak (k = i + 1, however k = 0 if i =  
AK 4) as the trigger for the timer to start counting.  
RAPI_EV_TIMER_ Selects overflow or underflow of timer B2 as the trigger for the timer to  
B2  
start counting.  
RAPI_TG_TAIS  
Only writing 1 to the TAiS bit of the TABSR register causes the timer to  
start counting.  
RAPI_PULSE_ON  
Selects that pulses are output from TAiIN pin. Selectable only when timer  
Ai is used.  
RAPI_PULSE_OFF Selects that no pulses are output from TAiIN pin. Selectable only when  
timer Ai is used.  
RAPI_PWM_16  
RAPI_PWM_8  
Selects operation as a 16-bit pulse width modulator.  
Selects operation as an 8-bit pulse width modulator.  
Rev.1.01  
2007.02.16  
75  
RJJ10J1643-0101  
 
RAPI_RISING  
Selects the rising edge of TAiIN pin input signal as active edge.  
Selects the falling edge of TAiIN pin input signal as active edge.  
RAPI_FALLING  
• Specifiable definition values when timer A is used (RAPI_TIMER_A0 to  
RAPI_TIMER_A4 specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F2, RAPI_F32, RAPI_FC32 }.  
The default value is RAPI_F2.  
(Operating states set) Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
(Count start condition) Specify one from { RAPI_TG_TAIS, RAPI_TG_TAIIN,  
RAPI_EV_TIMER_AJ, RAPI_EV_TIMER_AK,  
RAPI_EV_TIMER_B2 }. The default value is RAPI_TG_TAIIN.  
(Pulse output facility) Specify one from { RAPI_PULSE_ON, RAPI_PULSE_OFF }. The  
default value is RAPI_PULSE_OFF.  
(Modulator)  
Specify one from { RAPI_PWM_16, RAPI_PWM_8 }. The default  
value is RAPI_PWM_16.  
(TAiIN pin input)  
Specify one from { RAPI_RISING, RAPI_FALLING }. The default  
value is RAPI_FALLING. The active edge of TAiIN pin input can only  
be set when RAPI_TG_TAIIN is selected.  
(R8C)  
RAPI_TIMER_Y  
RAPI_TIMER_Z  
RAPI_TIMER_RB  
RAPI_F1  
Uses timer Y.  
Uses timer Z.  
Uses timer RB.  
Selects f1 for the count source.  
Selects f2 for the count source.  
Selects f8 for the count source.  
Selects fRING for the count source.  
Selects underflow of timer Y for the count source.  
RAPI_F2  
RAPI_F8  
RAPI_FRING  
RAPI_TIMER_Y_  
UNDERFLOW  
RAPI_TIMER_RA_ Selects underflow of timer RA for the count source.  
UNDERFLOW  
RAPI_TIMER_ON  
Sets the timer to start operating in __CreatePulseWidthModulationMode.  
RAPI_TIMER_OFF Sets the timer to stop operating in __CreatePulseWidthModulationMode.  
RAPI_H_L_L  
Sets to output a high during the primary period, a low during the  
secondary period, and a low when the timer is idle.  
RAPI_L_H_H  
Sets to output a low during the primary period, a high during the  
secondary period, and a high when the timer is idle.  
• Specifiable definition values when timer Y is used (RAPI_TIMER_Y specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F8, RAPI_FRING }. The default  
value is RAPI_F1.  
(Operating states set) Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
(Output)  
Specify one from { RAPI_H_L_L, RAPI_L_H_H }. The default value is  
RAPI_H_L_L.  
• Specifiable definition values when timer Z is used (RAPI_TIMER_Z specified)  
Rev.1.01  
2007.02.16  
76  
RJJ10J1643-0101  
 
(Count source)  
Specify one from { RAPI_F1, RAPI_F2, RAPI_F8,  
RAPI_TIMER_Y_UNDERFLOW}. The default value is RAPI_F1.  
(Operating states set) Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
(Output)  
Specify one from { RAPI_H_L_L, RAPI_L_H_H }. The default value is  
RAPI_H_L_L.  
• Specifiable definition values when timer RB is used (RAPI_TIMER_RB specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F2, RAPI_F8,  
RAPI_TIMER_RA_UNDERFLOW}. The default value is RAPI_F1.  
(Operating states set) Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
(Output)  
Specify one from { RAPI_H_L_L, RAPI_L_H_H }. The default value is  
RAPI_H_L_L.  
(H8/300H)  
RAPI_TIMER_V  
Uses timer V.  
RAPI_TV_F4  
RAPI_TV_F8  
RAPI_TV_F16  
RAPI_TV_F32  
RAPI_TV_F64  
RAPI_TV_F128  
Timer V counts on falling edges of internal clock φ/4.  
Timer V counts on falling edges of internal clock φ/8.  
Timer V counts on falling edges of internal clock φ/16.  
Timer V counts on falling edges of internal clock φ/32.  
Timer V counts on falling edges of internal clock φ/64.  
Timer V counts on falling edges of internal clock φ/128.  
RAPI_TIMER_ON Sets the timer to start operating in __CreatePulseWidthModulationMode.  
RAPI_TIMER_OFF Sets the timer to stop operating in __CreatePulseWidthModulationMode.  
RAPI_COMPARE  
_MATCH_A  
Enables compare match A interrupt.  
RAPI_COMPARE  
_MATCH_B  
Enables compare match B interrupt.  
RAPI_OUT_H_L  
Sets to output a high the during primary period and a low during the  
secondary period.  
RAPI_OUT_L_H  
Sets to output a low the during primary period and a high during the  
secondary period.  
RAPI_RISING  
RAPI_FALLING  
RAPI_BOTH  
Selects the rising edge of TRGV pin input signal as active edge.  
Selects the falling edge of TRGV pin input signal as active edge.  
Selects both rising and falling edges of TRGV pin input signal as active  
edge.  
RAPI_TRGV_RIS Selects the rising edge of TRGV pin input signal as active edge.  
ING  
RAPI_  
Selects the falling edge of TRGV pin input signal as active edge.  
TRGV_FALLING  
RAPI_  
Selects both rising and falling edges of TRGV pin input signal as active  
edges.  
TRGV_BOTH  
RAPI_TRGV_  
PROHIBITED  
Selects that trigger input from TRGV pin is disabled.  
Rev.1.01  
2007.02.16  
77  
RJJ10J1643-0101  
 
• Specifiable definition values when timer V is used (RAPI_TIMER_V specified)  
(Clock)  
Specify one from { RAPI_TV_F4, RAPI_TV_F8, RAPI_TV_F16,  
RAPI_TV_F32, RAPI_TV_F64, RAPI_TV_F128 }. If clock  
specification is omitted, specify “Disable clock input.”  
(Interrupt)  
If compare match  
A
interrupt requests are enabled, specify  
RAPI_COMPARE_MATCH_A. If compare match B interrupt requests  
are enabled, specify RAPI_COMPARE_MATCH_B. If no interrupts  
are specified, “No interrupt request” is set.  
(Operating states set) Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The  
default value is RAPI_TIMER_OFF.  
(Output)  
Specify one from { RAPI_OUT_H_L, RAPI_OUT_L_H }. Always be  
sure to specify this output.  
(TRGV pin input)  
Specify one from { RAPI_TRGV_RISING, RAPI_ TRGV_FALLING,  
RAPI_ TRGV_BOTH, RAPI_TRGV_PROHIBITED }.  
The default value is RAPI_TRGV_PROHIBITED.  
[data2]  
(M16C) (R8C)  
Specify the interrupt priority level (07) to be set in the interrupt control register.  
(H8/300H)  
Specify the interrupt priority level (0–1) to be set in the interrupt control register.  
For the CPUs that do not have an interrupt control register, specify 0.  
[data3]  
(M16C)  
Specify a pointer to the 16-bit variable in which the set value for the timer register is  
stored.  
For 16-bit PWM, specify the value of ‘n’ in “high-level width n/fj, period 65535/fj” in  
16 bits.  
For 8-bit PWM, specify the values of ‘n’ and ‘m’ in “high-level width n (m + 1)/f,  
period 255 (m + 1)/fj” in the 8 high-order bits and the 8 low-order bits, respectively.  
(R8C)  
Specify a pointer to the array in which the set value is stored.  
[0]: Specify the set value for the primary register in 8 bits.  
[1]: Specify the set value for the secondary register in 8 bits.  
[2]: Specify the set value for the prescaler in 8 bits.  
(H8/300H)  
Specify a pointer to the array in which the set value is stored.  
[0]: Specify the comparison value A in 8 bits.  
[1]: Specify the comparison value B in 8 bits.  
Return value  
Functionality  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Timer (pulse width modulation mode (PWM mode))  
Rev.1.01  
2007.02.16  
78  
RJJ10J1643-0101  
 
Reference  
Remark  
__EnablePulseWidthModulationMode, __DestroyPulseWidthModulationMode  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable timers differ with each CPU used.  
For the H8/300H, make sure that comparison value A < comparison value B.  
When used for the H8/300H, this API specify when freeing it from module stanby  
state.  
Program example  
#include "rapi_timer_r8c_13.h"  
void TimerIntFunc( void ){}  
void func( void )  
{
unsigned int p_tim[] = {0xAA, 0xBB, 0xCC};  
/* Set up timer Z as pulse width modulation mode */  
__CreatePulseWidthModulationMode( RAPI_TIMER_Z|RAPI_TIMER_ON|RAPI_F8,  
5, p_tim, TimerIntFunc);  
}
Rev.1.01  
2007.02.16  
79  
RJJ10J1643-0101  
 
__EnablePulseWidthModulationMode  
Synopsis  
<Control operation of pulse width modulation mode>  
Boolean __EnablePulseWidthModulationMode(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Controls operation of the timer that is set to specified pulse width modulation mode by  
starting or stopping it.  
[data]  
For data, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_ON  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2.  
Selects timer A channel 3.  
Selects timer A channel 4.  
Sets the timer that is set to pulse width modulation mode to  
start operating.  
RAPI_TIMER_OFF  
Sets the timer that is set to pulse width modulation mode to  
stop operating.  
(R8C)  
RAPI_TIMER_Y  
RAPI_TIMER_Z  
RAPI_TIMER_RB  
RAPI_TIMER_ON  
Selects timer Y.  
Selects timer Z.  
Selects timer RB.  
Sets the timer that is set to pulse width modulation mode to  
start operating.  
RAPI_TIMER_OFF  
Sets the timer that is set to pulse width modulation mode to  
stop operating.  
(H8/300H)  
RAPI_TIMER_V  
Selects timer V.  
RAPI_TIMER_ON  
Sets the timer that is set to pulse width modulation mode to  
start operating.  
RAPI_TIMER_OFF  
Sets the timer that is set to pulse width modulation mode to  
stop operating.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Timer (pulse width modulation mode (PWM mode))  
__CreatePulseWidthModulationMode, __DestroyPulseWidthModulationMode  
Rev.1.01  
2007.02.16  
80  
RJJ10J1643-0101  
 
Remark  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
/* Enable timer Y as pulse width modulation mode */  
__EnablePulseWidthModulationMode( RAPI_TIMER_Y|RAPI_TIMER_ON );  
}
Rev.1.01  
2007.02.16  
81  
RJJ10J1643-0101  
 
__DestroyPulseWidthModulationMode  
Synopsis  
<Discard settings of pulse width modulation mode>  
Boolean __DestroyPulseWidthModulationMode(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Discards settings of the timer that is set to specified pulse width modulation mode.  
[data]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2.  
Selects timer A channel 3.  
Selects timer A channel 4.  
(R8C)  
RAPI_TIMER_Y  
RAPI_TIMER_Z  
RAPI_TIMER_RB  
Selects timer Y.  
Selects timer Z.  
Selects timer RB.  
(H8/300H)  
RAPI_TIMER_V  
Selects timer V.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (pulse width modulation mode (PWM mode))  
__CreatePulseWidthModulationMode, __EnablePulseWidthModulationMode  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
When used for the H8/300H, this API places a specified timer into module stanby  
state after discarding it.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
/* Destroy the setting of timer Z as pulse width modulation mode */  
__DestroyPulseWidthModulationMode( RAPI_TIMER_Z );  
}
Rev.1.01  
2007.02.16  
82  
RJJ10J1643-0101  
 
__CreatePulsePeriodMeasurementMode  
Synopsis  
<Set pulse period measurement mode>  
Boolean __CreatePulsePeriodMeasurementMode(unsigned long data1, unsigned  
int data2, unsigned int data3, unsigned int data4, void* func)  
data1  
data2  
data3  
data4  
func  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Setup data 3 (content differs with MCU type)  
Setup data 4 (content differs with MCU type)  
Callback function pointer  
(Specify 0 if no callback functions are set.)  
Description  
Sets a specified timer to pulse period measurement mode.  
[data1]  
For data1, the following definition values can be set. To set multiple definition values at the  
same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_F1  
Uses timer B channel 0.  
Uses timer B channel 1.  
Uses timer B channel 2.  
Selects f1 for the count source.  
RAPI_F2  
Selects f2 for the count source.  
RAPI_F8  
Selects f8 for the count source.  
RAPI_F32  
Selects f32 for the count source.  
Selects fC32 for the count source.  
Sets the timer to start operating in  
__CreatePulsePeriodMeasurementMode.  
Sets the timer to stop operating in  
__CreatePulsePeriodMeasurementMode.  
Selects measurement of an interval from the rise to the next rise of a  
measurement pulse.  
RAPI_FC32  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_RISING_  
RISING  
RAPI_FALLING_  
FALLING  
Selects measurement of an interval from the fall to the next fall of a  
measurement pulse.  
• Specifiable definition values when timer B is used (RAPI_TIMER_B0 to RAPI_TIMER_B2  
specified)  
(Count source)  
Specify one from  
{
RAPI_F1, RAPI_F2, RAPI_F8, RAPI_F32,  
RAPI_FC32 }. The default value is RAPI_F2.  
states Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(Operating  
set)  
(Measurement  
pulse)  
Specify one from { RAPI_RISING_RISING, RAPI_FALLING_FALLING }.  
The default value is RAPI_FALLING_FALLING.  
(R8C)  
RAPI_TIMER_X  
Uses timer X.  
Rev.1.01  
2007.02.16  
83  
RJJ10J1643-0101  
 
RAPI_TIMER_RA  
RAPI_F1  
Uses timer RA.  
Selects f1 for the count source.  
RAPI_F2  
Selects f2 for the count source.  
RAPI_F8  
Selects f8 for the count source.  
RAPI_F32  
Selects f32 for the count source.  
RAPI_FC32  
Selects fC32 for the count source.  
RAPI_FOCO  
Selects fOCO for the count source.  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_RISING_  
RISING  
Sets the timer to start operating in __CreatePulsePeriodMeasurementMode.  
Sets the timer to stop operating in __CreatePulsePeriodMeasurementMode.  
Selects measurement of an interval from the rise to the next rise of a  
measurement pulse.  
RAPI_FALLING_  
FALLING  
Selects measurement of an interval from the fall to the next fall of a  
measurement pulse.  
RAPI_FILTER_F1  
RAPI_FILTER_F8  
RAPI_FILTER_F32  
RAPI_TIOSEL_P1_7  
RAPI_TIOSEL_P1_5  
Use sampling frequency f1 for digital filter function  
Use sampling frequency f8 for digital filter function  
Use sampling frequency f32 for digital filter function  
Sets count source input pin to P1_7.  
Sets count source input pin to P1_5.  
• Specifiable definition values when timer X is used (RAPI_TIMER_X specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F2, RAPI_F8, RAPI_F32 }. The  
default value is RAPI_F1.  
(Operating  
set)  
states Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(Measurement  
pulse)  
Specify one from { RAPI_RISING_RISING, RAPI_FALLING_FALLING }.  
The default value is RAPI_FALLING_FALLING.  
• Specifiable definition values when timer RA is used (RAPI_TIMER_RA specified)  
(Count source)  
Specify one from  
{
RAPI_F1, RAPI_F2, RAPI_F8, RAPI_F32,  
RAPI_FOCO }. The default value is RAPI_F1.  
states Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(Operating  
set)  
(Measure pulse)  
Specify one from { RAPI_RISING_RISING, RAPI_FALLING_FALLING }.  
The default value is RAPI_FALLING_FALLING.  
(Filter)  
Specify one from { RAPI_FILTER_F1, RAPI_FILTER_F8,  
RAPI_FILTER_F32}. The default value is no filter.  
(Input pin)  
Specify one from { RAPI_TIOSEL_P1_7, RAPI_TIOSEL_P1_5 }. The  
default value is RAPI_TIOSEL_P1_7.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RD2  
Uses timer W.  
Uses timer Z channel 0.  
Uses timer Z channel 1.  
Uses timer RC.  
Uses timer RD0 channel 0.  
Uses timer RD0 channel 1.  
Uses timer RD0 channel 2.  
Rev.1.01  
2007.02.16  
84  
RJJ10J1643-0101  
 
RAPI_TIMER_RD3  
RAPI_TW_F1  
RAPI_TW_F2  
RAPI_TW_F4  
RAPI_TW_F8  
RAPI_TZ_F1  
RAPI_TZ_F2  
RAPI_TZ_F4  
RAPI_TZ_F8  
RAPI_TRC_F1  
Uses timer RD0 channel 3.  
Timer W counts with internal clock φ.  
Timer W counts with internal clock φ/2.  
Timer W counts with internal clockφ/4.  
Timer W counts with internal clock φ/8.  
Timer Z counts with internal clock φ.  
Timer Z counts with internal clock φ/2.  
Timer Z counts with internal clock φ/4.  
Timer Z counts with internal clock φ/8.  
Timer RC counts with internal clock φ.  
RAPI_TRC_F2  
Timer RC counts with internal clock φ/2.  
Timer RC counts with internal clockφ/4.  
Timer RC counts with internal clock φ/8.  
Timer RC counts with internal clock φ/8.  
Timer RC counts with internal clock φ40M.  
Timer RD counts with internal clock φ.  
RAPI_TRC_F4  
RAPI_TRC_F8  
RAPI_TRC_F32  
RAPI_TRC_F40M  
RAPI_TRD_F1  
RAPI_TRD_F2  
Timer RD counts with internal clock φ/2.  
Timer RD counts with internal clockφ/4.  
Timer RD counts with internal clock φ/8.  
Timer RD counts with internal clock φ/32.  
Timer RD counts with internal clock φ40M.  
Sets the timer to start operating in __CreatePulsePeriodMeasurementMode.  
Sets the timer to stop operating in __CreatePulsePeriodMeasurementMode.  
Enables overflow interrupt.  
RAPI_TRD_F4  
RAPI_TRD_F8  
RAPI_TRD_F32  
RAPI_TRD_F40M  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_OVERFLOW  
RAPI_RISING_  
RISING  
Selects measurement of an interval from the rise to the next rise of a  
measurement pulse.  
RAPI_FALLING_  
FALLING  
Selects measurement of an interval from the fall to the next fall of a  
measurement pulse.  
RAPI_TRC_FILTER_F  
1
Use sampling frequency f1 for timer RC digital filter function  
RAPI_TRC_FILTER_F  
8
Use sampling frequency f8 for timer RC digital filter function  
Use sampling frequency f32 for timer RC digital filter function  
RAPI_TRC_FILTER_F  
32  
RAPI_TRD_FILTER_F  
RAPI_TRD_FILTER_F  
1
Use sampling frequency f for timer RC digital filter function  
Use sampling frequency f1 for timer RD digital filter function  
RAPI_TRD_FILTER_F  
8
Use sampling frequency f8 for timer RD digital filter function  
Use sampling frequency f32 for timer RD digital filter function  
RAPI_TRD_FILTER_F  
32  
RAPI_TRD_FILTER_F  
RAPI_FTIOA  
Use sampling frequency f for timer RD digital filter function  
Use FTIOA pin as input pin.  
Rev.1.01  
2007.02.16  
85  
RJJ10J1643-0101  
 
RAPI_FTIOB  
Use FTIOB pin as input pin.  
• Specifiable definition values when timer W is used (RAPI_TIMER_W specified)  
(Count source)  
Specify one from  
{
RAPI_TW_F1, RAPI_TW_F2, RAPI_TW_F4,  
RAPI_TW_F8 }. The default value is RAPI_TW_F1.  
states Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(Operating  
set)  
(Measurement  
pulse)  
Specify one from { RAPI_RISING_RISING, RAPI_FALLING_FALLING }.  
The default value is RAPI_RISING_RISING.  
(Interrupt)  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
no interrupts are specified, “No interrupt request” is set.  
• Specifiable definition values when timer Z is used (RAPI_TIMER_Z0 to RAPI_TIMER_Z1  
specified)  
(Count source)  
Specify one from { RAPI_TZ_F1, RAPI_TZ_F2, RAPI_TZ_F4,  
RAPI_TZ_F8 }. The default value is RAPI_TZ_F1.  
(Operating  
set)  
states Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(Measurement  
pulse)  
Specify one from { RAPI_RISING_RISING, RAPI_FALLING_FALLING }.  
The default value is RAPI_RISING_RISING.  
(Interrupt)  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
no interrupts are specified, “No interrupt request” is set.  
Specify one from { RAPI_FTIOA, RAPI_FTIOB }. The default value is  
RAPI_FTIOA.  
(Input pin)  
• Specifiable definition values when timer RC is used (RAPI_TIMER_RC specified)  
(Count source)  
Specify one from { RAPI_TRC_F1, RAPI_TRC_F2, RAPI_TRC_F4,  
RAPI_TRC_F8, RAPI_TRC_F32 }. The default value is RAPI_RC_F1.  
states Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(Operating  
set)  
(Measurement  
pulse)  
Specify one from { RAPI_RISING_RISING, RAPI_FALLING_FALLING }.  
The default value is RAPI_RISING_RISING.  
(Interrupt)  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
no interrupts are specified, “No interrupt request” is set.  
Specify one from { RAPI_FTIOA, RAPI_FTIOB }. The default value is  
RAPI_FTIOA.  
(Input pin)  
(Clock for digital Specify one from { RAPI_TRC_FILTER_F1, RAPI_TRC_FILTER_F8,  
filter)  
RAPI_TRC_FILTER_F32, RAPI_TRC_FILTER_F }. The default value is  
RAPI_TRC_FILTER_F32.  
• Specifiable definition values when timer RD is used (RAPI_TIMER_RD specified)  
(Count source)  
Specify one from { RAPI_TRD_F1, RAPI_TRD_F2, RAPI_TRD_F4,  
RAPI_TRD_F8, RAPI_TRD_F32, RAPI_TRD_F40M }. The default value  
is RAPI_RC_F1.  
(Operating  
set)  
states Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(Measurement  
pulse)  
Specify one from { RAPI_RISING_RISING, RAPI_FALLING_FALLING }.  
The default value is RAPI_RISING_RISING.  
Rev.1.01  
2007.02.16  
86  
RJJ10J1643-0101  
 
(Interrupt)  
(Input pin)  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
no interrupts are specified, “No interrupt request” is set.  
Specify one from { RAPI_FTIOA, RAPI_FTIOB }. The default value is  
RAPI_FTIOA.  
(Clock for digital Specify one from { RAPI_TRC_FILTER_F1, RAPI_TRC_FILTER_F8,  
filter)  
RAPI_TRC_FILTER_F32, RAPI_TRC_FILTER_F }. The default value is  
RAPI_TRC_FILTER_F32.  
[data2]  
(M16C) (R8C)  
Specify the interrupt priority level (07) to be set in the interrupt control register.  
(H8/300H)  
Specify the interrupt priority level (0–1) to be set in the interrupt control register. For  
the CPUs that do not have an interrupt control register, specify 0.  
[data3]  
(M16C) (H8/300H)  
Specify 0.  
(R8C)  
When using timer X, specify the set value for the timer register.  
[data4]  
(M16C) (H8/300H)  
Specify 0.  
(R8C)  
Specify the set value for the prescaler register.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE is  
returned.  
Functionality  
Reference  
Timer (pulse period measurement mode)  
__EnablePulsePeriodMeasurementMode, __DestroyPulsePeriodMeasurementMode,  
__GetPulsePeriodMeasurementMode  
Remark  
If an undefined value is specified in the first argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
When used for the H8/300H, this API specify when freeing it from module stanby  
state.  
Program example  
#include "rapi_timer_r8c_13.h"  
void TimerIntFunc( void ){}  
void func( void )  
{
/* Set up timer X as pulse period measurement mode */  
__CreatePulsePeriodMeasurementMode(  
RAPI_TIMER_X|RAPI_TIMER_ON|RAPI_FALLING_FALLING|RAPI_F8,  
5, 0x80, 0x80, TimerIntFunc);  
}
Rev.1.01  
2007.02.16  
87  
RJJ10J1643-0101  
 
__EnablePulsePeriodMeasurementMode  
Synopsis  
<Control operation of pulse period measurement mode>  
Boolean __EnablePulsePeriodMeasurementMode(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Controls operation of the timer that is set to specified pulse period measurement mode  
by starting or stopping it.  
[data]  
For data, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_TIMER_ON  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
Sets the timer that is set to pulse period measurement mode to start  
operating.  
RAPI_TIMER_OFF Sets the timer that is set to pulse period measurement mode to stop  
operating.  
(R8C)  
RAPI_TIMER_X  
Selects timer X.  
RAPI_TIMER_RA  
RAPI_TIMER_ON  
Selects timer RA.  
Sets the timer that is set to pulse period measurement mode to start  
operating.  
RAPI_TIMER_  
OFF  
Sets the timer that is set to pulse period measurement mode to stop  
operating.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD  
0
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RC.  
Selects timer RD channel 0.  
RAPI_TIMER_RD  
1
Selects timer RD channel 1.  
Selects timer RD channel 2.  
Selects timer RD channel 3.  
RAPI_TIMER_RD  
2
RAPI_TIMER_RD  
3
RAPI_TIMER_ON  
Sets the timer that is set to pulse period measurement mode to start  
operating.  
Rev.1.01  
2007.02.16  
88  
RJJ10J1643-0101  
 
RAPI_TIMER_  
OFF  
Sets the timer that is set to pulse period measurement mode to stop  
operating.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Timer (pulse period measurement mode)  
__CreatePulsePeriodMeasurementMode, __DestroyPulsePeriodMeasurementMode,  
__GetPulsePeriodMeasurementMode  
Remark  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
/* Enable timer X as pulse period measurement mode */  
__EnablePulsePeriodMeasurementMode( RAPI_TIMER_X|RAPI_TIMER_ON );  
}
Rev.1.01  
2007.02.16  
89  
RJJ10J1643-0101  
 
__DestroyPulsePeriodMeasurementMode  
Synopsis  
<Discard settings of pulse period measurement mode>  
Boolean __DestroyPulsePeriodMeasurementMode(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Discards settings of the timer that is set to specified pulse period measurement mode.  
[data]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
(R8C)  
RAPI_TIMER_X  
Selects timer X.  
RAPI_TIMER_RA  
Selects timer RA.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD  
0
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RC.  
Selects timer RD channel 0.  
RAPI_TIMER_RD  
1
Selects timer RD channel 1.  
Selects timer RD channel 2.  
Selects timer RD channel 3.  
RAPI_TIMER_RD  
2
RAPI_TIMER_RD  
3
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Timer (pulse period measurement mode)  
__CreatePulsePeriodMeasurementMode, __EnablePulsePeriodMeasurementMode,  
__GetPulsePeriodMeasurementMode  
Remark  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
Rev.1.01  
2007.02.16  
90  
RJJ10J1643-0101  
 
When used for the H8/300H, this API places a specified timer into module stanby  
state after discarding it.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
/* Destroy the setting of timer X as pulse period measurement mode */  
__DestroyPulsePeriodMeasurementMode( RAPI_TIMER_X );  
}
Rev.1.01  
2007.02.16  
91  
RJJ10J1643-0101  
 
__GetPulsePeriodMeasurementMode  
Synopsis  
<Get measured value in pulse period measurement mode>  
Boolean __GetPulsePeriodMeasurementMode(unsigned long data1, unsigned  
int *data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Pointer to the buffer in which counter value is stored  
Description  
Gets the counter value of the timer that is set to specified pulse period measurement  
mode.  
[data1]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
(R8C)  
RAPI_TIMER_X  
Selects timer X.  
RAPI_TIMER_RA  
Selects timer RA.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD  
0
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RC.  
Selects timer RD channel 0.  
RAPI_TIMER_RD  
1
Selects timer RD channel 1.  
Selects timer RD channel 2.  
Selects timer RD channel 3.  
RAPI_TIMER_RD  
2
RAPI_TIMER_RD  
3
[data2]  
Specify a pointer to the array in which the acquired counter value is stored.  
(M16C)  
• When using timer B (RAPI_TIMER_B0 to RAPI_TIMER_B2 specified)  
[0]: The value of timer Bi register (i = 0–2) is stored.  
(R8C)  
• When using timer X (RAPI_TIMER_X specified)  
[0]: The value of prescaler X register is stored.  
[1]: The value of timer X register is stored.  
• When using timer RA (RAPI_TIMER_RA specified)  
Rev.1.01  
2007.02.16  
92  
RJJ10J1643-0101  
 
[0]: The value of timer RA prescaler register is stored.  
[1]: The value of timer RA register is stored.  
(H8/300H)  
• When using timer W (RAPI_TIMER_W specified)  
[0]: (The value of general register A) – (The value of general register C) is stored.  
[1]: (The value of general register B) – (The value of general register D) is stored.  
• When using timer Z (RAPI_TIMER_Z0 - RAPI_TIMER_Z1 specified)  
[0]: (The value of general register Ai(i=0,1)) – (The value of general register C  
i(i=0,1)) is stored.  
[1]: (The value of general register B i(i=0,1)) – (The value of general register D  
i(i=0,1)) is stored.  
• When using timer RC (RAPI_TIMER_RC specified)  
[0]: (The value of general register A) – (The value of general register C) is stored.  
[1]: (The value of general register B) – (The value of general register D) is stored.  
• When using timer RD (RAPI_TIMER_RD specified)  
[0]: (The value of general register A) – (The value of general register C) is stored.  
[1]: (The value of general register B) – (The value of general register D) is stored.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Timer (pulse period measurement mode)  
__CreatePulsePeriodMeasurementMode, __EnablePulsePeriodMeasurementMode,  
__DestroyPulsePeriodMeasurementMode  
Remark  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
unsigned int data[2];  
/* Get the measured value of timer X as pulse period measurement mode  
*/  
__GetPulsePeriodMeasurementMode( RAPI_TIMER_X, data );  
}
Rev.1.01  
2007.02.16  
93  
RJJ10J1643-0101  
 
__CreatePulseWidthMeasurementMode  
Synopsis  
<Set pulse width measurement mode>  
Boolean __CreatePulseWidthMeasurementMode(unsigned long data1, unsigned  
int data2, unsigned int data3, unsigned int data4, void* func)  
data1  
data2  
data3  
data4  
func  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Setup data 3 (content differs with MCU type)  
Setup data 4 (content differs with MCU type)  
Callback function pointer  
(Specify 0 if no callback functions are set.)  
Description  
Sets a specified timer to pulse with measurement mode.  
[data1]  
For data1, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_F1  
Uses timer B channel 0.  
Uses timer B channel 1.  
Uses timer B channel 2.  
Selects f1 for the count source.  
Selects f2 for the count source.  
Selects f8 for the count source.  
Selects f32 for the count source.  
Selects fC32 for the count source.  
Sets the timer to start operating in  
__CreatePulseWidthMeasurementMode.  
RAPI_F2  
RAPI_F8  
RAPI_F32  
RAPI_FC32  
RAPI_TIMER_ON  
RAPI_TIMER_OFF Sets the timer to stop operating in  
__CreatePulseWidthMeasurementMode.  
• Specifiable definition values when timer B is used (RAPI_TIMER_B0 to  
RAPI_TIMER_B2 specified)  
(Count source) Specify one from { RAPI_F1, RAPI_F2, RAPI_F8, RAPI_F32, RAPI_FC32 }.  
The default value is RAPI_F2.  
(Operating  
states set)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
(R8C)  
RAPI_TIMER_X  
RAPI_TIMER_RA  
RAPI_F1  
Uses timer X.  
Uses timer RA.  
Selects f1 for the count source.  
Selects f2 for the count source.  
Selects f8 for the count source.  
Selects f32 for the count source.  
Selects fC32 for the count source.  
RAPI_F2  
RAPI_F8  
RAPI_F32  
RAPI_FC32  
Rev.1.01  
2007.02.16  
94  
RJJ10J1643-0101  
 
RAPI_FOCO  
Selects fOCO for the count source.  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_RISING_  
RISING  
Sets the timer to start operating in __CreatePulsePeriodMeasurementMode.  
Sets the timer to stop operating in __CreatePulsePeriodMeasurementMode.  
Selects measurement of an interval from the rise to the next rise of a  
measurement pulse.  
RAPI_FALLING_  
FALLING  
Selects measurement of an interval from the fall to the next fall of a  
measurement pulse.  
RAPI_FILTER_F1  
RAPI_FILTER_F8  
Use sampling frequency f1 for digital filter function  
Use sampling frequency f8 for digital filter function  
RAPI_FILTER_F32 Use sampling frequency f32 for digital filter function  
RAPI_TIOSEL_P1  
Sets count source input pin to P1_7.  
_7  
RAPI_TIOSEL_P1  
_5  
Sets count source input pin to P1_5.  
• Specifiable definition values when timer X is used (RAPI_TIMER_X specified)  
(Count source) Specify one from { RAPI_F1, RAPI_F2, RAPI_F8, RAPI_F32 }. The default  
value is RAPI_F1.  
(Operating  
states set)  
(Measurement  
pulse)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
Specify one from { RAPI_FALLING_RISING, RAPI_RISING_FALLING }.  
The default value is RAPI_FALLING_RISING.  
• Specifiable definition values when timer RA is used (RAPI_TIMER_RA specified)  
(Count source) Specify one from RAPI_F1, RAPI_F2, RAPI_F8, RAPI_F32,  
{
RAPI_FOCO }. The default value is RAPI_F1.  
(Operating  
states set)  
(Measure  
pulse)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
Specify one from { RAPI_RISING_RISING, RAPI_FALLING_FALLING }.  
The default value is RAPI_FALLING_FALLING.  
(Filter)  
Specify one from { RAPI_FILTER_F1, RAPI_FILTER_F8,  
RAPI_FILTER_F32}. The default value is no filter.  
(Input pin)  
Specify one from { RAPI_TIOSEL_P1_7, RAPI_TIOSEL_P1_5 }. The  
default value is RAPI_TIOSEL_P1_7.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
Uses timer W.  
Uses timer Z channel 0.  
Uses timer Z channel 1.  
Uses timer RC.  
RAPI_TIMER_RD0 Uses timer RD0 channel 0.  
RAPI_TIMER_RD1 Uses timer RD0 channel 1.  
RAPI_TIMER_RD2 Uses timer RD0 channel 2.  
RAPI_TIMER_RD3 Uses timer RD0 channel 3.  
RAPI_TW_F1  
RAPI_TW_F2  
RAPI_TW_F4  
Timer W counts with internal clock φ.  
Timer W counts with internal clock φ/2.  
Timer W counts with internal clock φ/4.  
Rev.1.01  
2007.02.16  
95  
RJJ10J1643-0101  
 
RAPI_TW_F8  
RAPI_TZ_F1  
RAPI_TZ_F2  
RAPI_TZ_F4  
RAPI_TZ_F8  
RAPI_TRC_F1  
RAPI_TRC_F2  
RAPI_TRC_F4  
RAPI_TRC_F8  
RAPI_TRC_F32  
RAPI_TRC_F40M  
RAPI_TRD_F1  
RAPI_TRD_F2  
RAPI_TRD_F4  
RAPI_TRD_F8  
RAPI_TRD_F32  
RAPI_TRD_F40M  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_OVERFLOW  
RAPI_RISING_  
RISING  
Timer W counts with internal clock φ/8.  
Timer Z counts with internal clock φ.  
Timer Z counts with internal clock φ/2.  
Timer Z counts with internal clock φ/4.  
Timer Z counts with internal clock φ/8.  
Timer RC counts with internal clock φ.  
Timer RC counts with internal clock φ/2.  
Timer RC counts with internal clockφ/4.  
Timer RC counts with internal clock φ/8.  
Timer RC counts with internal clock φ/8.  
Timer RC counts with internal clock φ40M.  
Timer RD counts with internal clock φ.  
Timer RD counts with internal clock φ/2.  
Timer RD counts with internal clockφ/4.  
Timer RD counts with internal clock φ/8.  
Timer RD counts with internal clock φ/32.  
Timer RD counts with internal clock φ40M.  
Sets the timer to start operating in __CreatePulsePeriodMeasurementMode.  
Sets the timer to stop operating in __CreatePulsePeriodMeasurementMode.  
Enables overflow interrupt.  
Selects measurement of an interval from the rise to the next rise of a  
measurement pulse.  
RAPI_FALLING_  
FALLING  
Selects measurement of an interval from the fall to the next fall of a  
measurement pulse.  
RAPI_TRC_FILTE  
R_F1  
Use sampling frequency f1 for timer RC digital filter function  
RAPI_TRC_FILTE  
R_F8  
Use sampling frequency f8 for timer RC digital filter function  
Use sampling frequency f32 for timer RC digital filter function  
Use sampling frequency f for timer RC digital filter function  
Use sampling frequency f1 for timer RD digital filter function  
Use sampling frequency f8 for timer RD digital filter function  
Use sampling frequency f32 for timer RD digital filter function  
Use sampling frequency f for timer RD digital filter function  
RAPI_TRC_FILTE  
R_F32  
RAPI_TRD_FILTE  
R_F  
RAPI_TRD_FILTE  
R_F1  
RAPI_TRD_FILTE  
R_F8  
RAPI_TRD_FILTE  
R_F32  
RAPI_TRD_FILTE  
R_F  
RAPI_FTIOA  
RAPI_FTIOB  
Use FTIOA pin as input pin.  
Use FTIOB pin as input pin.  
• Specifiable definition values when timer W is used (RAPI_TIMER_W specified)  
Rev.1.01  
2007.02.16  
96  
RJJ10J1643-0101  
 
(Count source) Specify one from { RAPI_TW_F1, RAPI_TW_F2, RAPI_TW_F4,  
RAPI_TW_F8 }. The default value is RAPI_TW_F1.  
(Operating  
states set)  
(Interrupt)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If no  
interrupts are specified, No interrupt requestis set.  
• Specifiable definition values when timer Z is used (RAPI_TIMER_Z0 to  
RAPI_TIMER_Z1 specified)  
(Count source) Specify one from { RAPI_TZ_F1, RAPI_TZ_F2, RAPI_TZ_F4,  
RAPI_TZ_F8 }. The default value is RAPI_TZ_F1.  
(Operating  
states set)  
(Interrupt)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If no  
interrupts are specified, “No interrupt request” is set.  
Specify one from { RAPI_FTIOA, RAPI_FTIOB }. The default value is  
RAPI_FTIOA.  
(Input pin)  
• Specifiable definition values when timer RC is used (RAPI_TIMER_RC specified)  
(Count  
Specify one from { RAPI_TRC_F1, RAPI_TRC_F2, RAPI_TRC_F4,  
RAPI_TRC_F8, RAPI_TRC_F32, RAPI_TRC_F40M }. The default value is  
RAPI_RC_F1.  
source)  
(Operating  
states set)  
(Interrupt)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If no  
interrupts are specified, “No interrupt request” is set.  
Specify one from { RAPI_FTIOA, RAPI_FTIOB }. The default value is  
RAPI_FTIOA.  
(Input pin)  
(Clock  
for Specify one from  
{
RAPI_TRC_FILTER_F1, RAPI_TRC_FILTER_F8,  
digital filter)  
RAPI_TRC_FILTER_F32, RAPI_TRC_FILTER_F }. The default value is  
RAPI_TRC_FILTER_F32.  
• Specifiable definition values when timer RD is used (RAPI_TIMER_RD specified)  
(Count  
Specify one from { RAPI_TRD_F1, RAPI_TRD_F2, RAPI_TRD_F4,  
RAPI_TRD_F8, RAPI_TRD_F32, RAPI_TRD_F40M }. The default value is  
RAPI_RC_F1.  
source)  
(Operating  
states set)  
(Interrupt)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If no  
interrupts are specified, “No interrupt request” is set.  
Specify one from { RAPI_FTIOA, RAPI_FTIOB }. The default value is  
RAPI_FTIOA.  
(Input pin)  
(Clock  
for Specify one from  
{
RAPI_TRC_FILTER_F1, RAPI_TRC_FILTER_F8,  
digital filter)  
RAPI_TRC_FILTER_F32, RAPI_TRC_FILTER_F }. The default value is  
RAPI_TRC_FILTER_F32.  
[data2]  
(M16C) (R8C)  
Rev.1.01  
2007.02.16  
97  
RJJ10J1643-0101  
 
Specify the interrupt priority level (07) to be set in the interrupt control register.  
(H8/300H)  
Specify the interrupt priority level (0–1) to be set in the interrupt control register. For  
the CPUs that do not have an interrupt control register, specify 0.  
[data3]  
(M16C)(H8/300H)  
Specify 0.  
(R8C)  
When using timer X, specify the set value for the timer register.  
[data4]  
(M16C) (H8/300H)  
Specify 0.  
(R8C)  
Specify the set value for the prescaler register.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Timer (pulse width measurement mode)  
__EnablePulseWidthMeasurementMode, __DestroyPulseWidthMeasurementMode,  
__GetPulseWidthMeasurementMode  
Remark  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable timers differ with each CPU used.  
When used for the H8/300H, this API specify when freeing it from module stanby  
state.  
Program example  
#include "rapi_timer_r8c_13.h"  
void TimerIntFunc( void ){}  
void func( void )  
{
/* Set up timer X as pulse width measurement mode */  
__CreatePulseWidthMeasurementMode(  
RAPI_TIMER_X|RAPI_TIMER_ON|RAPI_RISING_FALLING|RAPI_F8,  
5, 0x80, 0x80, TimerIntFunc);  
}
Rev.1.01  
2007.02.16  
98  
RJJ10J1643-0101  
 
__EnablePulseWidthMeasurementMode  
Synopsis  
<Control operation of pulse width measurement mode>  
Boolean __EnablePulseWidthMeasurementMode(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Controls operation of the timer that is set to specified pulse width measurement mode.  
[data]  
For data, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_TIMER_ON  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
Sets the timer that is set to pulse width measurement mode to start  
operating.  
RAPI_TIMER_OFF Sets the timer that is set to pulse width measurement mode to stop  
operating.  
(R8C)  
RAPI_TIMER_X  
Selects timer X.  
RAPI_TIMER_RA  
RAPI_TIMER_ON  
Selects timer RA.  
Sets the timer that is set to pulse width measurement mode to start  
operating.  
RAPI_TIMER_OFF Sets the timer that is set to pulse width measurement mode to stop  
operating.  
(H8/300H)  
RAPI_TIMER_W  
Selects timer W.  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD  
0
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RC.  
Selects timer RD channel 0.  
RAPI_TIMER_RD  
1
Selects timer RD channel 1.  
Selects timer RD channel 2.  
Selects timer RD channel 3.  
RAPI_TIMER_RD  
2
RAPI_TIMER_RD  
3
RAPI_TIMER_ON  
Sets the timer that is set to pulse width measurement mode to start  
operating.  
RAPI_TIMER_OFF Sets the timer that is set to pulse width measurement mode to stop  
operating.  
Rev.1.01  
2007.02.16  
99  
RJJ10J1643-0101  
 
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Timer (pulse width measurement mode)  
__CreatePulseWidthMeasurementMode, __DestroyPulseWidthMeasurementMode,  
__GetPulseWidthMeasurementMode  
Remark  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
/* Disable timer X as pulse width measurement mode */  
__EnablePulseWidthMeasurementMode( RAPI_TIMER_X|RAPI_TIMER_OFF );  
}
Rev.1.01  
2007.02.16  
100  
RJJ10J1643-0101  
 
__DestroyPulseWidthMeasurementMode  
Synopsis  
<Discard settings of pulse width measurement mode>  
Boolean __DestroyPulseWidthMeasurementMode(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Discards settings of the timer that is set to specified pulse width measurement mode.  
[data]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
(R8C)  
RAPI_TIMER_X  
Selects timer X.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD  
0
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RC.  
Selects timer RD channel 0.  
RAPI_TIMER_RD  
1
Selects timer RD channel 1.  
Selects timer RD channel 2.  
Selects timer RD channel 3.  
RAPI_TIMER_RD  
2
RAPI_TIMER_RD  
3
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Timer (pulse width measurement mode)  
__CreatePulseWidthMeasurementMode, __EnablePulseWidthMeasurementMode,  
__GetPulseWidthMeasurementMode  
Remark  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
When used for the H8/300H, this API places a specified timer into module stanby  
state after discarding it.  
Rev.1.01  
2007.02.16  
101  
RJJ10J1643-0101  
 
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
/* Destroy the setting of timer X as pulse width measurement mode */  
__DestroyPulseWidthMeasurementMode( RAPI_TIMER_X );  
}
Rev.1.01  
2007.02.16  
102  
RJJ10J1643-0101  
 
__GetPulseWidthMeasurementMode  
Synopsis  
<Get measured value in pulse width measurement mode>  
Boolean __GetPulseWidthMeasurementMode(unsigned long data1, unsigned int  
*data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Pointer to the buffer in which counter value is stored  
Description  
Gets the counter value of the timer that is set to specified pulse width measurement  
mode.  
[data1]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
(R8C)  
RAPI_TIMER_X  
Selects timer X.  
RAPI_TIMER_RA  
Selects timer RA.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD  
0
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RC.  
Selects timer RD channel 0.  
RAPI_TIMER_RD  
1
Selects timer RD channel 1.  
Selects timer RD channel 2.  
Selects timer RD channel 3.  
RAPI_TIMER_RD  
2
RAPI_TIMER_RD  
3
[data2]  
Specify a pointer to the array in which the acquired counter value is stored.  
(M16C)  
• When using timer B (RAPI_TIMER_B0 to RAPI_TIMER_B2 specified)  
[0]: The value of timer Bi register (i = 0–2) is stored.  
(R8C)  
• When using timer X (RAPI_TIMER_X specified)  
[0]: The value of prescaler X register is stored.  
[1]: The value of timer X register is stored.  
• When using timer RA (RAPI_TIMER_RA specified)  
Rev.1.01  
2007.02.16  
103  
RJJ10J1643-0101  
 
[0]: The value of timer RA prescaler register is stored.  
[1]: The value of timer RA register is stored.  
(H8/300H)  
• When using timer W (RAPI_TIMER_W specified)  
[0]: (The value of general register A) – (The value of general register C) is stored.  
[1]: (The value of general register B) – (The value of general register D) is stored.  
• When using timer Z (RAPI_TIMER_Z0 - RAPI_TIMER_Z1 specified)  
[0]: (The value of general register Ai(i=0,1)) – (The value of general register C  
i(i=0,1)) is stored.  
[1]: (The value of general register B i(i=0,1)) – (The value of general register D  
i(i=0,1)) is stored.  
• When using timer RC (RAPI_TIMER_RC specified)  
[0]: (The value of general register A) – (The value of general register C) is stored.  
[1]: (The value of general register B) – (The value of general register D) is stored.  
• When using timer RD (RAPI_TIMER_RD specified)  
[0]: (The value of general register A) – (The value of general register C) is stored.  
[1]: (The value of general register B) – (The value of general register D) is stored.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Timer (pulse width measurement mode)  
__CreatePulseWidthMeasurementMode, __EnablePulseWidthMeasurementMode,  
__DestroyPulseWidthMeasurementMode  
Remark  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
unsigned int data[2];  
/* Get the measured value of timer X as pulse width measurement mode  
*/  
__GetPulseWidthMeasurementMode( RAPI_TIMER_X, data );  
}
Rev.1.01  
2007.02.16  
104  
RJJ10J1643-0101  
 
__CreateInputCapture  
Synopsis  
<Set input capture mode>  
Boolean __CreateInputCapture(unsigned long data1, unsigned int* data2,  
unsigned int* data3, unsigned int* data4, void** data5)  
data1  
data2  
data3  
data4  
data5  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Setup data 3 (content differs with MCU type)  
Setup data 4 (content differs with MCU type)  
Setup data 5 (content differs with MCU type)  
Description  
Sets a specified timer to input capture mode.  
[data1]  
For data1, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_S  
RAPI_F1  
Uses timer S.  
Selects f1 for the count source.  
RAPI_F2  
Selects f2 for the count source.  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
Sets the timer to start operating in __CreateInputCapture.  
Sets the timer to stop operating in __CreateInputCapture.  
RAPI_OVERFLOW_BIT14 Selects overflow of bit 14 for the base timer interrupt.  
RAPI_OVERFLOW_BIT15 Selects overflow of bit 15 for the base timer interrupt.  
• Specifiable definition values when timer S is used (RAPI_TIMER_S specified)  
(Count source) Specify one from { RAPI_F1, RAPI_F2 }. The default value is RAPI_F2.  
(Operating  
states set)  
(Base timer)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
Specify one from { RAPI_OVERFLOW_BIT14, RAPI_OVERFLOW_BIT15 }.  
The default value is RAPI_OVERFLOW_BIT15.  
(R8C)  
RAPI_TIMER_C  
Uses timer C.  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TRD_F1  
Uses timer RD channel 0.  
Uses timer RD channel 1.  
Selects f1 for the timer RD count source.  
Selects f2 for the timer RD count source.  
Selects f8 for the timer RD count source.  
Selects f32 for the timer RD count source.  
Selects fOCO40M for the timer RD count source.  
Selects fRING-fast for the count source.  
RAPI_TRD_F2  
RAPI_TRD_F8  
RAPI_TRD_F32  
RAPI_TRD_F40M  
RAPI_FRING_FAST  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_RISING  
Sets the timer to start operating in __CreateInputCapture.  
Sets the timer to stop operating in __CreateInputCapture.  
Selects the rising edge of measurement pulse as active edge.  
Rev.1.01  
2007.02.16  
105  
RJJ10J1643-0101  
 
RAPI_FALLING  
RAPI_BOTH  
Selects the falling edge of measurement pulse as active edge.  
Selects both rising and falling edges of measurement pulse as  
active edge.  
RAPI_FILTER_F1  
RAPI_FILTER_F8  
RAPI_FILTER_F32  
Uses the digital filter facility that has a sampling frequency f1.  
Uses the digital filter facility that has a sampling frequency f8.  
Uses the digital filter facility that has a sampling frequency f32.  
RAPI_INT3_TRIGGER Selects the trigger facility of TCIN input.  
RAPI_FRING128  
RAPI_OVERFLOW  
RAPI_INPUT_CAPTU  
RE_A  
Selects the trigger facility of fRING128 input.  
Enable overflow interrupt.  
Enable GRA input capture interrupt.  
RAPI_INPUT_CAPTU  
RE_B  
Enable GRB input capture interrupt.  
RAPI_INPUT_CAPTU  
RE_C  
Enable GRC input capture interrupt.  
RAPI_INPUT_CAPTU  
RE_D  
Enable GRD input capture interrupt.  
RAPI_COUNT_CLEA  
R_A  
Selects GRA input capture to counter clear factor  
Selects GRB input capture to counter clear factor  
Selects GRC input capture to counter clear factor  
Selects GRD input capture to counter clear factor  
Clear counter in sync with the synchronized other timer counter  
Synchronize timer on channels A and B.  
RAPI_COUNT_CLEA  
R_B  
RAPI_COUNT_CLEA  
R_C  
RAPI_COUNT_CLEA  
R_D  
RAPI_COUNT_CLEA  
R_SYNC  
RAPI_TIMER_SYNC  
RAPI_TRD_FILTER_F Use sampling frequency f1 for digital filter function  
1
RAPI_TRD_FILTER_F Use sampling frequency f8 for digital filter function  
8
RAPI_TRD_FILTER_F Use sampling frequency f32 for digital filter function  
32  
RAPI_TRD_FILTER_F Use sampling frequency f for digital filter function  
• Specifiable definition values when timer C is used (RAPI_TIMER_C specified)  
(Count source) Specify one from [RAPI_TRD_F1, RAPI_TRD_F2, RAPI_TRD_F4,  
RAPI_TRD_F8, RAPI_TRD_F32, RAPI_TRD_F40M]. The default is  
RAPI_TRD_F1.  
(Operating  
states set)  
Specify one from [RAPI_TIMER_ON, RAPI_TIMER_OFF]. The default is  
RAPI_TIMER_OFF  
Rev.1.01  
2007.02.16  
106  
RJJ10J1643-0101  
 
(Interrupt)  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
input capture A, input capture B, input capture C, or input capture D interrupt  
requests  
are  
enabled,  
specify  
RAPI_INPUT_CAPURE_A,  
or  
RAPI_INPUT_CAPURE_B,  
RAPI_INPUT_CAPURE_C,  
RAPI_INPUT_CAPURE_D, respectively. When not specifying interrupts,  
select “No interrupt requests.”  
(Counter  
clear)  
To specify GRA, GRB, GRC, or GRD input capture for the cause for which  
the counter is cleared, select RAPI_COUNT_CLEAR_A,  
RAPI_COUNT_CLEAR_B, RAPI_COUNT_CLEAR_C, or  
RAPI_COUNT_CLEAR_D, respectively. If cleared at the same time a  
synchronously operating counter on another channel is cleared, select  
RAPI_COUNT_CLEAR_SYNC.  
(Synchronizati If timers on channels  
0
and  
1
are to be synchronized, select  
on)  
RAPI_TIMER_SYNC. When not specifying synchronization, select  
“Channels 0 and 1 operate independently.”  
(Clock  
for Specify one from [RAPI_TRD_FILTER_F1, RAPI_TRD_FILTER_F8,  
digital filter)  
RAPI_TRD_FILTER_F32,  
RAPI_TRD_FILTER_F32.  
RAPI_TRD_FILTER_F].  
The  
default  
is  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RD2  
RAPI_TIMER_RD3  
RAPI_TW_F1  
RAPI_TW_F2  
RAPI_TW_F4  
RAPI_TW_F8  
RAPI_TZ_F1  
Uses timer W.  
Uses timer Z channel 0.  
Uses timer Z channel 1.  
Uses timer RC.  
Uses timer RD0 channel 0.  
Uses timer RD0 channel 1.  
Uses timer RD0 channel 2.  
Uses timer RD0 channel 3.  
Timer W counts with internal clock φ.  
Timer W counts with internal clock φ/2.  
Timer W counts with internal clock φ/4.  
Timer W counts with internal clock φ/8.  
Timer Z counts with internal clock φ.  
Timer Z counts with internal clock φ/2.  
Timer Z counts with internal clock φ/4.  
Timer Z counts with internal clock φ/8.  
Timer RC counts with internal clock φ.  
Timer RC counts with internal clock φ/2.  
Timer RC counts with internal clockφ/4.  
Timer RC counts with internal clock φ/8.  
Timer RC counts with internal clock φ/8.  
Timer RC counts with internal clock φ40M.  
Timer RD counts with internal clock φ.  
Timer RD counts with internal clock φ/2.  
RAPI_TZ_F2  
RAPI_TZ_F4  
RAPI_TZ_F8  
RAPI_TRC_F1  
RAPI_TRC_F2  
RAPI_TRC_F4  
RAPI_TRC_F8  
RAPI_TRC_F32  
RAPI_TRC_F40M  
RAPI_TRD_F1  
RAPI_TRD_F2  
Rev.1.01  
2007.02.16  
107  
RJJ10J1643-0101  
 
RAPI_TRD_F4  
Timer RD counts with internal clockφ/4.  
Timer RD counts with internal clock φ/8.  
Timer RD counts with internal clock φ/32.  
Timer RD counts with internal clock φ40M.  
Sets the timer to start operating in __CreateInputCapture.  
Sets the timer to stop operating in __CreateInputCapture.  
Enables overflow interrupt.  
RAPI_TRD_F8  
RAPI_TRD_F32  
RAPI_TRD_F40M  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_OVERFLOW  
RAPI_INPUT_  
Enables GRA input capture interrupt.  
CAPTURE_A  
RAPI_INPUT_  
Enables GRB input capture interrupt.  
Enables GRC input capture interrupt.  
Enables GRD input capture interrupt.  
CAPTURE_B  
RAPI_INPUT_  
CAPTURE_C  
RAPI_INPUT_  
CAPTURE_D  
RAPI_COUNT_CLEAR_A  
RAPI_COUNT_CLEAR_B  
RAPI_COUNT_CLEAR_C  
RAPI_COUNT_CLEAR_D  
RAPI_COUNT_CLEAR_S  
YNC  
Specifies GRA input capture for the cause of counter clear.  
Specifies GRB input capture for the cause of counter clear.  
Specifies GRC input capture for the cause of counter clear.  
Specifies GRD input capture for the cause of counter clear.  
Clear counter in sync with the synchronized other timer counter  
RAPI_TIMER_SYNC  
RAPI_TRC_FILTER_F1  
RAPI_TRC_FILTER_F8  
RAPI_TRC_FILTER_F32  
RAPI_TRC_FILTER_F  
RAPI_TRD_FILTER_F1  
RAPI_TRD_FILTER_F8  
RAPI_TRD_FILTER_F32  
RAPI_TRD_FILTER_F  
Synchronizes timer on channels 0 and 1.  
Use sampling frequency f1 for timer RC digital filter function  
Use sampling frequency f8 for timer RC digital filter function  
Use sampling frequency f32 for timer RC digital filter function  
Use sampling frequency f for timer RD digital filter function  
Use sampling frequency f1 for timer RD digital filter function  
Use sampling frequency f8 for timer RD digital filter function  
Use sampling frequency f32 for timer RD digital filter function  
Use sampling frequency f for timer RD digital filter function  
• Specifiable definition values when timer W is used (RAPI_TIMER_W specified)  
(Count source) Specify one from { RAPI_TW_F1, RAPI_TW_F2, RAPI_TW_F4,  
RAPI_TW_F8 }. The default value is RAPI_TW_F1.  
(Operating  
states set)  
(Interrupt)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW.  
Similarly, if input capture A, input capture B, input capture C, or input capture  
D interrupt requests are enabled, specify RAPI_INPUT_CAPTURE_A,  
RAPI_INPUT_CAPTURE_B, RAPI_INPUT_CAPTURE_C, or  
RAPI_INPUT_CAPTURE_D, respectively. If no interrupts are specified, “No  
interrupt request” is set.  
Rev.1.01  
2007.02.16  
108  
RJJ10J1643-0101  
 
(Counter  
clear)  
To specify GRA, GRB, GRC, or GRD input capture for the cause for which  
the counter is cleared, select RAPI_COUNT_CLEAR_A,  
RAPI_COUNT_CLEAR_B, RAPI_COUNT_CLEAR_C, or  
RAPI_COUNT_CLEAR_D, respectively. If cleared at the same time a  
synchronously operating counter on another channel is cleared, select  
RAPI_COUNT_CLEAR_SYNC.  
• Specifiable definition values when timer Z is used (RAPI_TIMER_Z0 to  
RAPI_TIMER_Z1 specified)  
(Count source)  
Specify one from { RAPI_TZ_F1, RAPI_TZ_F2, RAPI_TZ_F4,  
RAPI_TZ_F8 }. The default value is RAPI_TZ_F1.  
(Operating  
states set)  
(Interrupt)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW.  
Similarly, if input capture A, input capture B, input capture C, or input  
capture D interrupt requests are enabled, specify  
RAPI_INPUT_CAPTURE_A, RAPI_INPUT_CAPTURE_B,  
RAPI_INPUT_CAPTURE_C, or RAPI_INPUT_CAPTURE_D,  
respectively. If no interrupts are specified, “No interrupt request” is set.  
To specify GRA, GRB, GRC, or GRD input capture for the cause of  
counter clear, specify RAPI_COUNT_CLEAR_A,  
(Counter clear)  
RAPI_COUNT_CLEAR_B, RAPI_COUNT_CLEAR_C, or  
RAPI_COUNT_CLEAR_D, respectively.  
(Synchronization) If the timer is synchronized on channels 0 and 1, specify  
RAPI_TIMER_SYNC. If synchronization is not specified, “Channels 0 and  
1 operate independently” is set.  
• Specifiable definition values when timer RC is used (RAPI_TIMER_RC specified)  
(Count source)  
Specify one from [RAPI_TRD_F1, RAPI_TRD_F2, RAPI_TRD_F4,  
RAPI_TRD_F8, RAPI_TRD_F32, RAPI_TRD_F40M]. The default is  
RAPI_TRD_F1.  
(Operating  
states set)  
(Interrupt)  
Specify one from [RAPI_TIMER_ON, RAPI_TIMER_OFF]. The default is  
RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
input capture A, input capture B, input capture C, or input capture D  
interrupt requests are enabled, specify RAPI_INPUT_CAPURE_A,  
RAPI_INPUT_CAPURE_B,  
RAPI_INPUT_CAPURE_C,  
or  
RAPI_INPUT_CAPURE_D, respectively. When not specifying interrupts,  
select “No interrupt requests.”  
(Clock for digital Specify one from [RAPI_TRD_FILTER_F1, RAPI_TRD_FILTER_F8,  
filter)  
RAPI_TRD_FILTER_F32, RAPI_TRD_FILTER_F]. The default is  
RAPI_TRD_FILTER_F32.  
• Specifiable definition values when timer RD is used (RAPI_TIMER_RD specified)  
(Count source)  
Specify one from [RAPI_TRD_F1, RAPI_TRD_F2, RAPI_TRD_F4,  
RAPI_TRD_F8, RAPI_TRD_F32, RAPI_TRD_F40M]. The default is  
RAPI_TRD_F1.  
Rev.1.01  
2007.02.16  
109  
RJJ10J1643-0101  
 
(Operating  
states set)  
(Interrupt)  
Specify one from [RAPI_TIMER_ON, RAPI_TIMER_OFF]. The default is  
RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
input capture A, input capture B, input capture C, or input capture D  
interrupt requests are enabled, specify RAPI_INPUT_CAPURE_A,  
RAPI_INPUT_CAPURE_B,  
RAPI_INPUT_CAPURE_C,  
or  
RAPI_INPUT_CAPURE_D, respectively. When not specifying interrupts,  
select “No interrupt requests.”  
(Counter clear)  
To specify GRA, GRB, GRC, or GRD input capture for the cause for  
which the counter is cleared, select RAPI_COUNT_CLEAR_A,  
RAPI_COUNT_CLEAR_B, RAPI_COUNT_CLEAR_C, or  
RAPI_COUNT_CLEAR_D, respectively. If cleared at the same time a  
synchronously operating counter on another channel is cleared, select  
RAPI_COUNT_CLEAR_SYNC.  
(Synchronization If timers on channels  
0
and  
1
are to be synchronized, select  
)
RAPI_TIMER_SYNC. When not specifying synchronization, select  
“Channels 0 and 1 operate independently.”  
(Clock for digital Specify one from [RAPI_TRD_FILTER_F1, RAPI_TRD_FILTER_F8,  
filter)  
RAPI_TRD_FILTER_F32, RAPI_TRD_FILTER_F]. The default is  
RAPI_TRD_FILTER_F32.  
[data2]  
(M16C)  
Specify a pointer to the array in which the interrupt priority level is stored.  
[0]: Specify the IC/OC base timer interrupt priority level (07).  
[1]: Specify the IC/OC interrupt 0 priority level (07).  
[2]: Specify the IC/OC interrupt 1 priority level (07).  
(R8C)  
When timer RD is used (RAPI_TIMER_RD0 or RAPI_TIMERRD1 specified),  
specify a pointer to the variable that contains the interrupt priority level (07) to be  
set in the interrupt control register. When timer RD is not used, specify a pointer to  
the following array that contains the interrupt priority level  
[0]: Specify the timer C interrupt priority level (07).  
[1]: Specify the compare match 0 interrupt priority level (07).  
[2]: Specify the compare match 1 interrupt priority level (07).  
(H8/300H)  
Specify the interrupt priority level (0–1) to be set in the interrupt control register. For  
the CPUs that do not have an interrupt control register, specify 0.  
[data3]  
(M16C)  
Specify a pointer to the array in which the set value for the time measurement  
control register is stored.  
[0]: Specify the set value for time measurement control register 0.  
[1]: Specify the set value for time measurement control register 1.  
Rev.1.01  
2007.02.16  
110  
RJJ10J1643-0101  
 
[2]: Specify the set value for time measurement control register 2.  
[3]: Specify the set value for time measurement control register 3.  
[4]: Specify the set value for time measurement control register 4.  
[5]: Specify the set value for time measurement control register 5.  
[6]: Specify the set value for time measurement control register 6.  
[7]: Specify the set value for time measurement control register 7.  
For each element of the array, the following definition values can be set. To set  
multiple definition values at the same time, use the symbol “|” to separate each  
specified value.  
RAPI_IC_RISING  
RAPI_IC_FALLING  
RAPI_IC_BOTH  
Selects the rising edge of measurement pulse as active edge.  
Selects the falling edge of measurement pulse as active edge.  
Selects both rising and falling edges of measurement pulse as  
active edge.  
RAPI_FILTER_F1_F2  
RAPI_FILTER_FBT1  
RAPI_GATE  
Uses the digital filter facility that has a sampling frequency f1 or f2.  
Uses the digital filter facility that has a sampling frequency fBT1  
.
Uses a gate facility.  
RAPI_GATE_CLEAR  
Clears the gate facility upon a match of base timer and G1POk  
register.  
RAPI_PRESCALER  
Uses a prescaler facility.  
• Specifiable definition values for time measurement registers 07  
(Measurement Specify one from { RAPI_IC_RISING, RAPI_IC_FALLING,  
pulse)  
(Filter)  
RAPI_IC_BOTH }. If no measurement pulses are specified, the time  
measurement register is set to “No time measurement performed.”  
Specify one from { RAPI_FILTER_F1, RAPI_FILTER_FBT1 }. If no filters are  
specified, “No digital filter” is set.  
• Specifiable definition values for time measurement registers 67  
(Gate)  
To use the gate facility, specify RAPI_GATE. If RAPI_GATE is not specified,  
“No facility unused” is set. Make sure RAPI_GATE_CLEAR is specified at  
the same time RAPI_GATE is specified.  
(Prescaler)  
To use the prescaler facility, specify RAPI_PRESCALER. If  
RAPI_PRESCALER is not specified, “No prescaler facility” is set.  
(R8C)  
When using timer RD (RAPI_TIMER_RD0 to RAPI_TIMER_RD1 specified), set one of the  
following values. Otherwise, specify 0.  
Specify a pointer to the array in which each active edge setting is stored.  
[0]: Specify the active edge of TRDIOAi (i=0,1) pin.  
[1]: Specify the active edge of TRDIOBi (i=0,1) pin.  
[2]: Specify the active edge of TRDIOCi (i=0,1) pin.  
[3]: Specify the active edge of TRDIODi (i=0,1) pin.  
For each element of the array, one of [RAPI_TRD_RISING, RAPI_TRD_FALLING,  
RAPI_TRD_BOTH] can be set as the active edge of measured pulses.  
Furthermore, if the digital filter function is enabled, select RAPI_FILTER_ON.  
To set the f0C0128 signal for the TRDI0A0 pin on channel 0, specify RAPI_F0C0128. For the  
elements corresponding to unused channels, set 0.  
Rev.1.01  
2007.02.16  
111  
RJJ10J1643-0101  
 
RAPI_TRD_RISING  
Selects the rising edge of measurement pulse as active edge.  
RAPI_TRD_FALLING Selects the falling edge of measurement pulse as active edge.  
RAPI_TRD_BOTH  
RAPI_FILTER_ON  
RAPI_FOCO128  
Selects both rising and falling edges of measurement pulse as active  
edge.  
Selects digital filter on. If not select “RAPI_FILTER_ON”, “No digital  
filter” is set.  
Selects fOCO128 as TRDIOA0 pin input. Specifiable only active  
edge of channel0 TRDIOA0 pin.  
(H8/300H)  
Specify a pointer to the array in which each active edge setting is stored.  
[0]: Specify the active edge of TRDIOA pin.  
[1]: Specify the active edge of TRDIOB pin.  
[2]: Specify the active edge of TRDIOC pin.  
[3]: Specify the active edge of TRDIOD pin.  
For each element of the array, one of the following definition values  
{ RAPI_RISING, RAPI_FALLING, RAPI_BOTH } can be set.  
For the array elements corresponding to unused channels, set 0.  
RAPI_RISING  
RAPI_FALLING Selects the falling edge of measurement pulse as active edge.  
RAPI_BOTH Selects both rising and falling edges of measurement pulse as active edge.  
RAPI_FILTER_ Selects digital filter on. If not select “RAPI_FILTER_ON”, “No digital filter” is  
Selects the rising edge of measurement pulse as active edge.  
ON  
set.  
[data4]  
(M16C)  
Specify a pointer to the array in which the set value for each register or timer S is  
stored.  
[0]: Specify the set value for the facility select and facility enable registers.  
Specify the channel for which the time measurement facility is enabled.  
[1]: Specify the set value for interrupt enable register 0.  
Specify the channel for which IO/CO interrupt 0 request is enabled.  
[2]: Specify the set value for interrupt enable register 1.  
Specify the channel for which IO/CO interrupt 1 request is enabled.  
[3]: Specify the set value for the count source divide-by-N register.  
Specify the value of ‘n’ in the formula “count source divided by (n +1)” in 8 bits.  
[4]: Specify the set value for time measurement prescaler register 6.  
Specify the value of ‘n’ in the prescaler period “n + 1” in 8 bits.  
[5]: Specify the set value for time measurement prescaler register 7.  
Specify the value of ‘n’ in the prescaler period “n +1” in 8 bits.  
For the channels to be specified in each array element, use the following definition  
values. To specify multiple definition values at the same time, use the symbol “|” to  
separate each specified value. If 0 is specified, the value 0 is set in the  
corresponding register.  
RAPI_CHANNEL0  
Selects channel 0.  
Rev.1.01  
2007.02.16  
112  
RJJ10J1643-0101  
 
RAPI_CHANNEL1  
RAPI_CHANNEL2  
RAPI_CHANNEL3  
RAPI_CHANNEL4  
RAPI_CHANNEL5  
RAPI_CHANNEL6  
RAPI_CHANNEL7  
(R8C) (H8/300H)  
Specify 0.  
Selects channel 1.  
Selects channel 2.  
Selects channel 3.  
Selects channel 4.  
Selects channel 5.  
Selects channel 6.  
Selects channel 7.  
[data5]  
(M16C)  
Specify a pointer to the array in which the callback function is stored.  
[0]: Specify a pointer to the callback function for IC/OC base timer interrupt. If this  
pointer is not specified, 0 is set.  
[1]: Specify a pointer to the callback function for IC/OC interrupt 0. If this pointer is  
not specified, 0 is set.  
[2]: Specify a pointer to the callback function for IC/OC interrupt 1. If this pointer is  
not specified, 0 is set.  
(R8C) (H8/300H)  
Specify a pointer to the array in which the callback function is stored. If this pointer  
is not specified, RAPI_NULL is set.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (input capture mode)  
__EnableInputCapture, __DestroyInputCapture, __GetInputCapture  
If an undefined value is specified in the first, third and fourth arguments, operation  
of the API cannot be guaranteed.  
The specifiable timers differ with each CPU used.  
When use CPU which has no digital filter function, cannot specify digital filter  
setting.  
When used for the H8/300H, this API specify when freeing it from module stanby  
state.  
Program example  
#include "rapi_timer_r8c_13.h"  
void TimerIntFunc( void ){}  
Rev.1.01  
2007.02.16  
113  
RJJ10J1643-0101  
 
void func( void )  
{
/* Set up timer C as imput capture mode */  
__CreateInputCapture(  
RAPI_TIMER_C|RAPI_TIMER_ON|RAPI_BOTH|RAPI_F32| RAPI_FRING128,  
5, TimerIntFunc);  
}
Rev.1.01  
2007.02.16  
114  
RJJ10J1643-0101  
 
__EnableInputCapture  
Synopsis  
<Control operation of input capture mode>  
Boolean __EnableInputCapture(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Controls operation of the timer that is set to specified input capture mode by starting or  
stopping it.  
[data]  
For data, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_S  
Selects timer S.  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
Sets the timer that is set to input capture mode to start operating.  
Sets the timer that is set to input capture mode to stop operating.  
(R8C)  
RAPI_TIMER_C  
Selects timer C.  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
Selects timer RD0 channe 0.  
Selects timer RD0 channe 1.  
Sets the timer that is set to input capture mode to start operating.  
Sets the timer that is set to input capture mode to stop operating.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RD2  
RAPI_TIMER_RD3  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RD0.  
Selects timer RD0 channe 0.  
Selects timer RD0 channe 1.  
Selects timer RD0 channe 2.  
Selects timer RD0 channe 3.  
Sets the timer that is set to input capture mode to start operating.  
Sets the timer that is set to input capture mode to stop operating.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (input capture mode)  
CreateInputCapture, DestroyInputCapture, GetInputCapture  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
Rev.1.01  
2007.02.16  
115  
RJJ10J1643-0101  
 
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
/* Enable timer C as input capture mode */  
__EnableInputCapture( RAPI_TIMER_C|RAPI_TIMER_ON );  
}
Rev.1.01  
2007.02.16  
116  
RJJ10J1643-0101  
 
__DestroyInputCapture  
Synopsis  
<Discard settings of input capture mode>  
Boolean __DestroyInputCapture(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Discards settings of the timer that is set to specified input capture mode.  
[data]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_S  
Selects timer S.  
(R8C)  
RAPI_TIMER_C  
Selects timer C.  
RAPI_TIMER_RD0 Selects timer RD0 channe 0.  
RAPI_TIMER_RD1 Selects timer RD0 channe 1.  
(H8/300H)  
RAPI_TIMER_W  
Selects timer W.  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RD0.  
RAPI_TIMER_RD0 Selects timer RD0 channe 0.  
RAPI_TIMER_RD1 Selects timer RD0 channe 1.  
RAPI_TIMER_RD2 Selects timer RD0 channe 2.  
RAPI_TIMER_RD3 Selects timer RD0 channe 3.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (input capture mode)  
__CreateInputCapture, __EnableInputCapture, __GetInputCapture  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
When used for the H8/300H, this API places a specified timer into module stanby  
state after discarding it.  
Program example  
#include "rapi_timer_r8c_13.h"  
Rev.1.01  
2007.02.16  
117  
RJJ10J1643-0101  
 
void func( void )  
{
/* Destroy the setting of timer C as input capture mode */  
__DestroyInputCapture( RAPI_TIMER_C );  
}
Rev.1.01  
2007.02.16  
118  
RJJ10J1643-0101  
 
__GetInputCapture  
Synopsis  
<Get input capture mode counter value>  
Boolean __GetInputCapture(unsigned long data1, unsigned int *data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Description  
Gets the counter value of the timer that is set to specified input capture mode.  
[data1]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_S  
Selects timer S.  
(R8C)  
RAPI_TIMER_C  
Selects timer C.  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
Selects timer RD0 channe 0.  
Selects timer RD0 channe 1.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RD2  
RAPI_TIMER_RD3  
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RD0.  
Selects timer RD0 channe 0.  
Selects timer RD0 channe 1.  
Selects timer RD0 channe 2.  
Selects timer RD0 channe 3.  
[data2]  
(M16C)  
Specify a pointer to the array in which the acquired counter value is stored.  
[0]: Stores the value of base timer register 0.  
[1]: Stores the value of time measurement register 0.  
[2]: Stores the value of time measurement register 1.  
[3]: Stores the value of time measurement register 2.  
[4]: Stores the value of time measurement register 3.  
[5]: Stores the value of time measurement register 4.  
[6]: Stores the value of time measurement register 5.  
[7]: Stores the value of time measurement register 6.  
[8]: Stores the value of time measurement register 7.  
(R8C)  
Specify a pointer to the array in which the acquired counter value is stored.  
• When timer C is used (RAPI_TIMER_C specified)  
[0]: Stores the value of timer C counter.  
[1]: Stores the value of capture & compare 0 register.  
Rev.1.01  
2007.02.16  
119  
RJJ10J1643-0101  
 
• When timer RD is used (RAPI_TIMER_RD0- RAPI_TIMER_RD1 specified)  
[0]: Stores the value of timer counter.  
[1]: Stores the value of general register A.  
[2]: Stores the value of general register B.  
[3]: Stores the value of general register C.  
[4]: Stores the value of general register D.  
(H8/300H)  
[0]: Stores the value of the timer counter.  
[1]: Stores the value of general register A.  
[2]: Stores the value of general register B.  
[3]: Stores the value of general register C.  
[4]: Stores the value of general register D.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (input capture mode)  
__CreateInputCapture, __EnableInputCapture, __DestroyInputCapture  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
unsigned int data[2];  
/* Get the counter of timer C as input capture mode */  
__GetInputCapture( RAPI_TIMER_C, data );  
}
Rev.1.01  
2007.02.16  
120  
RJJ10J1643-0101  
 
__CreateOutputCompare  
Synopsis  
<Set output compare mode>  
Boolean __CreateOutputCompare(unsigned long data1, unsigned int* data2,  
unsigned int* data3, unsigned int* data4, void** data5)  
data1  
data2  
data3  
data4  
data5  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Setup data 3 (content differs with MCU type)  
Setup data 4 (content differs with MCU type)  
Setup data 5 (content differs with MCU type)  
Description  
Sets a specified timer to output compare mode.  
[data1]  
For data1, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_S  
RAPI_F1  
Uses timer S.  
Selects f1 for the count source.  
RAPI_F2  
Selects f2 for the count source.  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
Sets the timer to start operating in __CreateOutputCompare.  
Sets the timer to stop operating in __CreateOutputCompare.  
RAPI_OVERFLOW_BIT14 Selects overflow of bit 14 for the base timer interrupt.  
RAPI_OVERFLOW_BIT15 Selects overflow of bit 15 for the base timer interrupt.  
• Specifiable definition values when timer S is used (RAPI_TIMER_S specified)  
(Count source) Specify one from { RAPI_F1, RAPI_F2 }. The default value is RAPI_F2.  
(Operating  
states set)  
(Base timer)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
Specify one from { RAPI_OVERFLOW_BIT14, RAPI_OVERFLOW_BIT15 }.  
The default value is RAPI_OVERFLOW_BIT15.  
(R8C)  
RAPI_TIMER_C  
Uses timer C.  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RE  
RAPI_F1  
Uses timer RD0 channe 0.  
Uses timer RD0 channe 1.  
Uses timer C.  
Selects f1 for the count source.  
Selects f8 for the count source.  
Selects f32 for the count source.  
Selects fRING-fast for the count source.  
Selects f1 for the timer RD count source.  
Selects f2 for the timer RD count source.  
Selects f4 for the timer RD count source.  
Selects f8 for the timer RD count source.  
RAPI_F8  
RAPI_F32  
RAPI_FRING_FAST  
RAPI_TRD_F1  
RAPI_TRD_F2  
RAPI_TRD_F4  
RAPI_TRD_F8  
Rev.1.01  
2007.02.16  
121  
RJJ10J1643-0101  
 
RAPI_TRD_F32  
RAPI_TRD_F40M  
RAPI_TRE_F4  
RAPI_TRE_F8  
RAPI_TRE_F32  
RAPI_TRE_FC4  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_TIMER_OVERFLO  
W
Selects f32 for the timer RD count source.  
Selects fOCO40M for the timer RD count source.  
Selects f4 for the timer RE count source.  
Selects f8 for the timer RE count source.  
Selects f32 for the timer RE count source.  
Selects fC4 for the timer RE count source.  
Sets the timer to start operating in __CreateOutputCompare.  
Sets the timer to stop operating in __CreateOutputCompare.  
Enables the overflow interrupt.  
RAPI_COMPARE_MATCH Enables the comparematch interrupt.  
RAPI_COMPARE_MATCH Enables the GRA compare match interrupt.  
_A  
RAPI_COMPARE_MATCH Enables the GRB compare match interrupt.  
_B  
RAPI_COMPARE_MATCH Enables the GRC compare match interrupt.  
_C  
RAPI_COMPARE_MATCH Enables the GRD compare match interrupt.  
_D  
RAPI_COUNT_CLEAR_A  
RAPI_COUNT_CLEAR_B  
RAPI_COUNT_CLEAR_C  
RAPI_COUNT_CLEAR_D  
RAPI_COUNT_CLEAR_SYNC  
RAPI_TIMER_SYNC  
Specifies GRA compare match for the cause of counter clear.  
Specifies GRB compare match for the cause of counter clear.  
Specifies GRC compare match for the cause of counter clear.  
Specifies GRD compare match for the cause of counter clear.  
Clear counter in sync with the synchronized other timer counter  
Synchronize timer on channels 0 and 1.  
Disables CMP output from CMP00.  
RAPI_CMP00_DISABLE  
RAPI_CMP01_DISABLE  
RAPI_CMP02_DISABLE  
RAPI_CMP10_DISABLE  
RAPI_CMP11_DISABLE  
RAPI_CMP12_DISABLE  
RAPI_CMP00_ENABLE  
RAPI_CMP01_ENABLE  
RAPI_CMP02_ENABLE  
RAPI_CMP10_ENABLE  
RAPI_CMP11_ENABLE  
RAPI_CMP12_ENABLE  
RAPI_OUTPUT_  
Disables CMP output from CMP01.  
Disables CMP output from CMP02.  
Disables CMP output from CMP10.  
Disables CMP output from CMP11.  
Disables CMP output from CMP12.  
Enables CMP output from CMP00.  
Enables CMP output from CMP01.  
Enables CMP output from CMP02.  
Enables CMP output from CMP10.  
Enables CMP output from CMP11.  
Enables CMP output from CMP12.  
Inverts CMP output from CMP00 through CMP02.  
REVERSE_0  
RAPI_OUTPUT_  
Inverts CMP output from CMP10 through CMP12.  
REVERSE_1  
RAPI_RELOAD  
Sets TC register to “0x0000” when compare 1 matches.  
Rev.1.01  
2007.02.16  
122  
RJJ10J1643-0101  
 
RAPI_UNCHANGE_0  
Leaves CMP0 output unchanged even when matched in  
compare 0.  
RAPI_REVERSE_0  
RAPI_L_0  
Inverts CMP0 output upon compare 0 match signal.  
Forces CMP0 output low upon compare 0 match signal.  
Forces CMP0 output high upon compare 0 match signal.  
Leaves CMP1 output unchanged even when matched in  
compare 1.  
RAPI_H_0  
RAPI_UNCHANGE_1  
RAPI_REVERSE_1  
RAPI_L_1  
Inverts CMP1 output upon compare 1 match signal.  
Forces CMP1 output low upon compare 1 match signal.  
Forces CMP1 output high upon compare 1 match signal.  
RAPI_H_1  
RAPI_OUTPUT_DISABLE Disable output.  
RAPI_OUTPUT_F2  
RAPI_OUTPUT_F4  
RAPI_OUTPUT_F8  
Specifies f2 output for output function.  
Specifies f4 output for output function.  
Specifies f8 output for output function.  
RAPI_OUTPUT_COMPAR Specifies compare output for output function.  
E
RAPI_4BIT_COUNTER  
Uses 4 bit counter.  
RAPI_COMPARE_MATCH Stop count when GRA compare match occur  
_A_STOP  
RAPI_STOP  
Stop count when clear TSTART bit.  
• Specifiable definition values when timer C is used (RAPI_TIMER_C specified)  
(Count source)  
Specify one from { RAPI_F1, RAPI_F8, RAPI_F32,  
RAPI_FRING_FAST }. The default value is RAPI_F1.  
(Operating states Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
set)  
value is RAPI_TIMER_OFF.  
(CMP00 output)  
Specify one from { RAPI_CMP00_DISABLE, RAPI_CMP00_ENABLE }.  
The default value is RAPI_CMP00_DISABLE.  
(CMP01 output)  
(CMP02 output)  
(CMP10 output)  
(CMP11 output)  
(CMP12 output)  
Specify one from { RAPI_CMP01_DISABLE, RAPI_CMP01_ENABLE }.  
The default value is RAPI_CMP01_DISABLE.  
Specify one from { RAPI_CMP02_DISABLE, RAPI_CMP02_ENABLE }.  
The default value is RAPI_CMP02_DISABLE.  
Specify one from { RAPI_CMP10_DISABLE, RAPI_CMP10_ENABLE }.  
The default value is RAPI_CMP10_DISABLE.  
Specify one from { RAPI_CMP11_DISABLE, RAPI_CMP11_ENABLE }.  
The default value is RAPI_CMP11_DISABLE.  
Specify one from { RAPI_CMP12_DISABLE, RAPI_CMP12_ENABLE }.  
The default value is RAPI_CMP12_DISABLE.  
(CMP0 output  
inversion)  
To invert CMP0 output, specify RAPI_OUTPUT_REVERSE_0. If  
RAPI_OUTPUT_REVERSE_0 is not specified, “CMP0 output not  
inverted” is set.  
(CMP1 output  
inversion)  
To invert CMP1 output, specify RAPI_OUTPUT_REVERSE_1. If  
RAPI_OUTPUT_REVERSE_1 is not specified, “CMP1 output not  
inverted” is set.  
Rev.1.01  
2007.02.16  
123  
RJJ10J1643-0101  
 
(TC reload)  
To reload TC register, specify RAPID_RELOAD. If RAPID_RELOAD is  
not specified, “No reload” is set.  
(CMP0 output  
mode)  
Specify one from { RAPI_UNCHANGE_0, RAPI_REVERSE_0,  
RAPI_L_0, RAPI_H_0 }. The default value is RAPI_UNCHANGE_0.  
Specify one from { RAPI_UNCHANGE_1, RAPI_REVERSE_1,  
RAPI_L_1, RAPI_H_1 }. The default value is RAPI_UNCHANGE_1.  
(CMP1 output  
mode)  
• Specifiable definition values when timer RD is used (RAPI_TIMER_RD specified)  
(Count source)  
Specify one from [RAPI_TRD_F1, RAPI_TRD_F2, RAPI_TRD_F4,  
RAPI_TRD_F8, RAPI_TRD_F32, RAPI_TRD_F40M]. The default is  
RAPI_TRD_F1.  
(Operating states Specify one from [RAPI_TIMER_ON, RAPI_TIMER_OFF]. The default  
set)  
is RAPI_TIMER_OFF  
(Interrupt)  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW.  
If input capture A, input capture B, input capture C, or input capture D  
interrupt requests are enabled, specify RAPI_INPUT_CAPURE_A,  
RAPI_INPUT_CAPURE_B,  
RAPI_INPUT_CAPURE_C,  
or  
RAPI_INPUT_CAPURE_D, respectively. When not specifying  
interrupts, select “No interrupt requests.”  
(Counter clear)  
To specify GRA, GRB, GRC, or GRD input capture for the cause for  
which the counter is cleared, select RAPI_COUNT_CLEAR_A,  
RAPI_COUNT_CLEAR_B, RAPI_COUNT_CLEAR_C, or  
RAPI_COUNT_CLEAR_D, respectively. If cleared at the same time a  
synchronously operating counter on another channel is cleared, select  
RAPI_COUNT_CLEAR_SYNC.  
(Synchronization)  
(count stop)  
If timers on channels 0 and 1 are to be synchronized, select  
RAPI_TIMER_SYNC. When not specifying synchronization, select  
“Channels 0 and 1 operate independently.”  
Specify one from [RAPI_COMPARE_MATCH_A_STOP, RAPI_STOP].  
The default is RAPI_STOP.  
• Specifiable definition values when timer RE is used (RAPI_TIMER_RE specified)  
(Count source)  
Specify one from [RAPI_TRE_F4, RAPI_TRE_F8, RAPI_TRE_F32,  
RAPI_TRD_FC4]. The default is RAPI_TRD_F1.  
(Operating states Specify one from [RAPI_TIMER_ON, RAPI_TIMER_OFF]. The default  
set)  
is RAPI_TIMER_OFF  
(Interrupt)  
If compare match interrupt requests are enabled, specify  
RAPI_COMPARE_MATCH. When not specifying interrupts, select “No  
interrupt requests.”  
(Output function)  
Specify one from [RAPI_OUTPUT_DISABLE, RAPI_OUTPUT_F2,  
RAPI_OUTPUT_F4, RAPI_OUTPUT_F8,  
RAPI_OUTPUT_COMPARE]. The default is  
RAPI_OUTPUT_COMPARE.  
(Counter)  
If use 4 bit counter, spcify RAPI_4BIT_COUNTER. The default is 8 bit  
counter .  
(H8/300H)  
Rev.1.01  
2007.02.16  
124  
RJJ10J1643-0101  
 
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RD2  
RAPI_TIMER_RD3  
RAPI_TW_F1  
Uses timer W.  
Uses timer Z channel 0.  
Uses timer Z channel 1.  
Uses timer RC.  
Uses timer RD0 channel 0.  
Uses timer RD0 channel 1.  
Uses timer RD0 channel 2.  
Uses timer RD0 channel 3.  
Timer W counts with internal clock φ.  
Timer W counts with internal clock φ/2.  
Timer W counts with internal clock φ/4.  
Timer W counts with internal clock φ/8.  
Timer Z counts with internal clock φ.  
Timer Z counts with internal clock φ/2.  
Timer Z counts with internal clock φ/4.  
Timer Z counts with internal clock φ/8.  
Timer RC counts with internal clock φ.  
Timer RC counts with internal clock φ/2.  
Timer RC counts with internal clockφ/4.  
Timer RC counts with internal clock φ/8.  
Timer RC counts with internal clock φ/8.  
Timer RC counts with internal clock φ40M.  
Timer RD counts with internal clock φ.  
Timer RD counts with internal clock φ/2.  
Timer RD counts with internal clockφ/4.  
Timer RD counts with internal clock φ/8.  
Timer RD counts with internal clock φ/32.  
Timer RD counts with internal clock φ40M.  
Sets the timer to start operating in __CreateOutputCompare.  
Sets the timer to stop operating in __CreateOutputCompare.  
Enables overflow interrupt.  
RAPI_TW_F2  
RAPI_TW_F4  
RAPI_TW_F8  
RAPI_TZ_F1  
RAPI_TZ_F2  
RAPI_TZ_F4  
RAPI_TZ_F8  
RAPI_TRC_F1  
RAPI_TRC_F2  
RAPI_TRC_F4  
RAPI_TRC_F8  
RAPI_TRC_F32  
RAPI_TRC_F40M  
RAPI_TRD_F1  
RAPI_TRD_F2  
RAPI_TRD_F4  
RAPI_TRD_F8  
RAPI_TRD_F32  
RAPI_TRD_F40M  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
RAPI_OVERFLOW  
RAPI_COMPARE_  
MATCH_A  
Enables GRA compare match interrupt.  
RAPI_COMPARE_  
MATCH_B  
Enables GRB compare match interrupt.  
Enables GRC compare match interrupt.  
Enables GRD compare match interrupt.  
RAPI_COMPARE_  
MATCH_C  
RAPI_COMPARE_  
MATCH_D  
RAPI_COUNT_CLEAR_A  
RAPI_COUNT_CLEAR_B  
RAPI_COUNT_CLEAR_C  
RAPI_COUNT_CLEAR_D  
Specifies GRA compare match for the cause of counter clear.  
Specifies GRB compare match for the cause of counter clear.  
Specifies GRC compare match for the cause of counter clear.  
Specifies GRD compare match for the cause of counter clear.  
Rev.1.01  
2007.02.16  
125  
RJJ10J1643-0101  
 
RAPI_COUNT_CLEAR_S  
YNC  
Clear counter in sync with the synchronized other timer counter  
Synchronizes timer on channels 0 and 1.  
RAPI_TIMER_SYNC  
• Specifiable definition values when timer W is used (RAPI_TIMER_W specified)  
(Count source) Specify one from { RAPI_TW_F1, RAPI_TW_F2, RAPI_TW_F4,  
RAPI_TW_F8 }. The default value is RAPI_TW_F1.  
(Operating  
states set)  
(Interrupt)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW.  
Similarly, if compare match A, compare match B, compare match C, or  
compare match D interrupt requests are enabled, specify  
RAPI_COMPARE_ATCH_A, RAPI_COMPARE_ATCH_B,  
RAPI_COMPARE_ATCH_C, or RAPI_COMPARE_ATCH_D, respectively. If  
no interrupts are specified, “No interrupt request” is set.  
(Counter clear) To specify GRA compare match for the cause of counter clear, specify  
RAPI_COUNT_CLEAR_A.  
• Specifiable definition values when timer Z is used (RAPI_TIMER_Z0 to  
RAPI_TIMER_Z1 specified)  
(Count source)  
Specify one from { RAPI_TZ_F1, RAPI_TZ_F2, RAPI_TZ_F4,  
RAPI_TZ_F8 }. The default value is RAPI_TZ_F1.  
(Operating  
states set)  
(Interrupt)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW.  
Similarly, if compare match A, compare match B, compare match C, or  
compare match D interrupt requests are enabled, specify  
RAPI_COMPARE_ATCH_A, RAPI_COMPARE_ATCH_B,  
RAPI_COMPARE_ATCH_C, or RAPI_COMPARE_ATCH_D,  
respectively. If no interrupts are specified, “No interrupt request” is set.  
To specify GRA, GRB, GRC, or GRD compare match for the cause of  
counter clear, specify RAPI_COUNT_CLEAR_A,  
(Counter clear)  
RAPI_COUNT_CLEAR_B, RAPI_COUNT_CLEAR_C, or  
RAPI_COUNT_CLEAR_D, respectively.  
(Synchronization) If the timer is synchronized on channels 0 and 1, specify  
RAPI_TIMER_SYNC. If synchronization is not specified, “Channels 0 and  
1 operate independently” is set.  
• Specifiable definition values when timer RC is used (RAPI_TIMER_RC specified)  
(Count source)  
Specify one from [RAPI_TRD_F1, RAPI_TRD_F2, RAPI_TRD_F4,  
RAPI_TRD_F8, RAPI_TRD_F32, RAPI_TRD_F40M]. The default is  
RAPI_TRD_F1.  
(Operating  
states set)  
Specify one from [RAPI_TIMER_ON, RAPI_TIMER_OFF]. The default is  
RAPI_TIMER_OFF.  
Rev.1.01  
2007.02.16  
126  
RJJ10J1643-0101  
 
(Interrupt)  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW. If  
compare match A, compare match B, compare match C, or compare  
match  
D
interrupt  
requests  
are  
enabled,  
specify  
RAPI_COMPARE_MATCH_A,  
RAPI_COMPARE_MATCH_C,  
RAPI_COMPARE_MATCH_B,  
RAPI_COMPARE_MATCH_D,  
or  
respectively. When not specifying interrupts, select “No interrupt  
requests.”  
(Counter clear)  
To specify GRA compare match for the cause of counter clear, specify  
RAPI_COUNT_CLEAR_A.  
• Specifiable definition values when timer RD is used (RAPI_TIMER_RD0 to  
RAPI_TIMER_RD4 specified)  
(Count source)  
Specify one from [RAPI_TRD_F1, RAPI_TRD_F2, RAPI_TRD_F4,  
RAPI_TRD_F8, RAPI_TRD_F32, RAPI_TRD_F40M]. The default is  
RAPI_TRD_F1.  
(Operating  
states set)  
(Interrupt)  
Specify one from { RAPI_TIMER_ON, RAPI_TIMER_OFF }. The default  
value is RAPI_TIMER_OFF.  
If overflow interrupt requests are enabled, specify RAPI_OVERFLOW.  
Similarly, if compare match A, compare match B, compare match C, or  
compare match D interrupt requests are enabled, specify  
RAPI_COMPARE_MATCH_A, RAPI_COMPARE_MATCH_B,  
RAPI_COMPARE_MATCH_C, or RAPI_COMPARE_MATCH_D,  
respectively. If no interrupts are specified, “No interrupt request” is set.  
To specify GRA, GRB, GRC, or GRD compare match for the cause of  
counter clear, specify RAPI_COUNT_CLEAR_A,  
(Counter clear)  
RAPI_COUNT_CLEAR_B, RAPI_COUNT_CLEAR_C, or  
RAPI_COUNT_CLEAR_D, respectively.  
(Synchronization) If the timer is synchronized on channels 0 and 1, specify  
RAPI_TIMER_SYNC. If synchronization is not specified, “Channels 0 and  
1 operate independently” is set.  
[data2]  
(M16C)  
Specify a pointer to the array in which the interrupt priority level is stored.  
[0]: Specify the IC/OC base timer interrupt priority level (07).  
[1]: Specify the IC/OC interrupt 0 priority level (07).  
[2]: Specify the IC/OC interrupt 1 priority level (07).  
(R8C)  
Specify a pointer to the array in which the interrupt priority level is stored.  
[0]: Specify the timer C interrupt priority level (07).  
[1]: Specify the compare match 0 interrupt priority level (07).  
[2]: Specify the compare match 1 interrupt priority level (07).  
(H8/300H)  
Specify 0.  
[data3]  
Rev.1.01  
2007.02.16  
127  
RJJ10J1643-0101  
 
(M16C)  
Specify a pointer to the array in which the set value for the waveform generation  
control register or waveform generation register is stored.  
[0]: Specify the set value for waveform generation control register 0.  
[1]: Specify the set value for waveform generation control register 1.  
[2]: Specify the set value for waveform generation control register 2.  
[3]: Specify the set value for waveform generation control register 3.  
[4]: Specify the set value for waveform generation control register 4.  
[5]: Specify the set value for waveform generation control register 5.  
[6]: Specify the set value for waveform generation control register 6.  
[7]: Specify the set value for waveform generation control register 7.  
[8]: Specify the set value for waveform generation register 0 in 16 bits.  
Specify the comparison value of channel 0 in 16 bits.  
[9]: Specify the set value for waveform generation register 1 in 16 bits.  
Specify the comparison value of channel 1 in 16 bits.  
[10]: Specify the set value for waveform generation register 2 in 16 bits.  
Specify the comparison value of channel 2 in 16 bits.  
[11]: Specify the set value for waveform generation register 3 in 16 bits.  
Specify the comparison value of channel 3 in 16 bits.  
[12]: Specify the set value for waveform generation register 4 in 16 bits.  
Specify the comparison value of channel 4 in 16 bits.  
[13]: Specify the set value for waveform generation register 5 in 16 bits.  
Specify the comparison value of channel 5 in 16 bits.  
[14]: Specify the set value for waveform generation register 6 in 16 bits.  
Specify the comparison value of channel 6 in 16 bits.  
[15]: Specify the set value for waveform generation register 7 in 16 bits.  
Specify the comparison value of channel 7 in 16 bits.  
To specify the set value for each waveform generation control register that is an  
array element, the following definition values can be set. To specify multiple  
definition values at the same time, use the symbol “|” to separate each specified  
value.  
RAPI_SINGLE  
Selects single-phase waveform output mode.  
Selects SR waveform output mode.  
Selects inverted waveform output mode.  
Outputs a 0 as the initial output value.  
Outputs a 1 as the initial output value.  
Uses an output inversion facility.  
RAPI_SR  
RAPI_PHASE_DELAYED  
RAPI_OUT_INIT_0  
RAPI_OUT_INIT_1  
RAPI_OUTPUT_  
REVERSED  
RAPI_RELOAD_WITH_  
RESET  
Selects a reset of the base timer as the timing with which the  
G1P0J register value is reloaded.  
RAPI_RELOAD_WITH_  
WRITE  
Selects a write to the base timer as the timing with which the  
G1P0J register value is reloaded.  
• Specifiable definition values for waveform generation control registers 07  
Rev.1.01  
2007.02.16  
128  
RJJ10J1643-0101  
 
(Output mode) Specify one from { RAPI_SINGLE, RAPI_SR, RAPI_PHASE_DELAYED }.  
The default value is RAPI_SINGLE.  
(Initial output  
value)  
Specify one from { RAPI_OUT_INIT_0, RAPI_OUT_INIT_1 }. The default  
value is RAPI_OUT_INIT_0.  
(Output  
To invert the output, specify RAPI_OUTPUT_REVERSED. If output  
inversion is not specified, “Output not inverted” is set.  
Specify one from { RAPI_RELOAD_WITH_RESET,  
RAPI_RELOAD_WITH_WRITE }.  
inversion)  
(Reload)  
The default value is RAPI_RELOAD_WITH_WRITE.  
(R8C)  
• When timer C is used (RAPI_TIMER_C specified)  
Specify a pointer to the array in which the comparison value is stored.  
[0]: Specify comparison value 0 in 16 bits.  
[1]: Specify comparison value 1 in 16 bits.  
• When timer RD is used (RAPI_TIMER_RD0 to RAPI_TIMER_RD4 specified)  
Specify a pointer to the array in which the comparison value is stored.  
[0]: Specify the output operation of TRDIOAi (i=0,1).  
[1]: Specify the output operation of TRDIOBi (i=0,1).  
[2]: Specify the output operation of TRDIOCi (i=0,1).  
[3]: Specify the output operation of TRDIODi (i=0,1).  
[4]: Specify the comparison value of general register A in 16 bits.  
[5]: Specify the comparison value of general register B in 16 bits.  
[6]: Specify the comparison value of general register C in 16 bits.  
[7]: Specify the comparison value of general register D in 16 bits.  
To specify output operation for each output compare of array elements, the following definition  
values can be used. To specify multiple definition values at the same time, use the symbol “|”  
to separate each specified value. For elements of output operation corresponding to unused  
channels, set 0.  
RAPI_OUT_0  
Selects 0 output for the output waveform.  
Selects 1 output for the output waveform.  
Selects toggle output for the output waveform.  
Selects 0 output for the initial output.  
RAPI_OUT_1  
RAPI_OUT_TOGGLE  
RAPI_OUT_INIT_0  
RAPI_OUT_INIT_1  
Selects 1 output for the initial output.  
• When timer RE is used (RAPI_TIMER_RE specified)  
Specify a pointer to the array in which the comparison value is stored.  
Specify comparison value of timer RE compare data register in 8 bits.  
(H8/300H)  
Specify a pointer to the array in which the comparison value is stored.  
[0]: Specify the output operation of FTIOA pin.  
[1]: Specify the output operation of FTIOB pin.  
[2]: Specify the output operation of FTIOC pin.  
[3]: Specify the output operation of FTIOD pin.  
[4]: Specify the comparison value of general register A in 16 bits.  
[5]: Specify the comparison value of general register B in 16 bits.  
Rev.1.01  
2007.02.16  
129  
RJJ10J1643-0101  
 
[6]: Specify the comparison value of general register C in 16 bits.  
[7]: Specify the comparison value of general register D in 16 bits.  
To specify output operation for each output compare of array elements, the following definition  
values can be used. To specify multiple definition values at the same time, use the symbol “|”  
to separate each specified value. For elements of output operation corresponding to unused  
channels, set 0.  
RAPI_OUT_0  
Selects 0 output for the output waveform.  
Selects 1 output for the output waveform.  
Selects toggle output for the output waveform.  
Selects 0 output for the initial output.  
RAPI_OUT_1  
RAPI_OUT_TOGGLE  
RAPI_OUT_INIT_0  
RAPI_OUT_INIT_1  
Selects 1 output for the initial output.  
[data4]  
(M16C)  
Specify a pointer to the array in which the set value for each register of timer S is  
stored.  
[0]: Specify the set value for the facility select and facility enable register.  
Specify the channel for which the waveform generation facility is enabled.  
[1]: Specify the set value for interrupt enable register 0.  
Specify the channel for which IO/CO interrupt 0 request is enabled.  
[2]: Specify the set value for interrupt enable register 1.  
Specify the channel for which IO/CO interrupt 1 request is enabled.  
[3]: Specify the set value for the count source divide-by-n register. Specify the value  
of ‘n’ in the formula “count source divided by (n + 1)” in 8 bits.  
For the channels to be specified in each array element, use the following definition  
values. To specify multiple definition values at the same time, use the symbol “|” to  
separate each specified value. If 0 is specified, the value 0 is set in the  
corresponding register.  
RAPI_CHANNEL0  
RAPI_CHANNEL1  
RAPI_CHANNEL2  
RAPI_CHANNEL3  
RAPI_CHANNEL4  
RAPI_CHANNEL5  
RAPI_CHANNEL6  
RAPI_CHANNEL7  
(R8C) (H8/300H)  
Specify 0.  
Selects channel 0.  
Selects channel 1.  
Selects channel 2.  
Selects channel 3.  
Selects channel 4.  
Selects channel 5.  
Selects channel 6.  
Selects channel 7.  
[data5]  
(M16C)  
Specify a pointer to the array in which the callback function is stored.  
[0]: Specify a pointer to the callback function for IC/OC base timer interrupt.  
If this pointer is not specified, 0 is set.  
Rev.1.01  
2007.02.16  
130  
RJJ10J1643-0101  
 
[1]: Specify a pointer to the callback function for IC/OC interrupt 0.  
If this pointer is not specified, 0 is set.  
[2]: Specify a pointer to the callback function for IC/OC interrupt 1.  
If this pointer is not specified, 0 is set.  
(R8C)  
• When timer C is used (RAPI_TIMER_C specified)  
Specify a pointer to the array in which the callback function is stored.  
[0]: Specify a pointer to the callback function for timer C interrupt.  
If this pointer is not specified, 0 is set.  
[1]: Specify a pointer to the callback function for compare match interrupt 0.  
If this pointer is not specified, 0 is set.  
[2]: Specify a pointer to the callback function for compare match interrupt 1.  
If this pointer is not specified, 0 is set.  
• When timer RD is used (RAPI_TIMER_RD0 to RAPI_TIMER_RD4 specified)  
Specify a pointer to the array in which the callback function is stored.  
If this pointer is not specified, RAPI_NULL is set.  
• When timer RE is used (RAPI_TIMER_RE specified)  
Specify a pointer to the array in which the callback function is stored.  
If this pointer is not specified, RAPI_NULL is set.  
(H8/300H)  
Specify a pointer to the variable in which the callback function is stored. If this  
pointer is not specified, RAPI_NULL is set.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (output compare mode)  
__EnableOutputCompare, __DestroyOutputCompare  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
If when using the H8/300H an undefined value is specified in the second argument,  
program operation cannot be guaranteed.  
If when using the M16C an undefined value is specified for any waveform  
generation control register in the third argument, operation of the API cannot be  
guaranteed.  
If when using the H8/300H an undefined value is specified for the output operation  
of any channel in the third argument, operation of the API cannot be guaranteed.  
If when using the M16C or the H8/300H an undefined value is specified in the  
fourth argument, operation of the API cannot be guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
Rev.1.01  
2007.02.16  
131  
RJJ10J1643-0101  
 
#include "rapi_timer_r8c_13.h"  
void TimerIntFunc0( void ){}  
void TimerIntFunc1( void ){}  
void TimerIntFunc2( void ){}  
void func( void )  
{
unsignedint*p_func[]= {(void*)TimerIntFunc0,(void*)TimerIntFunc1,  
(void*) TimerIntFunc2};  
unsigned char p_ic[] = {1,2,3};  
unsigned int p_cmp[] = {0x1234, 0x9876};  
/* Set up timer C as output compare mode */  
__CreateOutputCompare(  
RAPI_TIMER_C|RAPI_TIMER_ON|RAPI_RELOAD|RAPI_L_1|RAPI_L_0|RAPI_F32|  
RAPI_CMP02_ENABLE|RAPI_CMP12_ENABLE, p_cmp, p_ic, p_func );  
}
Rev.1.01  
2007.02.16  
132  
RJJ10J1643-0101  
 
__EnableOutputCompare  
Synopsis  
<Control operation of output compare mode>  
Boolean __EnableOutputCompare(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Controls operation of the timer that is set to specified output compare mode by starting  
or stopping it.  
[data]  
For data, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_S  
Selects timer S.  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
Sets the timer that is set to output compare mode to start operating.  
Sets the timer that is set to output compare mode to stop operating.  
(R8C)  
RAPI_TIMER_C  
Selects timer C.  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RE  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
Selects timer RD channel 0.  
Selects timer RD channel 1.  
Selects timer RE.  
Sets the timer that is set to output compare mode to start operating.  
Sets the timer that is set to output compare mode to stop operating.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RD2  
RAPI_TIMER_RD3  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RD0.  
Selects timer RD0 channe 0.  
Selects timer RD0 channe 1.  
Selects timer RD0 channe 2.  
Selects timer RD0 channe 3.  
Sets the timer that is set to output compare mode to start operating.  
Sets the timer that is set to output compare mode to stop operating.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (output compare mode)  
__CreateOutputCompare, __DestroyOutputCompare  
If an undefined value is specified in the argument, operation of the API cannot be  
Rev.1.01  
2007.02.16  
133  
RJJ10J1643-0101  
 
guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include "rapi_timer_r8c_13.h"  
void func( void )  
{
/* Enable timer C as output compare mode */  
__EnableOutputCompare( RAPI_TIMER_C|RAPI_TIMER_ON );  
}
Rev.1.01  
2007.02.16  
134  
RJJ10J1643-0101  
 
__DestroyOutputCompare  
Synopsis  
<Discard settings of output compare mode>  
Boolean __DestroyOutputCompare(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Discards settings of the timer that is set to specified output compare mode.  
[data]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_S  
Selects timer S.  
(R8C)  
RAPI_TIMER_C  
Selects timer C.  
RAPI_TIMER_RD0 Selects timer RD channel 0.  
RAPI_TIMER_RD1 Selects timer RD channel 1.  
RAPI_TIMER_RE  
Selects timer RE.  
(H8/300H)  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RD0.  
RAPI_TIMER_RD0 Selects timer RD0 channe 0.  
RAPI_TIMER_RD1 Selects timer RD0 channe 1.  
RAPI_TIMER_RD2 Selects timer RD0 channe 2.  
RAPI_TIMER_RD3 Selects timer RD0 channe 3.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (output compare mode)  
__CreateOutputCompare, __EnableOutputCompare  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
When used for the H8/300H, this API places a specified timer into module stanby  
state after discarding it.  
Program example  
#include "rapi_timer_r8c_13.h"  
Rev.1.01  
2007.02.16  
135  
RJJ10J1643-0101  
 
void func( void )  
{
/* Destroy the setting of timer C as output compare mode */  
__DestroyOutputCompare( RAPI_TIMER_C );  
}
Rev.1.01  
2007.02.16  
136  
RJJ10J1643-0101  
 
__SetTimerRegister  
Synopsis  
<Set timer register>  
Boolean __SetTimerRegister(unsigned long data1, unsigned int *data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Pointer to the buffer in which register value is stored  
Description  
Sets the registers of a specified timer.  
[data1]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_TIMER_S  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2.  
Selects timer A channel 3.  
Selects timer A channel 4.  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
Selects timer S.  
(R8C)  
RAPI_TIMER_C  
RAPI_TIMER_X  
RAPI_TIMER_Y  
RAPI_TIMER_Z  
RAPI_TIMER_RA  
RAPI_TIMER_RB  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RE  
Selects timer C.  
Selects timer X.  
Selects timer Y.  
Selects timer Z.  
Selects timer RA.  
Selects timer RB.  
Selects timer RD channel 0.  
Selects timer RD channel 1.  
Selects timer RE.  
(H8/300H)  
RAPI_TIMER_A  
RAPI_TIMER_B1  
RAPI_TIMER_V  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RD2  
RAPI_TIMER_RD3  
Selects timer A.  
Selects timer B1.  
Selects timer V.  
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RC.  
Selects timer RD channel 0.  
Selects timer RD channel 1.  
Selects timer RD channel 2.  
Selects timer RD channel 3.  
Rev.1.01  
2007.02.16  
137  
RJJ10J1643-0101  
 
[data2]  
The content of a pointer to the buffer in which the register value is stored must be specified  
as described below. The value is set in each register in order of buffer pointer elements.  
(M16C)  
• When using timer A (RAPI_TIMER_A0 to RAPI_TIMER_A4 specified)  
[0]: Specify the set value for the timer Ai mode register (i = 0–4).  
[1]: Specify the set value for the timer Ai register (i = 0–4).  
[2]: Specify the set value for the up/down flag register.  
[3]: Specify the set value for the one-shot start flag register.  
[4]: Specify the set value for the trigger select register.  
[5]: Specify the set value for the time-clock prescaler reset register.  
[6]: Specify the set value for the count start flag register.  
• When using timer B (RAPI_TIMER_B0 to RAPI_TIMER_B2)  
[0]: Specify the set value for the timer Bi mode register (i = 0–2).  
[1]: Specify the set value for the timer Bi register (i = 0–2).  
[3]: Specify the set value for the time-clock prescaler reset register.  
[4]: Specify the set value for the count start flag register.  
• When using timer S (RAPI_TIMER_S specified)  
[0]: Specify the set value for the base timer register.  
[1]: Specify the set value for the base timer reset register.  
[2]: Specify the set value for base timer control register 0.  
[3]: Specify the set value for base timer control register 1.  
[4]: Specify the set value for the count source divide-by-n register.  
[5]: Specify the set value for time measurement control register 0.  
[6]: Specify the set value for time measurement control register 1.  
[7]: Specify the set value for time measurement control register 2.  
[8]: Specify the set value for time measurement control register 3.  
[9]: Specify the set value for time measurement control register 4.  
[10]: Specify the set value for time measurement control register 5.  
[11]: Specify the set value for time measurement control register 6.  
[12]: Specify the set value for time measurement control register 7.  
[13]: Specify the set value for time measurement prescaler register 6.  
[14]: Specify the set value for time measurement prescaler register 7.  
[15]: Specify the set value for waveform generation control register 0.  
[16]: Specify the set value for waveform generation control register 1.  
[17]: Specify the set value for waveform generation control register 2.  
[18]: Specify the set value for waveform generation control register 3.  
[19]: Specify the set value for waveform generation control register 4.  
[20]: Specify the set value for waveform generation control register 5.  
[21]: Specify the set value for waveform generation control register 6.  
[22]: Specify the set value for waveform generation control register 7.  
[23]: Specify the set value for waveform generation register 0.  
[24]: Specify the set value for waveform generation register 1.  
[25]: Specify the set value for waveform generation register 2.  
[26]: Specify the set value for waveform generation register 3.  
Rev.1.01  
2007.02.16  
138  
RJJ10J1643-0101  
 
[27]: Specify the set value for waveform generation register 4.  
[28]: Specify the set value for waveform generation register 5.  
[29]: Specify the set value for waveform generation register 6.  
[30]: Specify the set value for waveform generation register 7.  
[31]: Specify the set value for the facility select register.  
[32]: Specify the set value for the facility enable register.  
[33]: Specify the set value for the interrupt request register.  
[34]: Specify the set value for interrupt enable register 0.  
[35]: Specify the set value for interrupt enable register 1.  
(R8C)  
• When using timer C (RAPI_TIMER_C specified)  
[0]: Specify the set value for the timer C output control register.  
[1]: Specify the set value for timer C control register 0.  
[2]: Specify the set value for timer C control register 1.  
[3]: Specify the set value for the capture & compare 0 register.  
[4]: Specify the set value for the compare 1 register.  
• When using timer X (RAPI_TIMER_X specified)  
[0]: Specify the set value for the timer count source setup register.  
[1]: Specify the set value for the prescaler X register.  
[2]: Specify the set value for the timer X register.  
[3]: Specify the set value for the timer X mode register.  
• When using timer Y (RAPI_TIMER_Y specified)  
[0]: Specify the set value for the timer count source setup register.  
[1]: Specify the set value for the prescaler Y register.  
[2]: Specify the set value for the timer Y primary register.  
[3]: Specify the set value for the timer Y secondary register.  
[4]: Specify the set value for the timer Y & Z waveform output control register.  
[5]: Specify the set value for the timer Y & Z output control register.  
[6]: Specify the set value for the timer Y & Z mode register.  
• When using timer Z (RAPI_TIMER_Z specified)  
[0]: Specify the set value for the timer count source setup register.  
[1]: Specify the set value for the prescaler Z register.  
[2]: Specify the set value for the timer Z primary register.  
[3]: Specify the set value for the timer Z secondary register.  
[4]: Specify the set value for the timer Y & Z waveform output control register.  
[5]: Specify the set value for the timer Y & Z output control register.  
[6]: Specify the set value for the timer Y & Z mode register.  
• When using timer RA (RAPI_TIMER_RA specified)  
[0]: Specify the set value for the timer RA I/O control register.  
[1]: Specify the set value for the timer RA prescaler register.  
[2]: Specify the set value for the timer RA register.  
[3]: Specify the set value for the timer RA mode register.  
[4]: Specify the set value for the timer RA control register.  
• When using timer RB (RAPI_TIMER_RB specified)  
[0]: Specify the set value for the timer RB one shot control register.  
Rev.1.01  
2007.02.16  
139  
RJJ10J1643-0101  
 
[1]: Specify the set value for the timer RB I/O control register.  
[2]: Specify the set value for the timer RB prescaler register.  
[3]: Specify the set value for the timer RB primary register.  
[4]: Specify the set value for the timer RB secondary register.  
[5]: Specify the set value for the timer RB mode register.  
[6]: Specify the set value for the timer RB control register.  
• When using timer RD (RAPI_TIMER_RD0 to RAPI_TIMER_RD1)  
[0]: Specify the set value for the timer RD mode register.  
[1]: Specify the set value for the timer RD PWM mode register.  
[2]: Specify the set value for the timer RD function control register.  
[3]: Specify the set value for the timer RD general register Ai (i=0,1).  
[4]: Specify the set value for the timer RD general register Bi (i=0,1).  
[5]: Specify the set value for the timer RD general register Ci (i=0,1).  
[6]: Specify the set value for the timer RD general register Di (i=0,1).  
[7]: Specify the set value for the timer RD digital filter function select register  
i(i=0,1).  
[8]: Specify the set value for the timer RD control register i(i=0,1).  
[9]: Specify the set value for the timer RD I/O control register Ai(i=0,1).  
[10]: Specify the set value for the timer RD I/O control register Ci(i=0,1).  
[11]: Specify the set value for the timer RD status register i(i=0,1).  
[12]: Specify the set value for the timer RD interrupt enable register i(i=0,1).  
[13]: Specify the set value for the timer RD counter i(i=0,1).  
[14]: Specify the set value for the timer RD start register.  
[15]: Specify the set value for the timer RD output master enable register 1.  
[16]: Specify the set value for the timer RD output master enable register 2.  
[17]: Specify the set value for the timer RD output control register.  
• When using timer RE (RAPI_TIMER_RE)  
[0]: Specify the set value for the timer RE second data register.  
[1]: Specify the set value for the timer RE minute data register.  
[2]: Specify the set value for the timer RE hour data register.  
[3]: Specify the set value for the timer RE day of week data register.  
[4]: Specify the set value for the timer RE control register 2.  
[5]: Specify the set value for the timer RE count source select register.  
[6]: Specify the set value for the timer RE control register 1.  
(H8/300H)  
• When using timer A (RAPI_TIMER_A specified)  
[0]: Specify the set value for timer mode register A.  
[1]: Specify the set value for timer counter A.  
• When using timer B1 (RAPI_TIMER_B1 specified)  
[0]: Specify the set value for timer mode register B1.  
[1]: Specify the set value for timer load register B1.  
• When using timer V (RAPI_TIMER_V specified)  
[0]: Specify the set value for timer counter V.  
[1]: Specify the set value for time constant register A.  
[2]: Specify the set value for time constant register B.  
Rev.1.01  
2007.02.16  
140  
RJJ10J1643-0101  
 
[3]: Specify the set value for timer control register V0.  
[4]: Specify the set value for timer control register V1.  
[5]: Specify the set value for timer control/status register V.  
• When using timer W (RAPI_TIMER_W specified)  
[0]: Specify the set value for timer control register W.  
[1]: Specify the set value for timer interrupt enable register W.  
[2]: Specify the set value for timer status register W.  
[3]: Specify the set value for timer I/O control register 0.  
[4]: Specify the set value for timer I/O control register 1.  
[5]: Specify the set value for the timer counter.  
[6]: Specify the set value for general register A.  
[7]: Specify the set value for general register B.  
[8]: Specify the set value for general register C.  
[9]: Specify the set value for general register D.  
[10]: Specify the set value for the timer mode register W.  
• When using timer Z (RAPI_TIMER_Z0 to RAPI_TIMER_Z1 specified)  
[0]: Specify the set value for the timer mode register.  
[1]: Specify the set value for the timer PWM mode register.  
[2]: Specify the set value for the timer function control register.  
[3]: Specify the set value for the timer output master enable register.  
[4]: Specify the set value for the timer output control register.  
[5]: Specify the set value for the timer counter.  
[6]: Specify the set value for general register A i(i=0,1).  
[7]: Specify the set value for general register B i(i=0,1).  
[8]: Specify the set value for general register C i(i=0,1).  
[9]: Specify the set value for general register D i(i=0,1).  
[10]: Specify the set value for timer control register_i (i = 0, 1).  
[11]: Specify the set value for timer I/O control register A_i (i = 0, 1).  
[12]: Specify the set value for timer I/O control register C_i (i = 0, 1).  
[13]: Specify the set value for timer status register_i (i = 0, 1).  
[14]: Specify the set value for timer interrupt enable register_i (i = 0, 1).  
[15]: Specify the set value for PWM mode output level control register_i (i = 0, 1).  
[16]: Specify the set value for the timer start register.  
• When using timer RC (RAPI_TIMER_RC)  
[0]: Specify the set value for timer RC control register 1.  
[1]: Specify the set value for timer RC control register 2.  
[2]: Specify the set value for timer RC interrupt enable register.  
[3]: Specify the set value for timer RC status register.  
[4]: Specify the set value for timer RC I/O control register 0.  
[5]: Specify the set value for timer RC I/O control register 1.  
[6]: Specify the set value for timer RC output enable register.  
[7]: Specify the set value for timer RC digital filter function select register.  
[8]: Specify the set value for timer RC counter.  
[9]: Specify the set value for general register A.  
[10]: Specify the set value for general register B.  
Rev.1.01  
2007.02.16  
141  
RJJ10J1643-0101  
 
[11]: Specify the set value for general register C.  
[12]: Specify the set value for general register D.  
[13]: Specify the set value for timer RC mode register.  
• When using timer RD (RAPI_TIMER_RD0 to RAPI_TIMER_RD3 specified)  
[0]: Specify the set value for the timer RD mode register.  
[1]: Specify the set value for the timer RD PWM mode register.  
[2]: Specify the set value for the timer RD function control register.  
[3]: Specify the set value for the timer RD output master enable register 1.  
[4]: Specify the set value for the timer RD output master enable register 2.  
[5]: Specify the set value for the timer RD output control register.  
[6]: Specify the set value for the timer RD counter i(i=0,1).  
[7]: Specify the set value for general register A_i(i=0,1).  
[8]: Specify the set value for general register B_i(i=0,1).  
[9]: Specify the set value for general register C_i(i=0,1).  
[10]: Specify the set value for general register D_i(i=0,1).  
[11]: Specify the set value for timer RD control register_i (i = 0, 1).  
[12]: Specify the set value for timer RD I/O control register A_i (i = 0, 1).  
[13]: Specify the set value for timer RD I/O control register C_i (i = 0, 1).  
[14]: Specify the set value for timer RD status register_i (i = 0, 1).  
[15]: Specify the set value for timer RD interrupt enable register_i (i = 0, 1).  
[16]: Specify the set value for PWM mode output level control register_i (i = 0, 1).  
[17]: Specify the set value for the timer RD digital filter function select register i(i = 0,  
1).  
[18]: Specify the set value for the timer RD start register.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (register manipulation)  
__EnableTimerRegister, __ClearTimerRegister, __GetTimerRegister  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include " rapi_timer_r8c_13.h"  
void func( void )  
{
unsigned char data[] = {0,0,0,0,0,0,0};  
/* Set up timer Z register */  
__SetTimerRegister( RAPI_TIMER_Z, data );  
}
Rev.1.01  
2007.02.16  
142  
RJJ10J1643-0101  
 
__EnableTimerRegister  
Synopsis  
<Control operation of timer register>  
Boolean __EnableTimerRegister(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Controls operation of a specified timer by starting or stopping it.  
[data]  
For data, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_TIMER_S  
RAPI_TIMER_ON  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2.  
Selects timer A channel 3.  
Selects timer A channel 4.  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
Selects timer S.  
Sets the selected timer to start operating.  
RAPI_TIMER_OFF Sets the selected timer to stop operating.  
(R8C)  
RAPI_TIMER_C  
Selects timer C.  
RAPI_TIMER_X  
RAPI_TIMER_Y  
RAPI_TIMER_Z  
Selects timer X.  
Selects timer Y.  
Selects timer Z.  
RAPI_TIMER_RA  
RAPI_TIMER_RB  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RE  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
Selects timer RA.  
Selects timer RB.  
Selects timer RD channel 0.  
Selects timer RD channel 1.  
Selects timer RE.  
Sets the selected timer to start operating.  
Sets the selected timer to stop operating.  
(H8/300H)  
RAPI_TIMER_V  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
Selects timer V.  
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RC.  
Selects timer RD channel 0.  
Selects timer RD channel 1.  
Rev.1.01  
2007.02.16  
143  
RJJ10J1643-0101  
 
RAPI_TIMER_RD2  
RAPI_TIMER_RD3  
RAPI_TIMER_ON  
RAPI_TIMER_OFF  
Selects timer RD channel 2.  
Selects timer RD channel 3.  
Sets the selected timer to start operating.  
Sets the selected timer to stop operating.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (register manipulation)  
__SetTimerRegister, __ClearTimerRegister, __GetTimerRegister  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
To specify commencement of timer operation when using timer V of the H8/300H, set the  
clock and count condition to be supplied to TCNTV that are specified in __SetTimerRegister  
immediately preceding this API.  
Program example  
#include " rapi_timer_r8c_13.h"  
void func( void )  
{
/* Activate timer C */  
__EnableTimerRegister( RAPI_TIMER_C|RAPI_TIMER_ON );  
}
Rev.1.01  
2007.02.16  
144  
RJJ10J1643-0101  
 
__ClearTimerRegister  
Synopsis  
<Clear timer register>  
Boolean __ClearTimerRegister(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Sets the timer register of a specified timer to its initial value after reset.  
[data]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_TIMER_S  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2.  
Selects timer A channel 3.  
Selects timer A channel 4.  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
Selects timer S.  
(R8C)  
RAPI_TIMER_C  
RAPI_TIMER_X  
RAPI_TIMER_Y  
RAPI_TIMER_Z  
RAPI_TIMER_RA  
RAPI_TIMER_RB  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RE  
Selects timer C.  
Selects timer X.  
Selects timer Y.  
Selects timer Z.  
Selects timer RA.  
Selects timer RB.  
Selects timer RD channel 0.  
Selects timer RD channel 1.  
Selects timer RE.  
(H8/300H)  
RAPI_TIMER_A  
Selects timer A.  
RAPI_TIMER_B1  
RAPI_TIMER_V  
Selects timer B1.  
Selects timer V.  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RD2  
RAPI_TIMER_RD3  
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RC.  
Selects timer RD channel 0.  
Selects timer RD channel 1.  
Selects timer RD channel 2.  
Selects timer RD channel 3.  
Rev.1.01  
2007.02.16  
145  
RJJ10J1643-0101  
 
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
Remark  
Timer (register manipulation)  
__SetTimerRegister, __EnableTimerRegister, __GetTimerRegister  
If an undefined value is specified in the argument, operation of the API cannot be  
guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include " rapi_timer_r8c_13.h"  
void func( void )  
{
/* Clear the setting of timer C */  
__ClearTimerRegister( RAPI_TIMER_C );  
}
Rev.1.01  
2007.02.16  
146  
RJJ10J1643-0101  
 
__GetTimerRegister  
Synopsis  
<Get timer register value>  
Boolean __GetTimerRegister(unsigned long data1, unsigned int *data2)  
data1  
data2  
Setup data (content differs with MCU type)  
Pointer to the buffer in which register value is stored  
Description  
Gets the counter value of a specified timer.  
[data]  
For data, the following definition values can be set.  
(M16C)  
RAPI_TIMER_A0  
RAPI_TIMER_A1  
RAPI_TIMER_A2  
RAPI_TIMER_A3  
RAPI_TIMER_A4  
RAPI_TIMER_B0  
RAPI_TIMER_B1  
RAPI_TIMER_B2  
RAPI_TIMER_S  
Selects timer A channel 0.  
Selects timer A channel 1.  
Selects timer A channel 2.  
Selects timer A channel 3.  
Selects timer A channel 4.  
Selects timer B channel 0.  
Selects timer B channel 1.  
Selects timer B channel 2.  
Selects timer S.  
(R8C)  
RAPI_TIMER_C  
RAPI_TIMER_X  
RAPI_TIMER_Y  
RAPI_TIMER_Z  
RAPI_TIMER_RA  
RAPI_TIMER_RB  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RE  
Selects timer C.  
Selects timer X.  
Selects timer Y.  
Selects timer Z.  
Selects timer RA.  
Selects timer RB.  
Selects timer RD channel 0.  
Selects timer RD channel 1.  
Selects timer RE.  
(H8/300H)  
RAPI_TIMER_A  
Selects timer A.  
RAPI_TIMER_B1  
RAPI_TIMER_V  
Selects timer B1.  
Selects timer V.  
RAPI_TIMER_W  
RAPI_TIMER_Z0  
RAPI_TIMER_Z1  
RAPI_TIMER_RC  
RAPI_TIMER_RD0  
RAPI_TIMER_RD1  
RAPI_TIMER_RD2  
RAPI_TIMER_RD3  
Selects timer W.  
Selects timer Z channel 0.  
Selects timer Z channel 1.  
Selects timer RC.  
Selects timer RD channel 0.  
Selects timer RD channel 1.  
Selects timer RD channel 2.  
Selects timer RD channel 3.  
Rev.1.01  
2007.02.16  
147  
RJJ10J1643-0101  
 
[data2]  
Specify a pointer to the array in which the acquired register value is stored.  
The content of the array is described below.  
(M16C)  
When using timer A (RAPI_TIMER_A0 to RAPI_TIMER_A4 specified)  
[0]: Store the value of timer Ai mode register (i = 0–4).  
[1]: Store the value of timer Ai register (i = 0–4).  
[2]: Store the value of the up/down flag register.  
[3]: Store the value of the one-shot start flag register.  
[4]: Store the value of the trigger select register.  
[5]: Store the value of the time-clock prescaler reset flag register.  
[6]: Store the value of the count start flag register.  
When using timer B (RAPI_TIMER_B0 to RAPI_TIMER_B2 specified)  
[0]: Store the value of timer Bi mode register (i = 0–2).  
[1]: Store the value of timer Bi register (i = 0–2).  
[2]: Store the value of the time-clock prescaler reset flag register.  
[3]: Store the value of the count start flag register.  
When using timer S (RAPI_TIMER_S specified)  
[0]: Store the value of the base timer register.  
[1]: Store the value of the base timer reset register.  
[2]: Store the value of base timer control register 0.  
[3]: Store the value of base timer control register 1.  
[4]: Store the value of the count source divide-by-n register.  
[5]: Store the value of time measurement control register 0.  
[6]: Store the value of time measurement control register 1.  
[7]: Store the value of time measurement control register 2.  
[8]: Store the value of time measurement control register 3.  
[9]: Store the value of time measurement control register 4.  
[10]: Store the value of time measurement control register 5.  
[11]: Store the value of time measurement control register 6.  
[12]: Store the value of time measurement control register 7.  
[13]: Store the value of time measurement prescaler register 6.  
[14]: Store the value of time measurement prescaler register 7.  
[15]: Store the value of waveform generation control register 0.  
[16]: Store the value of waveform generation control register 1.  
[17]: Store the value of waveform generation control register 2.  
[18]: Store the value of waveform generation control register 3.  
[19]: Store the value of waveform generation control register 4.  
[20]: Store the value of waveform generation control register 5.  
[21]: Store the value of waveform generation control register 6.  
[22]: Store the value of waveform generation control register 7.  
[23]: Store the value of time measurement register 0.  
[24]: Store the value of time measurement register 1/waveform generation register 1.  
[25]: Store the value of time measurement register 2/waveform generation register 2.  
Rev.1.01  
2007.02.16  
148  
RJJ10J1643-0101  
 
[26]: Store the value of time measurement register 3/waveform generation register 3.  
[27]: Store the value of time measurement register 4/waveform generation register 4.  
[28]: Store the value of time measurement register 5/waveform generation register 5.  
[29]: Store the value of time measurement register 6/waveform generation register 6.  
[30]: Store the value of time measurement register 7/waveform generation register 7.  
[31]: Store the value of the facility select register.  
[32]: Store the value of the facility enable register.  
[33]: Store the value of the interrupt request register.  
[34]: Store the value of interrupt enable register 0.  
[35]: Store the value of interrupt enable register 1.  
(R8C)  
When using timer C (RAPI_TIMER_C specified)  
[0]: Store the value of the timer C register.  
[1]: Store the value of the capture & compare 0 register.  
[2]: Store the value of the compare 1 register.  
[3]: Store the value of the timer C output control register.  
[4]: Store the value of timer C control register 1.  
[5]: Store the value of timer C control register 0.  
When using timer X (RAPI_TIMER_X specified)  
[0]: Store the value of the timer count source setup register.  
[1]: Store the value of the prescaler X register.  
[2]: Store the value of the timer X register.  
[3]: Store the value of the timer X mode register.  
When using timer Y (RAPI_TIMER_Y specified)  
[0]: Store the value of the timer count source setup register.  
[1]: Store the value of the prescaler Y register.  
[2]: Store the value of the timer Y primary register.  
[3]: Store the value of the timer Y secondary register.  
[4]: Store the value of the timer Y & Z waveform output control register.  
[5]: Store the value of the timer Y & Z output control register.  
[6]: Store the value of the timer Y & Z mode register.  
When using timer Z (RAPI_TIMER_Z specified)  
[0]: Store the value of the timer count source setup register.  
[1]: Store the value of the prescaler Z register.  
[2]: Store the value of the timer Z primary register.  
[3]: Store the value of the timer Z secondary register.  
[4]: Store the value of the timer Y & Z waveform output control register.  
[5]: Store the value of the timer Y & Z output control register.  
[6]: Store the value of the timer Y & Z mode register.  
• When using timer RA (RAPI_TIMER_RA specified)  
[0]: Specify the set value for the timer RA I/O control register.  
[1]: Specify the set value for the timer RA prescaler register.  
[2]: Specify the set value for the timer RA register.  
[3]: Specify the set value for the timer RA mode register.  
[4]: Specify the set value for the timer RA control register.  
Rev.1.01  
2007.02.16  
149  
RJJ10J1643-0101  
 
• When using timer RB (RAPI_TIMER_RB specified)  
[0]: Specify the set value for the timer RB one shot control register.  
[1]: Specify the set value for the timer RB I/O control register.  
[2]: Specify the set value for the timer RB prescaler register.  
[3]: Specify the set value for the timer RB primary register.  
[4]: Specify the set value for the timer RB secondary register.  
[5]: Specify the set value for the timer RB mode register.  
[6]: Specify the set value for the timer RB control register.  
• When using timer RD (RAPI_TIMER_RD0 to RAPI_TIMER_RD1)  
[0]: Specify the set value for the timer RD mode register.  
[1]: Specify the set value for the timer RD PWM mode register.  
[2]: Specify the set value for the timer RD function control register.  
[3]: Specify the set value for the timer RD general register Ai (i=0,1).  
[4]: Specify the set value for the timer RD general register Bi (i=0,1).  
[5]: Specify the set value for the timer RD general register Ci (i=0,1).  
[6]: Specify the set value for the timer RD general register Di (i=0,1).  
[7]: Specify the set value for the timer RD digital filter function select register  
i(i=0,1).  
[8]: Specify the set value for the timer RD control register i(i=0,1).  
[9]: Specify the set value for the timer RD I/O control register Ai(i=0,1).  
[10]: Specify the set value for the timer RD I/O control register Ci(i=0,1).  
[11]: Specify the set value for the timer RD status register i(i=0,1).  
[12]: Specify the set value for the timer RD interrupt enable register i(i=0,1).  
[13]: Specify the set value for the timer RD counter i(i=0,1).  
[14]: Specify the set value for the timer RD start register.  
[15]: Specify the set value for the timer RD output master enable register 1.  
[16]: Specify the set value for the timer RD output master enable register 2.  
[17]: Specify the set value for the timer RD output control register.  
• When using timer RE (RAPI_TIMER_RE)  
[0]: Specify the set value for the timer RE second data register.  
[1]: Specify the set value for the timer RE minute data register.  
[2]: Specify the set value for the timer RE hour data register.  
[3]: Specify the set value for the timer RE day of week data register.  
[4]: Specify the set value for the timer RE control register 2.  
[5]: Specify the set value for the timer RE count source select register.  
[6]: Specify the set value for the timer RE control register 1.  
(H8/300H)  
When using timer A (RAPI_TIMER_A specified)  
[0]: Store the value of timer mode register A.  
[1]: Store the value of timer counter A.  
When using timer B1 (RAPI_TIMER_B1 specified)  
[0]: Store the value of timer mode register B1.  
[1]: Store the value of timer counter B1.  
When using timer V (RAPI_TIMER_V specified)  
[0]: Store the value of timer counter V.  
Rev.1.01  
2007.02.16  
150  
RJJ10J1643-0101  
 
[1]: Store the value of time constant register A.  
[2]: Store the value of time constant register B.  
[3]: Store the value of timer control register V0.  
[4]: Store the value of timer control register V1.  
[5]: Store the value of timer control/status register V.  
When using timer W (RAPI_TIMER_W specified)  
[0]: Store the value of timer mode register W.  
[1]: Store the value of timer control register W.  
[2]: Store the value of timer interrupt master enable register W.  
[3]: Store the value of timer status register W.  
[4]: Store the value of timer I/O control register 0.  
[5]: Store the value of timer I/O control register 1.  
[6]: Store the value of the timer counter.  
[7]: Store the value of general register A.  
[8]: Store the value of general register B.  
[9]: Store the value of general register C.  
[10]: Store the value of general register D.  
When using timer Z (RAPI_TIMER_Z specified)  
[0]: Store the value of the timer start register.  
[1]: Store the value of the timer mode register.  
[2]: Store the value of the timer PWM mode register.  
[3]: Store the value of the timer function control register.  
[4]: Store the value of the timer output master enable register.  
[5]: Store the value of the timer output control register.  
[6]: Store the value of timer counter_i (i = 0, 1).  
[7]: Store the value of general register A_i (i = 0, 1).  
[8]: Store the value of general register B_i (i=0, 1).  
[9]: Store the value of general register C_i (i=0, 1).  
[10]: Store the value of general register D_i (i=0, 1).  
[11]: Store the value of timer control register_i (i = 0, 1).  
[12]: Store the value of timer I/O control register A_i (i = 0, 1).  
[13]: Store the value of timer I/O control register B_i (i = 0, 1).  
[14]: Store the value of timer status register_i (i = 0, 1).  
[15]: Store the value of timer interrupt enable register_i (i = 0, 1).  
[16]: Store the value of PWM mode output level control register_i (i = 0, 1).  
• When using timer RC (RAPI_TIMER_RC)  
[0]: Specify the set value for timer RC control register 1.  
[1]: Specify the set value for timer RC control register 2.  
[2]: Specify the set value for timer RC interrupt enable register.  
[3]: Specify the set value for timer RC status register.  
[4]: Specify the set value for timer RC I/O control register 0.  
[5]: Specify the set value for timer RC I/O control register 1.  
[6]: Specify the set value for timer RC output enable register.  
[7]: Specify the set value for timer RC digital filter function select register.  
[8]: Specify the set value for timer RC counter.  
Rev.1.01  
2007.02.16  
151  
RJJ10J1643-0101  
 
[9]: Specify the set value for general register A.  
[10]: Specify the set value for general register B.  
[11]: Specify the set value for general register C.  
[12]: Specify the set value for general register D.  
[13]: Specify the set value for timer RC mode register.  
• When using timer RD (RAPI_TIMER_RD0 to RAPI_TIMER_RD3 specified)  
[0]: Specify the set value for the timer RD mode register.  
[1]: Specify the set value for the timer RD PWM mode register.  
[2]: Specify the set value for the timer RD function control register.  
[3]: Specify the set value for the timer RD output master enable register 1.  
[4]: Specify the set value for the timer RD output master enable register 2.  
[5]: Specify the set value for the timer RD output control register.  
[6]: Specify the set value for the timer RD counter i(i=0,1).  
[7]: Specify the set value for general register A_i(i=0,1).  
[8]: Specify the set value for general register B_i(i=0,1).  
[9]: Specify the set value for general register C_i(i=0,1).  
[10]: Specify the set value for general register D_i(i=0,1).  
[11]: Specify the set value for timer RD control register_i (i = 0, 1).  
[12]: Specify the set value for timer RD I/O control register A_i (i = 0, 1).  
[13]: Specify the set value for timer RD I/O control register C_i (i = 0, 1).  
[14]: Specify the set value for timer RD status register_i (i = 0, 1).  
[15]: Specify the set value for timer RD interrupt enable register_i (i = 0, 1).  
[16]: Specify the set value for PWM mode output level control register_i (i = 0, 1).  
[17]: Specify the set value for the timer RD digital filter function select register i(i = 0,  
1).  
[18]: Specify the set value for the timer RD start register.  
Return value  
If the timer specification is incorrect, RAPI_FALSE is returned; otherwise, RAPI_TRUE  
is returned.  
Functionality  
Reference  
Remark  
Timer (register manipulation)  
__SetTimerRegister, __EnableTimerRegister, __ClearTimerRegister  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable timers differ with each CPU used.  
Program example  
#include " rapi_timer_r8c_13.h"  
void func( void )  
{
unsigned int data[7];  
/* Get the value of timer Z registers */  
__GetTimerRegister( RAPI_TIMER_Z, data );  
}
Rev.1.01  
2007.02.16  
152  
RJJ10J1643-0101  
 
4.2.3 I/O Port  
__SetIOPort  
Synopsis  
<Set I/O port>  
Boolean __SetIOPort(unsigned long data1, unsigned int data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Description  
Sets the operating conditions of a specified I/O port.  
[data1]  
For data1, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value. Note, however, that  
multiple ports cannot be specified at the same time.  
(M16C)  
The definition values corresponding to each I/O port are listed below.  
RAPI_PORT_0_0  
RAPI_PORT_0_2  
RAPI_PORT_0_4  
RAPI_PORT_0_6  
RAPI_PORT_1_0  
RAPI_PORT_1_2  
RAPI_PORT_1_4  
RAPI_PORT_1_6  
RAPI_PORT_2_0  
RAPI_PORT_2_2  
RAPI_PORT_2_4  
RAPI_PORT_2_6  
RAPI_PORT_3_0  
RAPI_PORT_3_2  
RAPI_PORT_3_4  
RAPI_PORT_3_6  
RAPI_PORT_6_0  
RAPI_PORT_6_2  
RAPI_PORT_6_4  
RAPI_PORT_6_6  
RAPI_PORT_7_0  
RAPI_PORT_7_2  
RAPI_PORT_7_4  
RAPI_PORT_7_6  
RAPI_PORT_8_0  
RAPI_PORT_8_2  
RAPI_PORT_8_4  
RAPI_PORT_8_6  
Port P00  
Port P02  
Port P04  
Port P06  
Port P10  
Port P12  
Port P14  
Port P16  
Port P20  
Port P22  
Port P24  
Port P26  
Port P30  
Port P32  
Port P34  
Port P36  
Port P60  
Port P62  
Port P64  
Port P66  
Port P70  
Port P72  
Port P74  
Port P76  
Port P80  
Port P82  
Port P84  
Port P86  
RAPI_PORT_0_1  
RAPI_PORT_0_3  
RAPI_PORT_0_5  
RAPI_PORT_0_7  
RAPI_PORT_1_1  
RAPI_PORT_1_3  
RAPI_PORT_1_5  
RAPI_PORT_1_7  
RAPI_PORT_2_1  
RAPI_PORT_2_3  
RAPI_PORT_2_5  
RAPI_PORT_2_7  
RAPI_PORT_3_1  
RAPI_PORT_3_3  
RAPI_PORT_3_5  
RAPI_PORT_3_7  
RAPI_PORT_6_1  
RAPI_PORT_6_3  
RAPI_PORT_6_5  
RAPI_PORT_6_7  
RAPI_PORT_7_1  
RAPI_PORT_7_3  
RAPI_PORT_7_5  
RAPI_PORT_7_7  
RAPI_PORT_8_1  
RAPI_PORT_8_3  
RAPI_PORT_8_5  
RAPI_PORT_8_7  
Port P01  
Port P03  
Port P05  
Port P07  
Port P11  
Port P13  
Port P15  
Port P17  
Port P21  
Port P23  
Port P25  
Port P27  
Port P31  
Port P33  
Port P35  
Port P37  
Port P61  
Port P63  
Port P65  
Port P67  
Port P71  
Port P73  
Port P75  
Port P77  
Port P81  
Port P83  
Port P85  
Port P87  
Rev.1.01  
2007.02.16  
153  
RJJ10J1643-0101  
 
RAPI_PORT_9_0  
RAPI_PORT_9_2  
RAPI_PORT_9_5  
RAPI_PORT_9_7  
RAPI_PORT_10_1  
RAPI_PORT_10_3  
RAPI_PORT_10_5  
RAPI_PORT_10_7  
Port P90  
Port P92  
Port P95  
Port P97  
Port P101  
Port P103  
Port P105  
Port P107  
RAPI_PORT_9_1  
RAPI_PORT_9_3  
RAPI_PORT_9_6  
RAPI_PORT_10_0  
RAPI_PORT_10_2  
RAPI_PORT_10_4  
RAPI_PORT_10_6  
Port P91  
Port P93  
Port P96  
Port P100  
Port P102  
Port P104  
Port P106  
The definition values related to port settings are described below.  
RAPI_PORT_INPUT  
RAPI_PORT_OUTPUT  
RAPI_PULLED_HIGH  
RAPI_NOT_PULLED  
_HIGH  
Sets a selected port for input.  
Sets a selected port for output.  
Sets a selected port to be pulled high.  
Sets a selected port not to be pulled high.  
RAPI_LATCH  
Sets a selected port to read the port latch regardless of whether it  
is set for input or output. Specifiable only when port P1 is used.  
(R8C)  
The definition values corresponding to each I/O port are listed below.  
RAPI_PORT_0_0  
RAPI_PORT_0_2  
RAPI_PORT_0_4  
RAPI_PORT_0_6  
RAPI_PORT_1_0  
RAPI_PORT_1_2  
RAPI_PORT_1_4  
RAPI_PORT_1_6  
RAPI_PORT_2_0  
RAPI_PORT_2_2  
RAPI_PORT_2_4  
RAPI_PORT_2_6  
RAPI_PORT_3_0  
RAPI_PORT_3_2  
RAPI_PORT_3_4  
RAPI_PORT_3_7  
RAPI_PORT_4_4  
RAPI_PORT_6_0  
RAPI_PORT_6_2  
RAPI_PORT_6_4  
RAPI_PORT_6_6  
Port P00  
Port P02  
Port P04  
Port P06  
Port P10  
Port P12  
Port P14  
Port P16  
Port P20  
Port P22  
Port P24  
Port P26  
Port P30  
Port P32  
Port P34  
Port P37  
Port P44  
Port P60  
Port P62  
Port P64  
Port P66  
RAPI_PORT_0_1  
RAPI_PORT_0_3  
RAPI_PORT_0_5  
RAPI_PORT_0_7  
RAPI_PORT_1_1  
RAPI_PORT_1_3  
RAPI_PORT_1_5  
RAPI_PORT_1_7  
RAPI_PORT_2_1  
RAPI_PORT_2_3  
RAPI_PORT_2_5  
RAPI_PORT_2_7  
RAPI_PORT_3_1  
RAPI_PORT_3_3  
RAPI_PORT_3_5  
RAPI_PORT_4_3  
RAPI_PORT_4_5  
RAPI_PORT_6_1  
RAPI_PORT_6_3  
RAPI_PORT_6_5  
RAPI_PORT_6_7  
Port P01  
Port P03  
Port P05  
Port P07  
Port P11  
Port P13  
Port P15  
Port P17  
Port P21  
Port P23  
Port P25  
Port P27  
Port P31  
Port P33  
Port P35  
Port P43  
Port P45  
Port P61  
Port P63  
Port P65  
Port P67  
The definition values corresponding to each I/O port are listed below.  
RAPI_PORT_INPUT  
RAPI_PORT_OUTPUT  
RAPI_PULLED_HIGH  
Sets a selected port for input.  
Sets a selected port for output.  
Sets a selected port to be pulled high.  
Rev.1.01  
2007.02.16  
154  
RJJ10J1643-0101  
 
RAPI_NOT_PULLED_HIGH  
Sets a selected port not to be pulled high.  
RAPI_DRIVE_CAPACITY_H Sets the N-channel output transistor drive capacity of a  
selected port to High. Specifiable only when port P1 is used.  
RAPI_DRIVE_CAPACITY_L  
Sets the N-channel output transistor drive capacity of a  
selected port to Low. Specifiable only when port P1 is used.  
(H8/300H)  
The definition values corresponding to each I/O port are listed below.  
RAPI_PORT_1_0  
RAPI_PORT_1_2  
RAPI_PORT_1_5  
RAPI_PORT_1_7  
RAPI_PORT_2_1  
RAPI_PORT_2_3  
RAPI_PORT_2_5  
RAPI_PORT_2_7  
RAPI_PORT_3_1  
RAPI_PORT_3_3  
RAPI_PORT_3_5  
RAPI_PORT_3_7  
RAPI_PORT_5_1  
RAPI_PORT_5_3  
RAPI_PORT_5_5  
RAPI_PORT_5_7  
RAPI_PORT_6_1  
RAPI_PORT_6_3  
RAPI_PORT_6_5  
RAPI_PORT_6_7  
RAPI_PORT_7_1  
RAPI_PORT_7_4  
RAPI_PORT_7_6  
RAPI_PORT_8_0  
RAPI_PORT_8_2  
RAPI_PORT_8_4  
RAPI_PORT_8_6  
RAPI_PORT_9_0  
RAPI_PORT_9_2  
RAPI_PORT_9_4  
RAPI_PORT_9_6  
RAPI_PORT_C_0  
RAPI_PORT_C_2  
RAPI_PORT_D_0  
RAPI_PORT_D_2  
RAPI_PORT_D_4  
Port P10  
Port P12  
Port P15  
Port P17  
Port P21  
Port P23  
Port P25  
Port P27  
Port P31  
Port P33  
Port P35  
Port P37  
Port P51  
Port P53  
Port P55  
Port P57  
Port P61  
Port P63  
Port P65  
Port P67  
Port P71  
Port P74  
Port P76  
Port P80  
Port P82  
Port P84  
Port P86  
Port P90  
Port P92  
Port P94  
Port P96  
Port PC0  
PortPC2  
PortPD0  
PortPD2  
PortPD4  
RAPI_PORT_1_1  
RAPI_PORT_1_4  
RAPI_PORT_1_6  
RAPI_PORT_2_0  
RAPI_PORT_2_2  
RAPI_PORT_2_4  
RAPI_PORT_2_6  
RAPI_PORT_3_0  
RAPI_PORT_3_2  
RAPI_PORT_3_4  
RAPI_PORT_3_6  
RAPI_PORT_5_0  
RAPI_PORT_5_2  
RAPI_PORT_5_4  
RAPI_PORT_5_6  
RAPI_PORT_6_0  
RAPI_PORT_6_2  
RAPI_PORT_6_4  
RAPI_PORT_6_6  
RAPI_PORT_7_0  
RAPI_PORT_7_2  
RAPI_PORT_7_5  
RAPI_PORT_7_7  
RAPI_PORT_8_1  
RAPI_PORT_8_3  
RAPI_PORT_8_5  
RAPI_PORT_8_7  
RAPI_PORT_9_1  
RAPI_PORT_9_3  
RAPI_PORT_9_5  
RAPI_PORT_9_7  
RAPI_PORT_C_1  
RAPI_PORT_C_3  
RAPI_PORT_D_1  
RAPI_PORT_D_3  
RAPI_PORT_D_5  
Port P11  
Port P14  
Port P16  
Port P20  
Port P22  
Port P24  
Port P26  
Port P30  
Port P32  
Port P34  
Port P36  
Port P50  
Port P52  
Port P54  
Port P56  
Port P60  
Port P62  
Port P64  
Port P66  
Port P70  
Port P72  
Port P75  
Port P77  
Port P81  
Port P83  
Port P85  
Port P87  
Port P91  
Port P93  
Port P95  
Port P97  
Port PC1  
PortPC3  
PortPD1  
PortPD3  
PortPD5  
Rev.1.01  
2007.02.16  
155  
RJJ10J1643-0101  
 
RAPI_PORT_D_6  
RAPI_PORT_E_0  
RAPI_PORT_E_2  
RAPI_PORT_E_4  
RAPI_PORT_E_6  
RAPI_PORT_F_0  
RAPI_PORT_G_1  
RAPI_PORT_G_3  
RAPI_PORT_G_5  
RAPI_PORT_G_7  
RAPI_PORT_H_1  
RAPI_PORT_H_3  
RAPI_PORT_H_5  
RAPI_PORT_H_7  
RAPI_PORT_J_1  
PortPD6  
PortPE0  
PortPE2  
PortPE4  
PortPE6  
PortPF0  
PortPG1  
PortPG3  
PortPG5  
PortPG7  
PortPH1  
PortPH3  
PortPH5  
PortPH7  
PortPJ1  
RAPI_PORT_D_7  
RAPI_PORT_E_1  
RAPI_PORT_E_3  
RAPI_PORT_E_5  
RAPI_PORT_E_7  
RAPI_PORT_G_0  
RAPI_PORT_G_2  
RAPI_PORT_G_4  
RAPI_PORT_G_6  
RAPI_PORT_H_0  
RAPI_PORT_H_2  
RAPI_PORT_H_4  
RAPI_PORT_H_6  
RAPI_PORT_J_0  
PortPD7  
PortPE1  
PortPE3  
PortPE5  
PortPE7  
PortPG0  
PortPG2  
PortPG4  
PortPG6  
PortPH0  
PortPH2  
PortPH4  
PortPH6  
PortPJ0  
The definition values related to port settings are described below.  
RAPI_PORT_INPUT  
Sets a selected port for input.  
RAPI_PORT_OUTPUT  
RAPI_PULLED_HIGH  
RAPI_NOT_PULLED_HIGH  
Sets a selected port for output.  
Sets a selected port to be pulled high.  
Sets a selected port not to be pulled high.  
[data2]  
(M16C)  
Specify the digital filter width of the digital debounce facility assigned to _NMI/_SD.  
Specifiable only when port P85 is used.  
Specify the digital filter width of the digital debounce facility assigned to  
INPC17/_INT5. Specifiable only when port P17 is used.  
When using any other port, set 0 for this data.  
(R8C) (H8/300H)  
Specify 0.  
Return value  
If the I/O port specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
I/O port  
__ReadIOPort, __WriteIOPort, __SetIOPortRegister, __ReadIOPortRegister,  
__WriteIOPortRegister  
Remark  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable I/O ports differ with each CPU used.  
The API cannot set function that the specified I/O port dont have.  
Rev.1.01  
2007.02.16  
156  
RJJ10J1643-0101  
 
Program example  
#include " rapi_io_port_r8c_13.h  
void func( void )  
{
/* Set up port P03 as input port */  
__SetIOPort(RAPI_PORT_0_3| RAPI_PORT_INPUT| RAPI_PULLED_HIGH, 0, 0 );  
}
Rev.1.01  
2007.02.16  
157  
RJJ10J1643-0101  
 
__ReadIOPort  
Synopsis  
<Read from I/O port>  
Boolean __ReadIOPort(unsigned long data1, unsigned int *data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Pointer to the variable in which the value read from I/O port is stored.  
Description  
Gets the value of a specified I/O port.  
[data1]  
Specify an I/O port from which data is read. The definition values corresponding to  
each I/O port are listed below.  
(M16C)  
RAPI_PORT_0_0  
RAPI_PORT_0_2  
RAPI_PORT_0_4  
RAPI_PORT_0_6  
RAPI_PORT_1_0  
RAPI_PORT_1_2  
RAPI_PORT_1_4  
RAPI_PORT_1_6  
RAPI_PORT_2_0  
RAPI_PORT_2_2  
RAPI_PORT_2_4  
RAPI_PORT_2_6  
RAPI_PORT_3_0  
RAPI_PORT_3_2  
RAPI_PORT_3_4  
RAPI_PORT_3_6  
RAPI_PORT_6_0  
RAPI_PORT_6_2  
RAPI_PORT_6_4  
RAPI_PORT_6_6  
RAPI_PORT_7_0  
RAPI_PORT_7_2  
RAPI_PORT_7_4  
RAPI_PORT_7_6  
RAPI_PORT_8_0  
RAPI_PORT_8_2  
RAPI_PORT_8_4  
RAPI_PORT_8_6  
RAPI_PORT_9_0  
RAPI_PORT_9_2  
Port P00  
Port P02  
Port P04  
Port P06  
Port P10  
Port P12  
Port P14  
Port P16  
Port P20  
Port P22  
Port P24  
Port P26  
Port P30  
Port P32  
Port P34  
Port P36  
Port P60  
Port P62  
Port P64  
Port P66  
Port P70  
Port P72  
Port P74  
Port P76  
Port P80  
Port P82  
Port P84  
Port P86  
Port P90  
Port P92  
RAPI_PORT_0_1  
RAPI_PORT_0_3  
RAPI_PORT_0_5  
RAPI_PORT_0_7  
RAPI_PORT_1_1  
RAPI_PORT_1_3  
RAPI_PORT_1_5  
RAPI_PORT_1_7  
RAPI_PORT_2_1  
RAPI_PORT_2_3  
RAPI_PORT_2_5  
RAPI_PORT_2_7  
RAPI_PORT_3_1  
RAPI_PORT_3_3  
RAPI_PORT_3_5  
RAPI_PORT_3_7  
RAPI_PORT_6_1  
RAPI_PORT_6_3  
RAPI_PORT_6_5  
RAPI_PORT_6_7  
RAPI_PORT_7_1  
RAPI_PORT_7_3  
RAPI_PORT_7_5  
RAPI_PORT_7_7  
RAPI_PORT_8_1  
RAPI_PORT_8_3  
RAPI_PORT_8_5  
RAPI_PORT_8_7  
RAPI_PORT_9_1  
RAPI_PORT_9_3  
Port P01  
Port P03  
Port P05  
Port P07  
Port P11  
Port P13  
Port P15  
Port P17  
Port P21  
Port P23  
Port P25  
Port P27  
Port P31  
Port P33  
Port P35  
Port P37  
Port P61  
Port P63  
Port P65  
Port P67  
Port P71  
Port P73  
Port P75  
Port P77  
Port P81  
Port P83  
Port P85  
Port P87  
Port P91  
Port P93  
Rev.1.01  
2007.02.16  
158  
RJJ10J1643-0101  
 
RAPI_PORT_9_5  
RAPI_PORT_9_7  
RAPI_PORT_10_1  
RAPI_PORT_10_3  
RAPI_PORT_10_5  
RAPI_PORT_10_7  
Port P95  
RAPI_PORT_9_6  
RAPI_PORT_10_0  
RAPI_PORT_10_2  
RAPI_PORT_10_4  
RAPI_PORT_10_6  
Port P96  
Port P97  
Port P100  
Port P102  
Port P104  
Port P106  
Port P101  
Port P103  
Port P105  
Port P107  
(R8C)  
RAPI_PORT_0_0  
RAPI_PORT_0_2  
RAPI_PORT_0_4  
RAPI_PORT_0_6  
RAPI_PORT_1_0  
RAPI_PORT_1_2  
RAPI_PORT_1_4  
RAPI_PORT_1_6  
RAPI_PORT_2_0  
RAPI_PORT_2_2  
RAPI_PORT_2_4  
RAPI_PORT_2_6  
RAPI_PORT_3_0  
RAPI_PORT_3_2  
RAPI_PORT_3_4  
RAPI_PORT_3_7  
RAPI_PORT_4_3  
RAPI_PORT_4_5  
RAPI_PORT_4_7  
RAPI_PORT_6_1  
RAPI_PORT_6_3  
RAPI_PORT_6_5  
RAPI_PORT_6_7  
Port P00  
Port P02  
Port P04  
Port P06  
Port P10  
Port P12  
Port P14  
Port P16  
Port P20  
Port P22  
Port P24  
Port P26  
Port P30  
Port P32  
Port P34  
Port P37  
Port P43  
Port P45  
Port P47  
Port P61  
Port P63  
Port P65  
Port P67  
RAPI_PORT_0_1  
RAPI_PORT_0_3  
RAPI_PORT_0_5  
RAPI_PORT_0_7  
RAPI_PORT_1_1  
RAPI_PORT_1_3  
RAPI_PORT_1_5  
RAPI_PORT_1_7  
RAPI_PORT_2_1  
RAPI_PORT_2_3  
RAPI_PORT_2_5  
RAPI_PORT_2_7  
RAPI_PORT_3_1  
RAPI_PORT_3_3  
RAPI_PORT_3_5  
RAPI_PORT_4_2  
RAPI_PORT_4_4  
RAPI_PORT_4_6  
RAPI_PORT_6_0  
RAPI_PORT_6_2  
RAPI_PORT_6_4  
RAPI_PORT_6_6  
Port P01  
Port P03  
Port P05  
Port P07  
Port P11  
Port P13  
Port P15  
Port P17  
Port P21  
Port P23  
Port P25  
Port P27  
Port P31  
Port P33  
Port P35  
Port P42  
Port P44  
Port P46  
Port P60  
Port P62  
Port P64  
Port P66  
(H8/300H)  
RAPI_PORT_1_0  
RAPI_PORT_1_2  
RAPI_PORT_1_5  
RAPI_PORT_1_7  
RAPI_PORT_2_1  
RAPI_PORT_2_3  
RAPI_PORT_2_5  
RAPI_PORT_2_7  
RAPI_PORT_3_1  
RAPI_PORT_3_3  
RAPI_PORT_3_5  
RAPI_PORT_3_7  
Port P10  
Port P12  
Port P15  
Port P17  
Port P21  
Port P23  
PortP25  
PortP27  
PortP31  
PortP33  
PortP35  
PortP37  
RAPI_PORT_1_1  
RAPI_PORT_1_4  
RAPI_PORT_1_6  
RAPI_PORT_2_0  
RAPI_PORT_2_2  
RAPI_PORT_2_4  
RAPI_PORT_2_6  
RAPI_PORT_3_0  
RAPI_PORT_3_2  
RAPI_PORT_3_4  
RAPI_PORT_3_6  
RAPI_PORT_5_0  
Port P11  
Port P14  
Port P16  
Port P20  
Port P22  
Port P24  
PortP26  
PortP30  
PortP32  
PortP34  
PortP36  
PortP50  
Rev.1.01  
2007.02.16  
159  
RJJ10J1643-0101  
 
RAPI_PORT_5_1  
RAPI_PORT_5_3  
RAPI_PORT_5_5  
RAPI_PORT_5_7  
RAPI_PORT_6_1  
RAPI_PORT_6_3  
RAPI_PORT_6_5  
RAPI_PORT_6_7  
RAPI_PORT_7_1  
RAPI_PORT_7_4  
RAPI_PORT_7_6  
RAPI_PORT_8_0  
RAPI_PORT_8_2  
RAPI_PORT_8_4  
RAPI_PORT_8_6  
RAPI_PORT_9_0  
RAPI_PORT_9_2  
RAPI_PORT_9_4  
RAPI_PORT_9_6  
RAPI_PORT_B_0  
RAPI_PORT_B_2  
RAPI_PORT_B_4  
RAPI_PORT_B_6  
RAPI_PORT_C_0  
RAPI_PORT_C_2  
RAPI_PORT_D_0  
RAPI_PORT_D_2  
RAPI_PORT_D_4  
RAPI_PORT_D_6  
RAPI_PORT_E_0  
RAPI_PORT_E_2  
RAPI_PORT_E_4  
RAPI_PORT_E_6  
RAPI_PORT_F_0  
RAPI_PORT_F_2  
RAPI_PORT_F_4  
RAPI_PORT_F_6  
RAPI_PORT_G_0  
RAPI_PORT_G_2  
RAPI_PORT_G_4  
RAPI_PORT_G_6  
RAPI_PORT_H_0  
RAPI_PORT_H_2  
PortP51  
PortP53  
PortP55  
PortP57  
PortP61  
PortP63  
PortP65  
PortP67  
PortP71  
PortP74  
PortP76  
PortP80  
PortP82  
PortP84  
PortP86  
PortP90  
PortP92  
PortP94  
PortP96  
PortPB0  
PortPB2  
PortPB4  
PortPB6  
PortPC0  
PortPC2  
PortPD0  
PortPD2  
PortPD4  
PortPD6  
PortPE0  
PortPE2  
PortPE4  
PortPE6  
PortPF0  
PortPF2  
PortPF4  
PortPF6  
PortPG0  
PortPG2  
PortPG4  
PortPG6  
PortPH0  
PortPH2  
RAPI_PORT_5_2  
RAPI_PORT_5_4  
RAPI_PORT_5_6  
RAPI_PORT_6_0  
RAPI_PORT_6_2  
RAPI_PORT_6_4  
RAPI_PORT_6_6  
RAPI_PORT_7_0  
RAPI_PORT_7_2  
RAPI_PORT_7_5  
RAPI_PORT_7_7  
RAPI_PORT_8_1  
RAPI_PORT_8_3  
RAPI_PORT_8_5  
RAPI_PORT_8_7  
RAPI_PORT_9_1  
RAPI_PORT_9_3  
RAPI_PORT_9_5  
RAPI_PORT_9_7  
RAPI_PORT_B_1  
RAPI_PORT_B_3  
RAPI_PORT_B_5  
RAPI_PORT_B_7  
RAPI_PORT_C_1  
RAPI_PORT_C_3  
RAPI_PORT_D_1  
RAPI_PORT_D_3  
RAPI_PORT_D_5  
RAPI_PORT_D_7  
RAPI_PORT_E_1  
RAPI_PORT_E_3  
RAPI_PORT_E_5  
RAPI_PORT_E_7  
RAPI_PORT_F_1  
RAPI_PORT_F_3  
RAPI_PORT_F_5  
RAPI_PORT_F_7  
RAPI_PORT_G_1  
RAPI_PORT_G_3  
RAPI_PORT_G_5  
RAPI_PORT_G_7  
RAPI_PORT_H_1  
RAPI_PORT_H_3  
PortP52  
PortP54  
PortP56  
PortP60  
PortP62  
PortP64  
PortP66  
PortP70  
PortP72  
PortP75  
PortP77  
PortP81  
PortP83  
PortP85  
PortP87  
PortP91  
PortP93  
PortP95  
PortP97  
PortPB1  
PortPB3  
PortPB5  
PortPB7  
PortPC1  
PortPC3  
PortPD1  
PortPD3  
PortPD5  
PortPD7  
PortPE1  
PortPE3  
PortPE5  
PortPE7  
PortPF1  
PortPF3  
PortPF5  
PortPF7  
PortPG1  
PortPG3  
PortPG5  
PortPG7  
PortPH1  
PortPH3  
Rev.1.01  
2007.02.16  
160  
RJJ10J1643-0101  
 
RAPI_PORT_H_4  
RAPI_PORT_H_6  
RAPI_PORT_J_0  
PortPH4  
PortPH6  
PortPJ0  
RAPI_PORT_H_5  
RAPI_PORT_H_7  
RAPI_PORT_J_1  
PortPH5  
PortPH7  
PortPJ1  
Return value  
If the I/O port specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
I/O port  
__SetIOPort, __WriteIOPort, __SetIOPortRegister, __ReadIOPortRegister,  
__WriteIOPortRegister  
Remark  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable I/O ports differ with each CPU used.  
Ports in port B of the H8/300H that are used as analog input pins cannot be used as input  
ports.  
Program example  
#include " rapi_io_port_r8c_13.h"  
void func( void )  
{
/* Get the value of port P12 */  
__ReadIOPort(RAPI_PORT_1_2, &data );  
}
Rev.1.01  
2007.02.16  
161  
RJJ10J1643-0101  
 
__WriteIOPort  
Synopsis  
<Write to I/O port>  
Boolean __WriteIOPort(unsigned long data1, unsigned int data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Data to be written to I/O port  
Description  
Writes data to a specified I/O port.  
[data1]  
Specify an I/O port to which data is written. The definition values corresponding to each  
I/O port are listed below.  
(M16C)  
RAPI_PORT_0_0  
RAPI_PORT_0_2  
RAPI_PORT_0_4  
RAPI_PORT_0_6  
RAPI_PORT_1_0  
RAPI_PORT_1_2  
RAPI_PORT_1_4  
RAPI_PORT_1_6  
RAPI_PORT_2_0  
RAPI_PORT_2_2  
RAPI_PORT_2_4  
RAPI_PORT_2_6  
RAPI_PORT_3_0  
RAPI_PORT_3_2  
RAPI_PORT_3_4  
RAPI_PORT_3_6  
RAPI_PORT_6_0  
RAPI_PORT_6_2  
RAPI_PORT_6_4  
RAPI_PORT_6_6  
RAPI_PORT_7_0  
RAPI_PORT_7_2  
RAPI_PORT_7_4  
RAPI_PORT_7_6  
RAPI_PORT_8_0  
RAPI_PORT_8_2  
RAPI_PORT_8_4  
RAPI_PORT_8_6  
RAPI_PORT_9_0  
RAPI_PORT_9_2  
Port P00  
Port P02  
Port P04  
Port P06  
Port P10  
Port P12  
Port P14  
Port P16  
Port P20  
Port P22  
Port P24  
Port P26  
Port P30  
Port P32  
Port P34  
Port P36  
Port P60  
Port P62  
Port P64  
Port P66  
Port P70  
Port P72  
Port P74  
Port P76  
Port P80  
Port P82  
Port P84  
Port P86  
Port P90  
Port P92  
RAPI_PORT_0_1  
RAPI_PORT_0_3  
RAPI_PORT_0_5  
RAPI_PORT_0_7  
RAPI_PORT_1_1  
RAPI_PORT_1_3  
RAPI_PORT_1_5  
RAPI_PORT_1_7  
RAPI_PORT_2_1  
RAPI_PORT_2_3  
RAPI_PORT_2_5  
RAPI_PORT_2_7  
RAPI_PORT_3_1  
RAPI_PORT_3_3  
RAPI_PORT_3_5  
RAPI_PORT_3_7  
RAPI_PORT_6_1  
RAPI_PORT_6_3  
RAPI_PORT_6_5  
RAPI_PORT_6_7  
RAPI_PORT_7_1  
RAPI_PORT_7_3  
RAPI_PORT_7_5  
RAPI_PORT_7_7  
RAPI_PORT_8_1  
RAPI_PORT_8_3  
RAPI_PORT_8_5  
RAPI_PORT_8_7  
RAPI_PORT_9_1  
RAPI_PORT_9_3  
Port P01  
Port P03  
Port P05  
Port P07  
Port P11  
Port P13  
Port P15  
Port P17  
Port P21  
Port P23  
Port P25  
Port P27  
Port P31  
Port P33  
Port P35  
Port P37  
Port P61  
Port P63  
Port P65  
Port P67  
Port P71  
Port P73  
Port P75  
Port P77  
Port P81  
Port P83  
Port P85  
Port P87  
Port P91  
Port P93  
Rev.1.01  
2007.02.16  
162  
RJJ10J1643-0101  
 
RAPI_PORT_9_5  
RAPI_PORT_9_7  
RAPI_PORT_10_1  
RAPI_PORT_10_3  
RAPI_PORT_10_5  
RAPI_PORT_10_7  
Port P95  
RAPI_PORT_9_6  
RAPI_PORT_10_0  
RAPI_PORT_10_2  
RAPI_PORT_10_4  
RAPI_PORT_10_6  
Port P96  
Port P97  
Port P100  
Port P102  
Port P104  
Port P106  
Port P101  
Port P103  
Port P105  
Port P107  
(R8C)  
RAPI_PORT_0_0  
RAPI_PORT_0_2  
RAPI_PORT_0_4  
RAPI_PORT_0_6  
RAPI_PORT_1_0  
RAPI_PORT_1_2  
RAPI_PORT_1_4  
RAPI_PORT_1_6  
RAPI_PORT_2_0  
RAPI_PORT_2_2  
RAPI_PORT_2_4  
RAPI_PORT_2_6  
RAPI_PORT_3_0  
RAPI_PORT_3_2  
RAPI_PORT_3_4  
RAPI_PORT_3_7  
RAPI_PORT_4_4  
RAPI_PORT_6_0  
RAPI_PORT_6_2  
RAPI_PORT_6_4  
RAPI_PORT_6_6  
Port P00  
Port P02  
Port P04  
Port P06  
Port P10  
Port P12  
Port P14  
Port P16  
Port P20  
Port P22  
Port P24  
Port P26  
Port P30  
Port P32  
Port P34  
Port P37  
Port P44  
Port P60  
Port P62  
Port P64  
Port P66  
RAPI_PORT_0_1  
RAPI_PORT_0_3  
RAPI_PORT_0_5  
RAPI_PORT_0_7  
RAPI_PORT_1_1  
RAPI_PORT_1_3  
RAPI_PORT_1_5  
RAPI_PORT_1_7  
RAPI_PORT_2_1  
RAPI_PORT_2_3  
RAPI_PORT_2_5  
RAPI_PORT_2_7  
RAPI_PORT_3_1  
RAPI_PORT_3_3  
RAPI_PORT_3_5  
RAPI_PORT_4_3  
RAPI_PORT_4_5  
RAPI_PORT_6_1  
RAPI_PORT_6_3  
RAPI_PORT_6_5  
RAPI_PORT_6_7  
Port P01  
Port P03  
Port P05  
Port P07  
Port P11  
Port P13  
Port P15  
Port P17  
Port P21  
Port P23  
Port P25  
Port P27  
Port P31  
Port P33  
Port P35  
Port P43  
Port P45  
Port P61  
Port P63  
Port P65  
Port P67  
(H8/300H)  
RAPI_PORT_1_0  
RAPI_PORT_1_2  
RAPI_PORT_1_5  
RAPI_PORT_1_7  
RAPI_PORT_2_1  
RAPI_PORT_2_3  
RAPI_PORT_2_5  
RAPI_PORT_2_7  
RAPI_PORT_3_1  
RAPI_PORT_3_3  
RAPI_PORT_3_5  
RAPI_PORT_3_7  
RAPI_PORT_5_1  
RAPI_PORT_5_3  
Port P10  
Port P12  
Port P15  
Port P17  
Port P21  
Port P23  
PortP25  
PortP27  
PortP31  
PortP33  
PortP35  
PortP37  
PortP51  
PortP53  
RAPI_PORT_1_1  
RAPI_PORT_1_4  
RAPI_PORT_1_6  
RAPI_PORT_2_0  
RAPI_PORT_2_2  
RAPI_PORT_2_4  
RAPI_PORT_2_6  
RAPI_PORT_3_0  
RAPI_PORT_3_2  
RAPI_PORT_3_4  
RAPI_PORT_3_6  
RAPI_PORT_5_0  
RAPI_PORT_5_2  
RAPI_PORT_5_4  
Port P11  
Port P14  
Port P16  
Port P20  
Port P22  
Port P24  
PortP26  
PortP30  
PortP32  
PortP34  
PortP36  
PortP50  
PortP52  
PortP54  
Rev.1.01  
2007.02.16  
163  
RJJ10J1643-0101  
 
RAPI_PORT_5_5  
RAPI_PORT_5_7  
RAPI_PORT_6_1  
RAPI_PORT_6_3  
RAPI_PORT_6_5  
RAPI_PORT_6_7  
RAPI_PORT_7_1  
RAPI_PORT_7_4  
RAPI_PORT_7_6  
RAPI_PORT_8_0  
RAPI_PORT_8_2  
RAPI_PORT_8_4  
RAPI_PORT_8_6  
RAPI_PORT_9_0  
RAPI_PORT_9_2  
RAPI_PORT_9_4  
RAPI_PORT_9_6  
RAPI_PORT_C_0  
RAPI_PORT_C_2  
RAPI_PORT_D_0  
RAPI_PORT_D_2  
RAPI_PORT_D_4  
RAPI_PORT_D_6  
RAPI_PORT_E_0  
RAPI_PORT_E_2  
RAPI_PORT_E_4  
RAPI_PORT_E_6  
RAPI_PORT_G_0  
RAPI_PORT_G_2  
RAPI_PORT_G_4  
RAPI_PORT_G_6  
RAPI_PORT_H_0  
RAPI_PORT_H_2  
RAPI_PORT_H_4  
RAPI_PORT_H_6  
RAPI_PORT_J_0  
PortP55  
PortP57  
PortP61  
PortP63  
PortP65  
PortP67  
PortP71  
PortP74  
PortP76  
PortP80  
PortP82  
PortP84  
PortP86  
PortP90  
PortP92  
PortP94  
PortP96  
PortPC0  
PortPC2  
PortPD0  
PortPD2  
PortPD4  
PortPD6  
PortPE0  
PortPE2  
PortPE4  
PortPE6  
PortPG0  
PortPG2  
PortPG4  
PortPG6  
PortPH0  
PortPH2  
PortPH4  
PortPH6  
PortPJ0  
RAPI_PORT_5_6  
RAPI_PORT_6_0  
RAPI_PORT_6_2  
RAPI_PORT_6_4  
RAPI_PORT_6_6  
RAPI_PORT_7_0  
RAPI_PORT_7_2  
RAPI_PORT_7_5  
RAPI_PORT_7_7  
RAPI_PORT_8_1  
RAPI_PORT_8_3  
RAPI_PORT_8_5  
RAPI_PORT_8_7  
RAPI_PORT_9_1  
RAPI_PORT_9_3  
RAPI_PORT_9_5  
RAPI_PORT_9_7  
RAPI_PORT_C_1  
RAPI_PORT_C_3  
RAPI_PORT_D_1  
RAPI_PORT_D_3  
RAPI_PORT_D_5  
RAPI_PORT_D_7  
RAPI_PORT_E_1  
RAPI_PORT_E_3  
RAPI_PORT_E_5  
RAPI_PORT_E_7  
RAPI_PORT_G_1  
RAPI_PORT_G_3  
RAPI_PORT_G_5  
RAPI_PORT_G_7  
RAPI_PORT_H_1  
RAPI_PORT_H_3  
RAPI_PORT_H_5  
RAPI_PORT_H_7  
RAPI_PORT_J_1  
PortP56  
PortP60  
PortP62  
PortP64  
PortP66  
PortP70  
PortP72  
PortP75  
PortP77  
PortP81  
PortP83  
PortP85  
PortP87  
PortP91  
PortP93  
PortP95  
PortP97  
PortPC1  
PortPC3  
PortPD1  
PortPD3  
PortPD5  
PortPD7  
PortPE1  
PortPE3  
PortPE5  
PortPE7  
PortPG1  
PortPG3  
PortPG5  
PortPG7  
PortPH1  
PortPH3  
PortPH5  
PortPH7  
PortPJ1  
Return value  
If the I/O port specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
I/O port  
__SetIOPort, __ReadIOPort, __SetIOPortRegister, __ReadIOPortRegister,  
Rev.1.01  
2007.02.16  
164  
RJJ10J1643-0101  
 
__WriteIOPortRegister  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
Remark  
The specifiable I/O ports differ with each CPU used.  
Program example  
#include " rapi_io_port_r8c_13.h"  
void func( void )  
{
unsigned int data;  
/* Set the data to port P05 */  
__WriteIOPort( RAPI_PORT_0_5, 0 );  
}
Rev.1.01  
2007.02.16  
165  
RJJ10J1643-0101  
 
__SetIOPortRegister  
<Set I/O port register>  
Synopsis  
Boolean __SetIOPortRegister(unsigned long data1, unsigned int data2, unsigned  
int data3, unsigned int data4)  
data1  
data2  
data3  
data4  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Setup data 3 (content differs with MCU type)  
Setup data 4 (content differs with MCU type)  
[data1]  
Description  
Set the operating condition of a specified I/O port in each relevant register.  
(M16C)  
The definition values corresponding to each I/O port register are listed below.  
RAPI_PORT_0  
RAPI_PORT_2  
RAPI_PORT_6  
RAPI_PORT_8  
RAPI_PORT_10  
Port P0 register  
Port P2 register  
Port P6 register  
Port P8 register  
Port P10 register  
RAPI_PORT_1  
RAPI_PORT_3  
RAPI_PORT_7  
RAPI_PORT_9  
Port P1 register  
Port P3 register  
Port P7 register  
Port P9 register  
The definition values related to port settings are described below.  
RAPI_LATCH  
Set to read the port latch regardless of whether the port is set for input or  
output. Specifiable only when port P1 is used.  
(R8C)  
The definition values corresponding to each I/O port register are listed below.  
RAPI_PORT_0  
RAPI_PORT_2  
RAPI_PORT_4  
Port P0 register  
Port P2 register  
Port P4 register  
RAPI_PORT_1  
RAPI_PORT_3  
RAPI_PORT_6  
Port P1 register  
Port P3 register  
Port P6 register  
(H8/300H)  
The definition values corresponding to each I/O port register are listed below.  
RAPI_PORT_1  
RAPI_PORT_3  
RAPI_PORT_6  
RAPI_PORT_8  
RAPI_PORT_C  
RAPI_PORT_E  
RAPI_PORT_G  
RAPI_PORT_J  
Port P1 register  
Port P3 register  
Port P6 register  
Port P8 register  
Port PC register  
Port PE register  
Port PG register  
Port PJ register  
RAPI_PORT_2  
RAPI_PORT_5  
RAPI_PORT_7  
RAPI_PORT_9  
RAPI_PORT_D  
RAPI_PORT_F  
RAPI_PORT_H  
Port P2 register  
Port P5 register  
Port P7 register  
Port P9 register  
Port PD register  
Port PF register  
Port PH register  
[data2]  
(M16C) (R8C)  
Specify the set value for the port direction register corresponding to a selected port.  
(H8/300H)  
Rev.1.01  
2007.02.16  
166  
RJJ10J1643-0101  
 
Specify the set value for the port control register corresponding to a selected port.  
[data3]  
(M16C) (R8C)  
Specify the set value for the pullup control register corresponding to a selected port.  
(H8/300H)  
Specify the set value for the pullup control register corresponding to a selected port.  
[data4]  
(M16C)  
Specify the digital filter width of the digital debounce facility assigned to _NMI/_SD.  
Specifiable only when port P8 is used.  
Specify the digital filter width of the digital debounce facility assigned to  
INPC17/_INT5. Specifiable only when port P1 is used.  
When using any other port, set 0 for this data.  
(R8C)  
Specify the set value for the port P1 drive capacity register. Specifiable only when  
port P1 is used.  
When using any other port, set 0 for this data.  
(H8/300H)  
Specify 0.  
Return value  
If the I/O port register specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
I/O port  
__SetIOPort, __ReadIOPort, __WriteIOPort, __ReadIOPortRegister,  
__WriteIOPortRegister  
Remark  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable I/O port registers differ with each CPU used.  
Program example  
#include " rapi_io_port_r8c_13.h"  
void func( void )  
{
/* Set inputs/outputs of port P1 register */  
__SetIOPortRegister(RAPI_PORT_1, 0xAA, 0, 0 );  
}
Rev.1.01  
2007.02.16  
167  
RJJ10J1643-0101  
 
__ReadIOPortRegister  
Synopsis  
<Read from I/O port register>  
Boolean __ReadIOPortRegister(unsigned long data1, unsigned int *data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Pointer to the variable in which the value read from I/O port register is stored.  
Description  
Gets the value of a specified I/O port from each relevant register.  
[data1]  
Specify an I/O port register from which data is read. The definition values  
corresponding to each I/O port register are listed below.  
(M16C)  
RAPI_PORT_0  
RAPI_PORT_2  
RAPI_PORT_6  
RAPI_PORT_8  
RAPI_PORT_10  
Port P0 register  
Port P2 register  
Port P6 register  
Port P8 register  
Port P10 register  
RAPI_PORT_1  
RAPI_PORT_3  
RAPI_PORT_7  
RAPI_PORT_9  
Port P1 register  
Port P3 register  
Port P7 register  
Port P9 register  
(R8C)  
RAPI_PORT_0  
RAPI_PORT_2  
RAPI_PORT_4  
Port P0 register  
Port P2 register  
Port P4 register  
RAPI_PORT_1  
RAPI_PORT_3  
RAPI_PORT_6  
Port P1 register  
Port P3 register  
Port P6 register  
(H8/300H)  
RAPI_PORT_1  
RAPI_PORT_3  
RAPI_PORT_6  
RAPI_PORT_8  
RAPI_PORT_B  
RAPI_PORT_D  
RAPI_PORT_F  
RAPI_PORT_H  
Port P1 register  
Port P3 register  
Port P6 register  
Port P8 register  
Port PB register  
Port PD register  
Port PF register  
Port PH register  
RAPI_PORT_2  
RAPI_PORT_5  
RAPI_PORT_7  
RAPI_PORT_9  
RAPI_PORT_C  
RAPI_PORT_E  
RAPI_PORT_G  
RAPI_PORT_J  
Port P2 register  
Port P5 register  
Port P7 register  
Port P9 register  
Port PC register  
Port PE register  
Port PG register  
Port PJ register  
Return value  
If the I/O port register specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
I/O port  
__SetIOPort, __ReadIOPort, __WriteIOPort, __SetIOPortRegister,  
__WriteIOPortRegister  
Remark  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable I/O port registers differ with each CPU used.  
Rev.1.01  
2007.02.16  
168  
RJJ10J1643-0101  
 
Ports in port B of the H8/300H that are used as analog input pins cannot be used as input  
ports.  
Program example  
#include " rapi_io_port_r8c_13.h"  
void func( void )  
{
unsigned int data;  
/* Get the value of port P1 register */  
__ReadIOPortRegister( RAPI_PORT_1, &data );  
}
Rev.1.01  
2007.02.16  
169  
RJJ10J1643-0101  
 
__WriteIOPortRegister  
Synopsis  
<Write to I/O port register>  
Boolean __WriteIOPortRegister(unsigned long data1, unsigned int data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Data to be written to I/O port register  
Description  
Writes the value for a specified I/O port to each relevant register.  
[data1]  
Specify an I/O port register to which data is written. The definition values  
corresponding to each I/O port register are listed below.  
(M16C)  
RAPI_PORT_0  
RAPI_PORT_2  
RAPI_PORT_6  
RAPI_PORT_8  
RAPI_PORT_10  
Port P0 register  
Port P2 register  
Port P6 register  
Port P8 register  
Port P10 register  
RAPI_PORT_1  
RAPI_PORT_3  
RAPI_PORT_7  
RAPI_PORT_9  
Port P1 register  
Port P3 register  
Port P7 register  
Port P9 register  
(R8C)  
RAPI_PORT_0  
RAPI_PORT_2  
RAPI_PORT_4  
Port P0 register  
Port P2 register  
Port P4 register  
RAPI_PORT_1  
RAPI_PORT_3  
RAPI_PORT_6  
Port P1 register  
Port P3 register  
Port P6 register  
(H8/300H)  
RAPI_PORT_1  
RAPI_PORT_3  
RAPI_PORT_6  
RAPI_PORT_8  
RAPI_PORT_B  
RAPI_PORT_D  
RAPI_PORT_F  
RAPI_PORT_H  
Port P1 register  
Port P3 register  
Port P6 register  
Port P8 register  
Port PB register  
Port PD register  
Port PF register  
Port PH register  
RAPI_PORT_2  
RAPI_PORT_5  
RAPI_PORT_7  
RAPI_PORT_9  
RAPI_PORT_C  
RAPI_PORT_E  
RAPI_PORT_G  
RAPI_PORT_J  
Port P2 register  
Port P5 register  
Port P7 register  
Port P9 register  
Port PC register  
Port PE register  
Port PG register  
Port PJ register  
Return value  
If the I/O port register specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
I/O port  
__SetIOPort, __ReadIOPort, __WriteIOPort, __SetIOPortRegister,  
__ReadIOPortRegister  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
Remark  
The specifiable I/O port registers differ with each CPU used.  
Rev.1.01  
2007.02.16  
170  
RJJ10J1643-0101  
 
Program example  
#include " rapi_io_port_r8c_13.h"  
void func( void )  
{
/* Set the data to port P1 register */  
__WriteIOPortRegister( RAPI_PORT_1, 0xFF );  
}
Rev.1.01  
2007.02.16  
171  
RJJ10J1643-0101  
 
4.2.4 External interrupt  
__SetInterrupt  
Synopsis  
<Set external interrupt>  
Boolean __SetInterrupt(unsigned long data1, unsigned int data2, void* func)  
data1  
data2  
func  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Callback function pointer  
(Specify 0 if no callback functions are set.)  
Description  
Sets a specified external interrupt.  
[data1]  
For data1, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value. Note, however, that  
multiple external interrupts cannot be specified at the same time.  
(M16C)  
RAPI_INT0  
RAPI_INT1  
RAPI_INT2  
RAPI_INT3  
RAPI_INT4  
RAPI_INT5  
RAPI_KEY  
Uses _INT0 interrupt.  
Uses _INT1 interrupt.  
Uses _INT2 interrupt.  
Uses _INT3 interrupt.  
Uses _INT4 interrupt.  
Uses _INT5 interrupt.  
Uses key input interrupt.  
Specifies a rising edge for the active edge of a selected external  
interrupt.  
RAPI_INT_RISING  
RAPI_INT_FALLING Specifies a falling edge for the active edge of a selected external  
interrupt.  
RAPI_INT_BOTH  
Specifies both edges for the active edge of a selected external  
interrupt.  
RAPI_KI0_ENABLE  
RAPI_KI1_ENABLE  
RAPI_KI2_ENABLE  
RAPI_KI3_ENABLE  
Uses _KI0 pin input.  
Uses _KI1 pin input.  
Uses _KI2 pin input.  
Uses _KI3 pin input.  
• Specifiable definition values when _INT05 interrupts are used (RAPI_INT0 to  
RAPI_INT5 specified)  
(Polarity)  
Specify one from { RAPI_INT_RISING, RAPI_INT_FALLING,  
RAPI_INT_BOTH }. The default value is RAPI_INT_FALLING.  
• Specifiable definition values when key input interrupt is used (RAPI_KEY specified)  
(Input pin)  
To use _KI0, _KI1, _KI2, or _KI3 pin input, specify RAPI_KI0_ENABLE,  
RAPI_KI1_ENABLE, RAPI_KI2_ENABLE, or RAPI_KI3_ENABLE,  
respectively. The default value is RAPI_INT_FALLING.  
(R8C)  
RAPI_INT0  
RAPI_INT1  
Uses _INT0 interrupt.  
Uses _INT1 interrupt.  
Rev.1.01  
2007.02.16  
172  
RJJ10J1643-0101  
 
RAPI_INT2  
Uses _INT2 interrupt.  
RAPI_INT3  
Uses _INT3 interrupt.  
RAPI_KEY  
Uses key input interrupt.  
RAPI_INT_RISING  
Specifies a rising edge for the active edge of a selected external  
interrupt.  
RAPI_INT_FALLING Specifies a falling edge for the active edge of a selected external  
interrupt.  
RAPI_INT_BOTH  
Specifies both edges for the active edge of a selected external  
interrupt.  
RAPI_FILTER_F1  
RAPI_FILTER_F8  
RAPI_FILTER_F32  
RAPI_KI0_FALLING  
RAPI_KI0_RISING  
RAPI_KI1_FALLING  
RAPI_KI1_RISING  
RAPI_KI2_FALLING  
RAPI_KI2_RISING  
RAPI_KI3_FALLING  
RAPI_KI3_RISING  
Uses the digital filter facility that has a sampling frequency f1.  
Uses the digital filter facility that has a sampling frequency f8.  
Uses the digital filter facility that has a sampling frequency f32.  
Enables _KI0 pin input whose falling edge is the active edge.  
Enables _KI0 pin input whose rising edge is the active edge.  
Enables _KI1 pin input whose falling edge is the active edge.  
Enables _KI1 pin input whose rising edge is the active edge.  
Enables _KI2 pin input whose falling edge is the active edge.  
Enables _KI2 pin input whose rising edge is the active edge.  
Enables _KI3 pin input whose falling edge is the active edge.  
Enables _KI3 pin input whose rising edge is the active edge.  
• Specifiable definition values when _INT0 to _INT3 interrupt is used (RAPI_INT0 to  
RAPI_INT3 specified)  
(Polarity)  
Specify one from { RAPI_INT_RISING, RAPI_INT_FALLING,  
RAPI_INT_BOTH }. The default value is RAPI_INT_FALLING.  
Specify one from { RAPI_FILTER_F1, RAPI_FILTER_F8,  
RAPI_FILTER_F32 }. If no filters are specified, “No filter” is set.  
(Filter)  
• Specifiable definition values when key input interrupt is used (RAPI_KEY specified)  
(_KI0 pin input) Specify one from { RAPI_KI0_FALLING, RAPI_KI0_RISING }. If _KI0 pin  
input is not specified, “_KI0 pin input disabled” is set.  
(_KI1 pin input) Specify one from { RAPI_KI1_FALLING, RAPI_KI1_RISING }. If _KI1 pin  
input is not specified, “_KI1 pin input disabled” is set.  
(_KI2 pin input) Specify one from { RAPI_KI2_FALLING, RAPI_KI2_RISING }. If _KI2 pin  
input is not specified, “_KI2 pin input disabled” is set.  
(_KI3 pin input) Specify one from { RAPI_KI3_FALLING, RAPI_KI3_RISING }. If _KI3 pin  
input is not specified, “_KI3 pin input disabled” is set.  
(H8/300H)  
RAPI_IRQ0  
Uses IRQ0 interrupt.  
RAPI_IRQ1  
Uses IRQ1 interrupt.  
RAPI_IRQ2  
Uses IRQ2 interrupt.  
RAPI_IRQ3  
Uses IRQ3 interrupt.  
RAPI_WKP  
Uses WKP interrupt.  
RAPI_NOT_INT_  
REQUEST  
Does not request assertion of interrupt for a selected external  
interrupt.  
RAPI_INT_REQUEST  
Requests assertion of interrupt for a selected external interrupt.  
Rev.1.01  
2007.02.16  
173  
RJJ10J1643-0101  
 
RAPI_INT_RISING  
RAPI_INT_FALLING  
Specifies a rising edge for the active edge of a selected external  
interrupt.  
Specifies a falling edge for the active edge of a selected external  
interrupt.  
RAPI_WKP0_FALLING Enables _WKP0 pin input whose falling edge is the active edge.  
RAPI_WKP0_RISING Enables _WKP0 pin input whose rising edge is the active edge.  
RAPI_WKP1_FALLING Enables _WKP1 pin input whose falling edge is the active edge.  
RAPI_WKP1_RISING Enables _WKP1 pin input whose rising edge is the active edge.  
RAPI_WKP2_FALLING Enables _WKP2 pin input whose falling edge is the active edge.  
RAPI_WKP2_RISING Enables _WKP2 pin input whose rising edge is the active edge.  
RAPI_WKP3_FALLING Enables _WKP3 pin input whose falling edge is the active edge.  
RAPI_WKP3_RISING Enables _WKP3 pin input whose rising edge is the active edge.  
RAPI_WKP4_FALLING Enables _WKP4 pin input whose falling edge is the active edge.  
RAPI_WKP4_RISING Enables _WKP4 pin input whose rising edge is the active edge.  
RAPI_WKP5_FALLING Enables _WKP5 pin input whose falling edge is the active edge.  
RAPI_WKP5_RISING Enables _WKP5 pin input whose rising edge is the active edge.  
• Specifiable definition values when _IRQ0–3 interrupts are used (RAPI_IRQ0 to  
RAPI_IRQ3 specified)  
(Polarity)  
Specify one from { RAPI_INT_RISING, RAPI_INT_FALLING }. The  
default value is RAPI_INT_FALLING.  
(Interrupt  
request)  
Specify one from { RAPI_NOT_INT_REQUEST, RAPI_INT_REQUEST }.  
The default value is RAPI_NOT_INT_REQUEST.  
• Specifiable definition values when WKP interrupt is used (RAPI_WKP specified)  
(_WKP0 pin input) Specify one from { RAPI_WKP0_FALLING, RAPI_WKP0_RISING }. If  
_WKP0 pin input is not specified, “_WKP0 pin input disabled” is set.  
(_WKP1 pin input) Specify one from { RAPI_WKP1_FALLING, RAPI_WKP1_RISING }. If  
_WKP1 pin input is not specified, “_WKP1 pin input disabled” is set.  
(_WKP pin input) Specify one from { RAPI_WKP2_FALLING, RAPI_WKP2_RISING }. If  
_WKP2 pin input is not specified, “_WKP2 pin input disabled” is set.  
(_WKP3 pin input) Specify one from { RAPI_WKP3_FALLING, RAPI_WKP3_RISING }. If  
_WKP3 pin input is not specified, “_WKP3 pin input disabled” is set.  
(_WKP4 pin input) Specify one from { RAPI_WKP4_FALLING, RAPI_WKP4_RISING }. If  
_WKP4 pin input is not specified, “_WKP4 pin input disabled” is set.  
(_WKP5 pin input) Specify one from { RAPI_WKP5_FALLING, RAPI_WKP5_RISING }. If  
_WKP5 pin input is not specified, “_WKP5 pin input disabled” is set.  
[data2]  
(M16C) (R8C)  
Specify the interrupt priority level (07) to be set in the interrupt control register.  
(H8/300H)  
Specify the interrupt priority level (0–1) to be set in the interrupt control register. For  
the CPUs that do not have an interrupt control register, specify 0.  
Return value  
If the external interrupt specification is incorrect, RAPI_FALSE is returned; otherwise,  
Rev.1.01  
2007.02.16  
174  
RJJ10J1643-0101  
 
RAPI_TRUE is returned.  
Functionality  
Reference  
Remark  
External interrupt  
__EnableInterrupt, __GetInterruptFlag, __ClearInterruptFlag  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable external interrupts differ with each CPU used.  
For the R8C, if its CPU type is the one that does not accept specification of “both edges” for  
interrupts to INT2 and INT3, RAPI_INT_BOTH cannot be specified for INT2 and INT3.  
Program example  
#include " rapi_interrupt_r8c_13.h"  
void IntFunc( void ){}  
void func( void )  
{
/* Set up _INT0 interrupt */  
__SetInterrupt( RAPI_INT0|RAPI_INT_FALLING, 0, IntFunc );  
}
Rev.1.01  
2007.02.16  
175  
RJJ10J1643-0101  
 
__EnableInterrupt  
Synopsis  
<Control external interrupt>  
Boolean __EnableInterrupt(unsigned long data1, unsigned int data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Setup data 2 (content differs with MCU type)  
Description  
Changes the operating condition of a specified external interrupt.  
[data1]  
The following definition values can be set for data1. To specify multiple definition values at the  
same time, use the symbol “|” to separate each specified value. Note, however, that multiple  
external interrupts cannot be specified at the same time.  
(M16C)  
RAPI_INT0  
RAPI_INT1  
RAPI_INT2  
RAPI_INT3  
RAPI_INT4  
RAPI_INT5  
RAPI_KEY  
Uses _INT0 interrupt.  
Uses _INT1 interrupt.  
Uses _INT2 interrupt.  
Uses _INT3 interrupt.  
Uses _INT4 interrupt.  
Uses _INT5 interrupt.  
Uses key input interrupt.  
(R8C)  
RAPI_INT0  
RAPI_INT1  
RAPI_INT2  
RAPI_INT3  
RAPI_KEY  
Uses _INT0 interrupt.  
Uses _INT1 interrupt.  
Uses _INT2 interrupt.  
Uses _INT3 interrupt.  
Uses key input interrupt.  
(H8/300H)  
RAPI_IRQ0  
Uses IRQ0 interrupt.  
RAPI_IRQ1  
Uses IRQ1 interrupt.  
RAPI_IRQ2  
Uses IRQ2 interrupt.  
RAPI_IRQ3  
Uses IRQ3 interrupt.  
RAPI_WKP  
Uses WKP interrupt.  
RAPI_NOT_INT_  
REQUEST  
Does not request assertion of interrupt for a selected external  
interrupt. (Default)  
RAPI_INT_REQUEST  
Requests assertion of interrupt for a selected external interrupt.  
[data2]  
(M16C) (R8C)  
Specify the interrupt priority level (07) to be set in the interrupt control register.  
(H8/300H)  
Specify the interrupt priority level (0–1) to be set in the interrupt control register. For  
the CPUs that do not have an interrupt control register, specify 0.  
Rev.1.01  
2007.02.16  
176  
RJJ10J1643-0101  
 
Return value  
If the external interrupt specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
Remark  
External interrupt  
__SetInterrupt, __GetInterruptFlag, __ClearInterruptFlag  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable external interrupts differ with each CPU used.  
Program example  
#include " rapi_interrupt_r8c_13.h"  
void func( void )  
{
/* Activate _INT1 interrupt ( interrupt priority level 5 ) */  
__EnableInterrupt(RAPI_INT1, 5 );  
}
Rev.1.01  
2007.02.16  
177  
RJJ10J1643-0101  
 
__GetInterruptFlag  
Synopsis  
<Get the status of external interrupt flag>  
Boolean __GetInterruptFlag(unsigned long data1, unsigned int *data2))  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Pointer to the buffer in which the acquired flag data is stored  
Description  
Gets the value of interrupt request flag of a specified external interrupt.  
[data1]  
(M16C)  
RAPI_INT0  
RAPI_INT1  
RAPI_INT2  
RAPI_INT3  
RAPI_INT4  
RAPI_INT5  
RAPI_KEY  
Uses _INT0 interrupt.  
Uses _INT1 interrupt.  
Uses _INT2 interrupt.  
Uses _INT3 interrupt.  
Uses _INT4 interrupt.  
Uses _INT5 interrupt.  
Uses key input interrupt.  
(R8C)  
RAPI_INT0  
RAPI_INT1  
RAPI_INT2  
RAPI_INT3  
RAPI_KEY  
Uses _INT0 interrupt.  
Uses _INT1 interrupt.  
Uses _INT2 interrupt.  
Uses _INT3 interrupt.  
Uses key input interrupt.  
(H8/300H)  
RAPI_IRQ0  
RAPI_IRQ1  
RAPI_IRQ2  
RAPI_IRQ3  
RAPI_WKP0  
RAPI_WKP1  
RAPI_WKP2  
RAPI_WKP3  
RAPI_WKP4  
RAPI_WKP5  
Uses IRQ0 interrupt.  
Uses IRQ1 interrupt.  
Uses IRQ2 interrupt.  
Uses IRQ3 interrupt.  
Uses WKP0 interrupt.  
Uses WKP1 interrupt.  
Uses WKP2 interrupt.  
Uses WKP3 interrupt.  
Uses WKP4 interrupt.  
Uses WKP5 interrupt.  
[data2]  
0 0 0 0 0 0 0  
Value of interrupt request flag (0: Interrupt not requested; 1: Interrupt requested)  
Return value  
If the external interrupt specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Rev.1.01  
2007.02.16  
178  
RJJ10J1643-0101  
 
Functionality  
Reference  
Remark  
External interrupt  
__SetInterrupt, __EnableInterrupt, __ClearInterruptFlag  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable external interrupts differ with each CPU used.  
Program example  
#include " rapi_interrupt_r8c_13.h"  
void func( void )  
{
unsigned char data;  
/* Get flag of _INT2 interrupt */  
__GetInterruptFlag( IS_INT2, &data );  
}
Rev.1.01  
2007.02.16  
179  
RJJ10J1643-0101  
 
__ClearInterruptFlag  
Synopsis  
<Clear external interrupt flag>  
Boolean __ClearInterruptFlag(unsigned long data)  
data  
Setup data (content differs with MCU type)  
Description  
Clears the interrupt request flag of a specified external interrupt.  
[data]  
(M16C)  
RAPI_INT0  
RAPI_INT1  
RAPI_INT2  
RAPI_INT3  
RAPI_INT4  
RAPI_INT5  
RAPI_KEY  
Uses _INT0 interrupt.  
Uses _INT1 interrupt.  
Uses _INT2 interrupt.  
Uses _INT3 interrupt.  
Uses _INT4 interrupt.  
Uses _INT5 interrupt.  
Uses key input interrupt.  
(R8C)  
RAPI_INT0  
RAPI_INT1  
RAPI_INT2  
RAPI_INT3  
RAPI_KEY  
Uses _INT0 interrupt.  
Uses _INT1 interrupt.  
Uses _INT2 interrupt.  
Uses _INT3 interrupt.  
Uses key input interrupt.  
(H8/300H)  
RAPI_IRQ0  
RAPI_IRQ1  
RAPI_IRQ2  
RAPI_IRQ3  
RAPI_WKP0  
RAPI_WKP1  
RAPI_WKP2  
RAPI_WKP3  
RAPI_WKP4  
RAPI_WKP5  
Uses IRQ0 interrupt.  
Uses IRQ1 interrupt.  
Uses IRQ2 interrupt.  
Uses IRQ3 interrupt.  
Uses WKP0 interrupt.  
Uses WKP1 interrupt.  
Uses WKP2 interrupt.  
Uses WKP3 interrupt.  
Uses WKP4 interrupt.  
Uses WKP5 interrupt.  
Return value  
If the external interrupt specification is incorrect, RAPI_FALSE is returned; otherwise,  
RAPI_TRUE is returned.  
Functionality  
Reference  
Remark  
External interrupt  
__SetInterrupt, __EnableInterrupt, __GetInterruptFlag  
If an undefined value is specified in the first argument, operation of the API cannot  
Rev.1.01  
2007.02.16  
180  
RJJ10J1643-0101  
 
be guaranteed.  
The specifiable external interrupts differ with each CPU used.  
Program example  
#include " rapi_interrupt_r8c_13.h"  
void func( void )  
{
/* Clear status of _INT0 interrupt */  
__ClearInterruptFlag( RAPI_INT0 );  
}
Rev.1.01  
2007.02.16  
181  
RJJ10J1643-0101  
 
4.2.5 A/D converter  
__CreateADC  
Synopsis  
<Set A/D converter>  
Boolean __CreateADC(unsigned long data1, unsigned int data2, unsigned int  
data3, void* func)  
data1  
data2  
data3  
func  
Setup data 1 (content differs with MCU type)  
Number of analog input pins used by A/D converter (differs with MCU type)  
Setup data 3 (content differs with MCU type)  
Callback function pointer  
(Specify 0 if no callback functions are set.)  
Description  
Sets the A/D converter to specified mode and operating condition.  
[data1]  
For data1, the following definition values can be set. To set multiple definition values at  
the same time, use the symbol “|” to separate each specified value. Note, however,  
that multiple analog input pin symbols cannot be specified at the same time.  
(M16C)  
RAPI_ONE_SHOT  
RAPI_REPEAT  
RAPI_SINGLE_SWEEP  
RAPI_REPEAT_SWEEP0  
RAPI_REPEAT_SWEEP1  
RAPI_SIMULTANEOUS_  
SAMPLE_SWEEP  
RAPI_DELAYED_TRIGGER0  
RAPI_DELAYED_TRIGGER1  
RAPI_AN0  
Selects one-shot mode.  
Selects repeat mode.  
Selects single sweep mode.  
Selects repeat sweep mode 0.  
Selects repeat sweep mode 1.  
Selects simultaneous sampling sweep mode.  
Selects delayed trigger mode 0.  
Selects delayed trigger mode 1.  
Uses AN0 pin for the analog input pin.  
Uses AN1 pin for the analog input pin.  
Uses AN2 pin for the analog input pin.  
Uses AN3 pin for the analog input pin.  
Uses AN4 pin for the analog input pin.  
Uses AN5 pin for the analog input pin.  
Uses AN6 pin for the analog input pin.  
Uses AN7 pin for the analog input pin.  
Uses AN00 pin for the analog input pin.  
Uses AN01 pin for the analog input pin.  
Uses AN02 pin for the analog input pin.  
Uses AN03 pin for the analog input pin.  
Uses AN04 pin for the analog input pin.  
Uses AN05 pin for the analog input pin.  
Uses AN06 pin for the analog input pin.  
Uses AN07 pin for the analog input pin.  
Uses AN20 pin for the analog input pin.  
Uses AN21 pin for the analog input pin.  
RAPI_AN1  
RAPI_AN2  
RAPI_AN3  
RAPI_AN4  
RAPI_AN5  
RAPI_AN6  
RAPI_AN7  
RAPI_AN00  
RAPI_AN01  
RAPI_AN02  
RAPI_AN03  
RAPI_AN04  
RAPI_AN05  
RAPI_AN06  
RAPI_AN07  
RAPI_AN20  
RAPI_AN21  
Rev.1.01  
2007.02.16  
182  
RJJ10J1643-0101  
 
RAPI_AN22  
Uses AN22 pin for the analog input pin.  
Uses AN23 pin for the analog input pin.  
Uses AN24 pin for the analog input pin.  
Uses AN25 pin for the analog input pin.  
Uses AN26 pin for the analog input pin.  
Uses AN27 pin for the analog input pin.  
Uses AN30 pin for the analog input pin.  
Uses AN31 pin for the analog input pin.  
Uses AN32 pin for the analog input pin.  
Uses port P0 group for the analog input pin.  
Uses port P10 group for the analog input pin.  
Uses port P1/P9 group for the analog input pin.  
Uses port P9 group for the analog input pin.  
Sets the AD converter’s operating frequency to fAD  
RAPI_AN23  
RAPI_AN24  
RAPI_AN25  
RAPI_AN26  
RAPI_AN27  
RAPI_AN30  
RAPI_AN31  
RAPI_AN32  
RAPI_P0_GROUP  
RAPI_P10_GROUP  
RAPI_P1P9_GROUP  
RAPI_P9_GROUP  
RAPI_FAD  
.
Sets the AD converter’s operating frequency to fAD divided by 2.  
Sets the AD converter’s operating frequency to fAD divided by 3.  
Sets the AD converter’s operating frequency to fAD divided by 4.  
Sets the AD converter’s operating frequency to fAD divided by 6.  
Sets the AD converter’s operating frequency to fAD divided by 12.  
Sets the AD converter’s resolution to 10 bits.  
RAPI_FAD2  
RAPI_FAD3  
RAPI_FAD4  
RAPI_FAD6  
RAPI_FAD12  
RAPI_10BIT  
RAPI_8BIT  
Sets the AD converter’s resolution to 8 bits.  
RAPI_AD_ON  
Sets the AD converter to start operating.  
RAPI_AD_OFF  
RAPI_WITH_SAMPLE_HOLD  
RAPI_WITHOUT_SAMPLE_  
HOLD  
Sets the AD converter to stop operating.  
Specifies that sample-and-hold action is applied.  
Specifies that sample-and-hold action is not applied.  
RAPI_SOFTWARE_TRIGGER  
RAPI_EXTERNAL_TRIGGER  
RAPI_TIMER_B0_TRIGGER  
RAPI_TIMER_B2_TRIGGER  
RAPI_ICTB2_TRIGGER  
Selects software trigger.  
Selects external trigger.  
Selects underflow of timer B0 as trigger.  
Selects underflow of timer B2 as trigger.  
Selects underflow of timer B2 interrupt generation  
frequency set counter as trigger.  
• Specifiable definition values when one-shot mode is used (RAPI_ONE_SHOT specified)  
Specify one from { RAPI_AN0, RAPI_AN1, RAPI_AN2, RAPI_AN3, RAPI_AN4,  
RAPI_AN5, RAPI_AN6, RAPI_AN7, RAPI_AN00, RAPI_AN01, RAPI_AN02,  
RAPI_AN03, RAPI_AN04, RAPI_AN05, RAPI_AN06, RAPI_AN07, RAPI_AN20,  
RAPI_AN21, RAPI_AN22, RAPI_AN23, RAPI_AN24, RAPI_AN25, RAPI_AN26,  
RAPI_AN27, RAPI_AN30, RAPI_AN31, RAPI_AN32 }. The default is RAPI_AN0.  
Specify one from { RAPI_FAD, RAPI_FAD2, RAPI_FAD3, RAPI_FAD4,  
(Input pin)  
(Operating  
frequency)  
(Resolution)  
RAPI_FAD6, RAPI_FAD12 }. The default value is RAPI_FAD4.  
Specify one from { RAPI_10BIT, RAPI_8BIT }. The default value is  
RAPI_8BIT.  
(Operating  
states set)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Rev.1.01  
2007.02.16  
183  
RJJ10J1643-0101  
 
Specify one from { RAPI_WITH_SAMPLE_HOLD,  
RAPI_WITHOUT_SAMPLE_HOLD }. The default value is  
RAPI_WITHOUT_SAMPLE_HOLD.  
(Conversion  
method)  
(Trigger)  
Specify one from { RAPI_SOFTWARE_TRIGGER,  
RAPI_EXTERNAL_TRIGGER }.  
The default value is RAPI_SOFTWARE_TRIGGER.  
• Specifiable definition values when repeat mode is used (RAPI_REPEAT specified)  
Specify one from { RAPI_AN0, RAPI_AN1, RAPI_AN2, RAPI_AN3, RAPI_AN4,  
RAPI_AN5, RAPI_AN6, RAPI_AN7, RAPI_AN00, RAPI_AN01, RAPI_AN02,  
RAPI_AN03, RAPI_AN04, RAPI_AN05, RAPI_AN06, RAPI_AN07, RAPI_AN20,  
RAPI_AN21, RAPI_AN22, RAPI_AN23, RAPI_AN24, RAPI_AN25, RAPI_AN26,  
RAPI_AN27, RAPI_AN30, RAPI_AN31, RAPI_AN32 }. The default is RAPI_AN0.  
Specify one from { RAPI_FAD, RAPI_FAD2, RAPI_FAD3, RAPI_FAD4,  
(Input pin)  
(Operating  
frequency)  
(Resolution)  
RAPI_FAD6, RAPI_FAD12 }. The default value is RAPI_FAD4.  
Specify one from { RAPI_10BIT, RAPI_8BIT }. The default value is  
RAPI_8BIT.  
(Operating  
states set)  
(Conversion  
method)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_WITH_SAMPLE_HOLD,  
RAPI_WITHOUT_SAMPLE_HOLD }.  
The default value is RAPI_WITHOUT_SAMPLE_HOLD.  
Specify one from { RAPI_SOFTWARE_TRIGGER,  
RAPI_EXTERNAL_TRIGGER }.  
(Trigger)  
The default value is RAPI_SOFTWARE_TRIGGER.  
• Specifiable definition values when single sweep mode is used  
(RAPI_SINGLE_SWEEP specified)  
(Input pin)  
Specify one from { RAPI_P0_GROUP, RAPI_P10_GROUP,  
RAPI_P1P9_GROUP, RAPI_P9_GROUP }. The default value is  
RAPI_P10_GROUP.  
(Operating  
frequency)  
(Resolution)  
Specify one from { RAPI_FAD, RAPI_FAD2, RAPI_FAD3, RAPI_FAD4,  
RAPI_FAD6, RAPI_FAD12 }. The default value is RAPI_FAD4.  
Specify one from { RAPI_10BIT, RAPI_8BIT }. The default value is  
RAPI_8BIT.  
(Operating  
states set)  
(Conversion  
method)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_WITH_SAMPLE_HOLD,  
RAPI_WITHOUT_SAMPLE_HOLD }.  
The default value is RAPI_WITHOUT_SAMPLE_HOLD.  
Specify one from { RAPI_SOFTWARE_TRIGGER,  
RAPI_EXTERNAL_TRIGGER }.  
(Trigger)  
The default value is RAPI_SOFTWARE_TRIGGER.  
• Specifiable definition values when repeat sweep mode 0 is used  
(RAPI_REPEAT_SWEEP0 specified)  
(Input pin)  
Specify one from { RAPI_P0_GROUP, RAPI_P10_GROUP,  
RAPI_P1P9_GROUP, RAPI_P9_GROUP }. The default value is  
RAPI_P10_GROUP.  
(Operating  
frequency)  
Specify one from { RAPI_FAD, RAPI_FAD2, RAPI_FAD3, RAPI_FAD4,  
RAPI_FAD6, RAPI_FAD12 }. The default value is RAPI_FAD4.  
Rev.1.01  
2007.02.16  
184  
RJJ10J1643-0101  
 
(Resolution)  
Specify one from { RAPI_10BIT, RAPI_8BIT }. The default value is  
RAPI_8BIT.  
(Operating  
states set)  
(Conversion  
method)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_WITH_SAMPLE_HOLD,  
RAPI_WITHOUT_SAMPLE_HOLD }. The default value is  
RAPI_WITHOUT_SAMPLE_HOLD.  
Specify one from { RAPI_SOFTWARE_TRIGGER,  
RAPI_EXTERNAL_TRIGGER }. The default value is  
RAPI_SOFTWARE_TRIGGER.  
(Trigger)  
• Specifiable definition values when repeat sweep mode 1 is used  
(RAPI_REPEAT_SWEEP1 specified)  
(Input pin)  
Specify one from { RAPI_P0_GROUP, RAPI_P10_GROUP,  
RAPI_P1P9_GROUP, RAPI_P9_GROUP }. The default value is  
RAPI_P10_GROUP.  
(Operating  
frequency)  
(Resolution)  
Specify one from { RAPI_FAD, RAPI_FAD2, RAPI_FAD3, RAPI_FAD4,  
RAPI_FAD6, RAPI_FAD12 }. The default value is RAPI_FAD4.  
Specify one from { RAPI_10BIT, RAPI_8BIT }. The default value is  
RAPI_8BIT.  
(Operating  
states set)  
(Conversion  
method)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_WITH_SAMPLE_HOLD,  
RAPI_WITHOUT_SAMPLE_HOLD }.  
The default value is RAPI_WITHOUT_SAMPLE_HOLD.  
Specify one from { RAPI_SOFTWARE_TRIGGER,  
RAPI_EXTERNAL_TRIGGER }.  
(Trigger)  
The default value is RAPI_SOFTWARE_TRIGGER.  
• Specifiable definition values when simultaneous sampling sweep mode is used  
(RAPI_SIMULTANEOUS_SAMPLE_SWEEP specified)  
(Input pin)  
Specify one from { RAPI_P0_GROUP, RAPI_P10_GROUP,  
RAPI_P1P9_GROUP, RAPI_P9_GROUP }. The default value is  
RAPI_P10_GROUP.  
(Operating  
frequency)  
(Resolution)  
Specify one from { RAPI_FAD, RAPI_FAD2, RAPI_FAD3, RAPI_FAD4,  
RAPI_FAD6, RAPI_FAD12 }. The default value is RAPI_FAD4.  
Specify one from { RAPI_10BIT, RAPI_8BIT }. The default value is  
RAPI_8BIT.  
(Operating  
states set)  
(Trigger)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_SOFTWARE_TRIGGER, RAPI_EXTERNAL_TRIGGER,  
RAPI_TIMER_B0_TRIGGER, RAPI_TIMER_B2_TRIGGER,  
RAPI_ICTB2_TRIGGER }. The default value is RAPI_SOFTWARE_TRIGGER.  
• Specifiable definition values when delayed trigger mode 0 is used  
(RAPI_DELAYED_TRIGGER0 specified)  
(Input pin)  
Specify one from { RAPI_P0_GROUP, RAPI_P10_GROUP,  
RAPI_P1P9_GROUP, RAPI_P9_GROUP }. The default value is  
RAPI_P10_GROUP.  
(Operating  
frequency)  
Specify one from { RAPI_FAD, RAPI_FAD2, RAPI_FAD3, RAPI_FAD4,  
RAPI_FAD6, RAPI_FAD12 }. The default value is RAPI_FAD4.  
Rev.1.01  
2007.02.16  
185  
RJJ10J1643-0101  
 
(Resolution)  
Specify one from { RAPI_10BIT, RAPI_8BIT }. The default value is  
RAPI_8BIT.  
Specify RAPI_WITH_SAMPLE_HOLD.  
(Conversion  
method)  
• Specifiable definition values when delayed trigger mode 1 is used  
(RAPI_DELAYED_TRIGGER1 specified)  
(Input pin)  
Specify one from { RAPI_P0_GROUP, RAPI_P10_GROUP,  
RAPI_P1P9_GROUP, RAPI_P9_GROUP }. The default value is  
RAPI_P10_GROUP.  
(Operating  
frequency)  
(Resolution)  
Specify one from { RAPI_FAD, RAPI_FAD2, RAPI_FAD3, RAPI_FAD4,  
RAPI_FAD6, RAPI_FAD12 }. The default value is RAPI_FAD4.  
Specify one from { RAPI_10BIT, RAPI_8BIT }. The default value is  
RAPI_8BIT.  
Specify RAPI_WITH_SAMPLE_HOLD.  
(Conversion  
method)  
(R8C)  
RAPI_ONE_SHOT  
RAPI_REPEAT  
RAPI_AN0  
Selects one-shot mode.  
Selects repeat mode.  
Uses AN0 pin for the analog input pin.  
Uses AN1 pin for the analog input pin.  
Uses AN2 pin for the analog input pin.  
Uses AN3 pin for the analog input pin.  
Uses AN4 pin for the analog input pin.  
Uses AN5 pin for the analog input pin.  
Uses AN6 pin for the analog input pin.  
Uses AN7 pin for the analog input pin.  
Uses AN8 pin for the analog input pin.  
Uses AN9 pin for the analog input pin.  
Uses AN10 pin for the analog input pin.  
Uses AN11 pin for the analog input pin.  
Sets the AD converter’s operating frequency to fAD  
RAPI_AN1  
RAPI_AN2  
RAPI_AN3  
RAPI_AN4  
RAPI_AN5  
RAPI_AN6  
RAPI_AN7  
RAPI_AN8  
RAPI_AN9  
RAPI_AN10  
RAPI_AN11  
RAPI_FAD  
.
RAPI_FAD2  
RAPI_FAD4  
RAPI_FOCOF  
RAPI_10BIT  
RAPI_8BIT  
Sets the AD converter’s operating frequency to fAD divided by 2.  
Sets the AD converter’s operating frequency to fAD divided by 4.  
Sets the AD converter’s operating frequency to fOCO-F.  
Sets the AD converter’s resolution to 10 bits.  
Sets the AD converter’s resolution to 8 bits.  
RAPI_AD_ON  
RAPI_AD_OFF  
RAPI_WITH_SAMPLE_  
HOLD  
Sets the AD converter to start operating in __CreateAD.  
Sets the AD converter to stop operating in __CreateAD  
Specifies that sample-and-hold action is applied.  
RAPI_WITHOUT_  
SAMPLE_HOLD  
Specifies that sample-and-hold action is not applied.  
Rev.1.01  
2007.02.16  
186  
RJJ10J1643-0101  
 
RAPI_SOFTWARE_TRI  
GGER  
Selects software trigger.  
RAPI_TIMER_RD_TRIG Selects timer RD as trigger.  
GER  
• Specifiable definition values when one-shot mode is used (RAPI_ONE_SHOT specified)  
(Input pin)  
Specify one from  
{
RAPI_AN0, RAPI_AN1, RAPI_AN2, RAPI_AN3,  
RAPI_AN4, RAPI_AN5, RAPI_AN6, RAPI_AN7, RAPI_AN8, RAPI_AN9,  
RAPI_AN10, RAPI_AN11 }. Always be sure to specify an input pin.  
Specify one from { RAPI_FAD, RAPI_FAD2, RAPI_FAD4, RAPI_FOCOF }.  
The default value is RAPI_FAD4.  
(Operating  
frequency)  
(Resolution)  
Specify one from { RAPI_10BIT, RAPI_8BIT }. The default value is  
RAPI_8BIT.  
(Operating  
states set)  
(Conversion  
method)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_WITH_SAMPLE_HOLD,  
RAPI_WITHOUT_SAMPLE_HOLD }.  
The default value is RAPI_WITHOUT_SAMPLE_HOLD.  
(Trigger)  
Specify  
one  
from  
{
RAPI_SOFTWARE_TRIGGER,  
The default value is  
RAPI_TIMER_RD_TRIGGER  
RAPI_SOFTWARE_TRIGGER.  
}.  
• Specifiable definition values when repeat mode is used (RAPI_REPEAT specified)  
Specify one from  
{
RAPI_AN0, RAPI_AN1, RAPI_AN2, RAPI_AN3,  
(Input pin)  
RAPI_AN4, RAPI_AN5, RAPI_AN6, RAPI_AN7, RAPI_AN8, RAPI_AN9,  
RAPI_AN10, RAPI_AN11}. Always be sure to specify an input pin.  
Specify one from { RAPI_FAD, RAPI_FAD2, RAPI_FAD4 }. The default  
(Operating  
frequency)  
(Resolution)  
value is RAPI_FAD4.  
Specify one from { RAPI_10BIT, RAPI_8BIT }. The default value is  
RAPI_8BIT.  
(Operating  
states set)  
(Conversion  
method)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_WITH_SAMPLE_HOLD,  
RAPI_WITHOUT_SAMPLE_HOLD }.  
The default value is RAPI_WITHOUT_SAMPLE_HOLD.  
(Trigger)  
Specify  
one  
from  
{
RAPI_SOFTWARE_TRIGGER,  
The default value is  
RAPI_TIMER_RD_TRIGGER  
RAPI_SOFTWARE_TRIGGER.  
}.  
(H8/300H)  
RAPI_ONE_SHOT  
RAPI_REPEAT  
RAPI_SINGLE_SWEEP  
RAPI_REPEAT_SWEEP0  
RAPI_AN0  
Selects one-shot mode.  
Selects repeat mode.  
Selects single sweep mode.  
Selects repeat sweep mode 0.  
Uses AN0 pin for the analog input pin.  
Uses AN1 pin for the analog input pin.  
Uses AN2 pin for the analog input pin.  
Uses AN3 pin for the analog input pin.  
RAPI_AN1  
RAPI_AN2  
RAPI_AN3  
Rev.1.01  
2007.02.16  
187  
RJJ10J1643-0101  
 
RAPI_AN4  
Uses AN4 pin for the analog input pin.  
Uses AN5 pin for the analog input pin.  
Uses AN6 pin for the analog input pin.  
Uses AN7 pin for the analog input pin.  
Uses AN8 pin for the analog input pin.  
Uses AN9 pin for the analog input pin.  
Uses AN10 pin for the analog input pin.  
Uses AN11 pin for the analog input pin.  
Uses AN12 pin for the analog input pin.  
Uses AN13 pin for the analog input pin.  
Uses AN14 pin for the analog input pin.  
Uses AN15 pin for the analog input pin.  
Uses AN0AN3 group for the analog input pin.  
Uses AN4AN7 group for the analog input pin.  
Uses AN8AN11 group for the analog input pin.  
Uses AN12AN15 group for the analog input pin.  
Conversion time = 134 states  
RAPI_AN5  
RAPI_AN6  
RAPI_AN7  
RAPI_AN8  
RAPI_AN9  
RAPI_AN10  
RAPI_AN11  
RAPI_AN12  
RAPI_AN13  
RAPI_AN14  
RAPI_AN15  
RAPI_AN0_GROUP  
RAPI_AN4_GROUP  
RAPI_AN8_GROUP  
RAPI_AN12_GROUP  
RAPI_134_STATES  
RAPI_70_STATES  
RAPI_AD_ON  
RAPI_AD_OFF  
RAPI_RISING_TRIGGER  
Conversion time = 70 states  
Sets the AD converter to start operating in __CreateAD.  
Sets the AD converter to stop operating in __CreateAD.  
Includes a rising-edge external trigger in the A/D conversion  
start condition.  
RAPI_FALLING_TRIGGER Includes a falling-edge external trigger in the A/D conversion  
start condition.  
RAPI_AD_INT_REQUEST Requests assertion of interrupt for A/D conversion interrupt.  
RAPI_NOT_AD_INT_  
REQUEST  
Does not request assertion of interrupt for A/D conversion  
interrupt.  
• Specifiable definition values when one-shot mode is used (RAPI_ONE_SHOT specified)  
(Input pin)  
Specify one from { RAPI_AN0, RAPI_AN1, RAPI_AN2, RAPI_AN3, RAPI_AN4,  
RAPI_AN5, RAPI_AN6, RAPI_AN7, RAPI_AN8, RAPI_AN9, RAPI_AN10,  
RAPI_AN11, RAPI_AN12, RAPI_AN13, RAPI_AN14, RAPI_AN15 }. The default  
value is RAPI_AN0.  
(Conversion  
time)  
Specify one from { RAPI_134_STATES, RAPI_70_STATES }. The default  
value is RAPI_134_STATES.  
(Operating  
states set)  
(Trigger)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_RISING_TRIGGER, RAPI_FALLING_TRIGGER }.  
If no triggers are specified, “Trigger input disabled” is set.  
Specify one from { RAPI_AD_INT_REQUEST,  
RAPI_NOT_AD_INT_REQUEST }.  
(Interrupt  
request)  
The default value is RAPI_NOT_AD_INT_REQUEST.  
• Specifiable definition values when repeat mode is used (RAPI_REPEAT specified)  
Rev.1.01  
2007.02.16  
188  
RJJ10J1643-0101  
 
(Input pin)  
Specify one from { RAPI_AN0, RAPI_AN1, RAPI_AN2, RAPI_AN3, RAPI_AN4,  
RAPI_AN5, RAPI_AN6, RAPI_AN7, RAPI_AN8, RAPI_AN9, RAPI_AN10,  
RAPI_AN11, RAPI_AN12, RAPI_AN13, RAPI_AN14, RAPI_AN15 } The default  
value is RAPI_AN0.  
(Conversion  
time)  
Specify one from { RAPI_134_STATES, RAPI_70_STATES }. The default  
value is RAPI_134_STATES.  
(Operating  
states set)  
(Trigger)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_RISING_TRIGGER, RAPI_FALLING_TRIGGER }.  
If no triggers are specified, “Trigger input disabled” is set.  
• Specifiable definition values when single sweep mode is used  
(RAPI_SINGLE_SWEEP specified)  
(Input pin)  
Specify  
one  
from  
{
RAPI_AN0_GROUP,  
RAPI_AN4_GROUP,  
RAPI_AN8_GROUP, RAPI_AN12_GROUP }.  
The default value is RAPI_AN0_GROUP.  
(Conversion  
time)  
Specify one from { RAPI_134_STATES, RAPI_70_STATES }. The default  
value is RAPI_134_STATES.  
(Operating  
states set)  
(Trigger)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_RISING_TRIGGER, RAPI_FALLING_TRIGGER }.  
If no triggers are specified, “Trigger input disabled” is set.  
Specify one from { RAPI_AD_INT_REQUEST,  
(Interrupt  
request)  
RAPI_NOT_AD_INT_REQUEST }.  
The default value is RAPI_NOT_AD_INT_REQUEST.  
• Specifiable definition values when repeat sweep mode 0 is used  
(RAPI_REPEAT_SWEEP0 specified)  
(Input pin)  
Specify  
one  
from  
{
RAPI_AN0_GROUP,  
RAPI_AN4_GROUP,  
RAPI_AN8_GROUP, RAPI_AN12_GROUP }. The default value is  
RAPI_AN0_GROUP.  
(Conversion  
time)  
Specify one from { RAPI_134_STATES, RAPI_70_STATES }. The default  
value is RAPI_134_STATES.  
(Operating  
states set)  
(Trigger)  
Specify one from { RAPI_AD_ON, RAPI_AD_OFF }. The default value is  
RAPI_AD_OFF.  
Specify one from { RAPI_RISING_TRIGGER, RAPI_FALLING_TRIGGER }.  
If no triggers are specified, “Trigger input disabled” is set.  
[data2]  
(M16C)  
The set value differs with the A/D conversion mode used.  
One-shot mode  
Specify 1.  
Repeat mode  
Single sweep mode  
Repeat sweep mode 0  
Simultaneous sampling mode  
Delayed trigger mode 0  
Specify 2, 4, 6, or 8.  
Rev.1.01  
2007.02.16  
189  
RJJ10J1643-0101  
 
Delayed trigger mode 1  
Repeat sweep mode  
Specify 1, 2, 3, or 4.  
(R8C)  
Specify 1.  
(H8/300H)  
One-shot mode  
Specify 1.  
Repeat mode  
Single sweep mode  
Repeat sweep mode 0  
Specify 1, 2, 3, or 4.  
[data3]  
(M16C) (R8C)  
Specify the interrupt priority level (07) to be set in the interrupt control register.  
(H8/300H)  
Specify the interrupt priority level (0–1) to be set in the interrupt control register.  
For the CPUs that do not have an interrupt control register, specify 0.  
Return value  
If A/D converter was successfully set, RAPI_TRUE is returned; if failed, RAPI_FALSE  
is returned.  
Functionality  
Reference  
Remark  
A/D converter  
__EnableADC, __DestroyADC, __GetADC, __GetADCAll  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable analog input pins differ with each CPU used.  
If you use an R8C MCU which does not support fOCO-F for its operating frequency, you  
cannot specify RAPI_FOCOF.  
If you use an R8C MCU which does not support timer RD as a trigger, you cannot specify  
RAPI_TIMER_RD_TRIGGER as a trigger.  
When used for the H8/300H, this API specify when freeing it from module stanby.  
Program example  
#include " rapi_ad_r8c_13.h"  
void AdIntFunc( void ){}  
void func( void )  
{
/* Set up A/D converter as one short mode */  
__CreateADC( RAPI_ONE_SHOT|RAPI_AN2|RAPI_FAD2| RAPI_WITH_SAMPLE_HOLD  
|
RAPI_EXTERNAL_TRIGGER  
|RAPI_AD_ON|RAPI_10BIT,  
1,  
5,  
AdIntFunc );  
}
Rev.1.01  
2007.02.16  
190  
RJJ10J1643-0101  
 
__EnableADC  
Synopsis  
<Control operation of A/D converter>  
Boolean __EnableADC (unsigned long data1, unsigned int data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Number of analog input pins used by A/D converter (differs with MCU type)  
Description  
Controls operation of the A/D converter by starting or stopping it.  
[data1]  
(M16C)  
RAPI_AN0  
RAPI_AN1  
RAPI_AN2  
RAPI_AN3  
RAPI_AN4  
RAPI_AN5  
RAPI_AN6  
RAPI_AN7  
RAPI_AN00  
RAPI_AN01  
RAPI_AN02  
RAPI_AN03  
RAPI_AN04  
RAPI_AN05  
RAPI_AN06  
RAPI_AN07  
RAPI_AN20  
Uses AN0 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN1 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN2 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN3 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN4pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN5pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN6 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN7 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN00 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN01 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN02 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN03 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN04 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN05pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN06 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN07 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN20 pin for the analog input pin.  
Rev.1.01  
2007.02.16  
191  
RJJ10J1643-0101  
 
Selectable only when one-shot mode or repeat mode is used.  
Uses AN21 pin for the analog input pin.  
RAPI_AN21  
RAPI_AN22  
RAPI_AN23  
RAPI_AN24  
RAPI_AN25  
RAPI_AN26  
RAPI_AN27  
RAPI_AN30  
RAPI_AN31  
RAPI_AN32  
RAPI_P0_GROUP  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN22 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN23 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN24 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN25 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN26 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN27 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN30 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN31 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN32 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses port P0 group for the analog input pin. Selectable only when  
sweep mode, repeat sweep mode 0, simultaneous sampling sweep  
mode, delayed trigger mode 0, delayed trigger mode 1, or repeat sweep  
mode 1 is used.  
RAPI_P10_GROUP Uses port P10 group for the analog input pin. Selectable only when  
sweep mode, repeat sweep mode 0, simultaneous sampling sweep  
mode, delayed trigger mode 0, delayed trigger mode 1, or repeat sweep  
mode 1 is used.  
RAPI_P1P9_GROUP Uses port P1 /P9 group for the analog input pin. Selectable only when  
sweep mode, repeat sweep mode 0, simultaneous sampling sweep  
mode, delayed trigger mode 0, delayed trigger mode 1, or repeat sweep  
mode 1 is used.  
RAPI_P9_GROUP  
Uses port P9 group for the analog input pin. Selectable only when  
sweep mode, repeat sweep mode 0, simultaneous sampling sweep  
mode, delayed trigger mode 0, delayed trigger mode 1, or repeat sweep  
mode 1 is used.  
RAPI_AD_ON  
RAPI_AD_OFF  
Sets the A/D converter to start operating.  
Sets the A/D converter to stop operating.  
(R8C)  
RAPI_AN0  
RAPI_AN1  
RAPI_AN2  
RAPI_AN3  
Uses AN0 pin for the analog input pin.  
Uses AN1 pin for the analog input pin.  
Uses AN2 pin for the analog input pin.  
Uses AN3 pin for the analog input pin.  
Rev.1.01  
2007.02.16  
192  
RJJ10J1643-0101  
 
RAPI_AN4  
RAPI_AN5  
RAPI_AN6  
RAPI_AN7  
RAPI_AN8  
RAPI_AN9  
RAPI_AN10  
RAPI_AN11  
RAPI_AD_ON  
RAPI_AD_OFF  
Uses AN4 pin for the analog input pin.  
Uses AN5 pin for the analog input pin.  
Uses AN6 pin for the analog input pin.  
Uses AN7 pin for the analog input pin.  
Uses AN8 pin for the analog input pin.  
Uses AN9 pin for the analog input pin.  
Uses AN10 pin for the analog input pin.  
Uses AN11 pin for the analog input pin.  
Sets the A/D converter to start operating.  
Sets the A/D converter to stop operating.  
(H8/300H)  
RAPI_AN0  
RAPI_AN1  
RAPI_AN2  
RAPI_AN3  
RAPI_AN4  
RAPI_AN5  
RAPI_AN6  
RAPI_AN7  
RAPI_AN8  
RAPI_AN9  
RAPI_AN10  
RAPI_AN11  
RAPI_AN12  
RAPI_AN13  
RAPI_AN14  
RAPI_AN15  
RAPI_AN0_GROUP  
Uses AN0 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN1 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN2 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN3 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN4 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN5 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN6 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN7 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN8 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN9 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN10 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN11 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN12 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN13 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN14 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN15 pin for the analog input pin.  
Selectable only when one-shot mode or repeat mode is used.  
Uses AN0-AN3 pins group for the analog input pin.  
Rev.1.01  
2007.02.16  
193  
RJJ10J1643-0101  
 
Selectable only when sweep mode or repeat sweep mode 0 is used.  
Uses AN4-AN7 pins group for the analog input pin.  
RAPI_AN4_GROUP  
RAPI_AN8_GROUP  
Selectable only when sweep mode or repeat sweep mode 0 is used.  
Uses AN8-AN11 pins group for the analog input pin.  
Selectable only when sweep mode or repeat sweep mode 0 is used.  
RAPI_AN12_GROUP Uses AN12-AN15 pins group for the analog input pin.  
Selectable only when sweep mode or repeat sweep mode 0 is used.  
RAPI_AD_ON  
RAPI_AD_OFF  
Sets the A/D converter to start operating.  
Sets the A/D converter to stop operating.  
[data2]  
(M16C)  
The set value differs with the A/D conversion mode used.  
One-shot mode  
Specify 1.  
Repeat mode  
Single sweep mode  
Repeat sweep mode 0  
Simultaneous sampling mode  
Delayed trigger mode 0  
Delayed trigger mode 1  
Repeat sweep mode 1  
Specify 2, 4, 6, or 8.  
Specify 1, 2, 3, or 4.  
(R8C)  
Specify 1.  
(H8/300H)  
One-shot mode  
Specify 1.  
Repeat mode  
Single sweep mode  
Repeat sweep mode 0  
Specify 1, 2, 3, or 4.  
Return value  
Functionality  
If A/D converter was successfully controlled, RAPI_TRUE is returned; if failed,  
RAPI_FALSE is returned.  
A/D converter  
Reference  
Remark  
__CreateADC, __DestroyADC, __GetADC, __GetADCAll  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
The specifiable analog input pins differ with each CPU used.  
Program example  
#include "rapi_ad_r8c_13.h"  
Rev.1.01  
2007.02.16  
194  
RJJ10J1643-0101  
 
void func( void )  
{
/* Disable A/D converter */  
__EnableADC( RAPI_AN0|RAPI_AD_OFF, 1 );  
}
Rev.1.01  
2007.02.16  
195  
RJJ10J1643-0101  
 
__DestroyADC  
Synopsis  
<Discard settings of A/D converter>  
Boolean __DestroyADC(void)  
Description  
Discards settings of a specified A/D converter.  
Return value  
If converter setting was successfully discarded, RAPI_TRUE is returned; if failed,  
RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
A/D converter  
__CreateADC, __EnableADC, __GetADC, __GetADCAll  
When used for the H8/300H, this API places a specified timer into module stanby  
state after discarding it.  
Program example  
#include "rapi_ad_r8c_13.h"  
void func( void )  
{
/* Destroy A/D converter */  
__DestroyADC();  
}
Rev.1.01  
2007.02.16  
196  
RJJ10J1643-0101  
 
__GetADC  
Synopsis  
<Get A/D converted value (register specified)>  
Boolean __GetADC(unsigned long data1, unsigned int *data2)  
data1  
data2  
Setup data 1 (content differs with MCU type)  
Pointer to the buffer in which A/D converted value is stored.  
Description  
Gets the A/D converted value from a specified A/D register.  
For data1, the following values can be set.  
(M16C)  
RAPI_AD0  
RAPI_AD1  
RAPI_AD2  
RAPI_AD3  
RAPI_AD4  
RAPI_AD5  
RAPI_AD6  
RAPI_AD7  
Selects A/D register 0.  
Selects A/D register 1.  
Selects A/D register 2.  
Selects A/D register 3.  
Selects A/D register 4.  
Selects A/D register 5.  
Selects A/D register 6.  
Selects A/D register 7.  
(R8C)  
Specify 0.  
(H8/300H)  
RAPI_ADDRA  
RAPI_ADDRB  
RAPI_ADDRC  
RAPI_ADDRD  
Selects A/D data register A.  
Selects A/D data register B.  
Selects A/D data register C.  
Selects A/D data register D.  
Return value  
If A/D converted value was successfully acquired, RAPI_TRUE is returned; if failed,  
RAPI_FALSE is returned.  
Functionality  
Reference  
Remark  
A/D converter  
__CreateADC, __EnableADC, __DestroyADC, __GetADCAll  
If an undefined value is specified in the first argument, operation of the API cannot  
be guaranteed.  
Program example  
#include "rapi_ad_r8c_13.h"  
void func( void )  
{
unsigned int data;  
/* Get an A/D convertered data of A/D register 0 */  
__GetADC( RAPI_AD0, &data );  
}
Rev.1.01  
2007.02.16  
197  
RJJ10J1643-0101  
 
__GetADCAll  
Synopsis  
<Get A/D converted value (all registers)>  
Boolean __GetADCAll(unsigned int *data)  
data  
Pointer to the buffer in which A/D converted value is stored.  
Description  
Gets the A/D converted value from all A/D registers.  
The A/D registers from which A/D converted values are acquired are listed below.  
[M16C]  
:
[0] A/D register 0  
[1] A/D register 1  
[2] A/D register 2  
[3] A/D register 3  
[4] A/D register 4  
[5] A/D register 5  
[6] A/D register 6  
[7] A/D register 7  
(16 bytes)  
[R8C]  
:
:
A/D register  
(2 bytes)  
[H8/300H]  
[0] A/D register A  
[1] A/D register B  
[2] A/D register C  
[3] A/D register D  
(8 bytes)  
Return value  
If A/D converted values were successfully acquired, RAPI_TRUE is returned; if failed,  
RAPI_FALSE is returned.  
Functionality  
Reference  
A/D converter  
__CreateADC, __EnableADC, __DestroyADC, __GetADC  
Program example  
#include "rapi_ad_r8c_13.h"  
void func( void )  
{
unsigned int data[8];  
/* Get A/D convertered datas of A/D register */  
__GetADCAll( data );  
}
Rev.1.01  
2007.02.16  
198  
RJJ10J1643-0101  
 
__GetADCStatus  
Synopsis  
<Get the status of A/D converter>  
Boolean __GetADCStatus(unsigned int *status)  
status  
Pointer to the buffer in which the register content indicating A/D converter  
status is stored.  
Description  
Gets the status of a specified A/D converter.  
The status of interrupt bit (when using the M16C or R8C) or the value of A/D end flag  
(when using the H8/300H) is stored in the first low-order bit of *status. Furthermore,  
the status of A/D conversion start flag is stored in the second low-order bit of *status.  
When used in the M16C, the value of A/D conversion status register 0 is stored in the 8  
high-order bits of *status.  
[Configuration of *status]  
0 0 0 0 0 0  
Value of interrupt  
bit or A/D end flag  
Value of A/D conversion status Value of A/D conversion start flag (for only  
register 0 (for only the M16C; 0 for the R8C; 0 for the M16C and H8/300H)  
the R8C and H8/300H)  
Return value  
If A/D converter status was successfully acquired, RAPI_TRUE is returned; if failed,  
RAPI_FALSE is returned.  
Functionality  
Reference  
A/D converter  
__ClearADCStatus  
Program example  
#include " rapi_ad_r8c_13.h"  
void func( void )  
{
unsigned int status;  
/* Get status of A/D convertered */  
__GetADCStatus( &status );  
}
Rev.1.01  
2007.02.16  
199  
RJJ10J1643-0101  
 
__ClearADCStatus  
Synopsis  
<Clear the status of A/D converter>  
Boolean __ClearADCStatus(unsigned int status)  
status  
Status of A/D converter  
Description  
Clears the status flag of a specified A/D converter.  
Specify the status of interrupt bit (when using the M16C or R8C) or the value of A/D  
end flag (when using the H8/300H) in the first low-order bit of status.  
When used in the M16C, specify the value of A/D conversion status register 0 in the 8  
high-order bits of status. Write 0 to the bits to be cleared and 1 to the bits that do not  
need to be cleared.  
[Configuration of status]  
0 0 0 0 0 0 0  
Value of A/D conversion status register 0 (for Value of interrupt bit or  
only the M16C; 0 for the R8C and H8/300H)  
A/D end flag  
Return value  
If A/D converter status flag was successfully cleared, RAPI_TRUE is returned; if failed,  
RAPI_FALSE is returned.  
Functionality  
Reference  
A/D converter  
__GetADCStatus  
Program example  
#include "rapi_ad_r8c_13.h"  
void func( void )  
{
/* Clear status of A/D convertered */  
__ClearADCStatus( 0 );  
}
Rev.1.01  
2007.02.16  
200  
RJJ10J1643-0101  
 
Renesas Embedded  
Application Programming Interface  
Reference Manual  
Rev. 1.01  
Issued: April 2007  
Rev.1.01  
2007.02.16  
201  
RJJ10J1643-0101  
 
Renesas Embedded  
Application Programming Interface  
Reference manual  
2-6-2, Ote-machi, Chiyoda-ku, Tokyo,100-0004, Japan  
 

PYLE Audio Speaker PSPVC4 User Guide
Rangemaster Oven Single Built in Oven User Guide
RCA Telephone 25825 User Guide
RIDGID Drill R82015 User Guide
Rose electronic Switch Vista Mini User Guide
Samsung Blu ray Player BD J5900 User Guide
Samsung Security Camera SCC C6407 User Guide
SATO Printer MI 6308 User Guide
Schwinn Home Gym 112212 User Guide
Seagate Computer Drive ST98823A User Guide