# Old Company Name in Catalogs and Other Documents

On April 1<sup>st</sup>, 2010, NEC Electronics Corporation merged with Renesas Technology Corporation, and Renesas Electronics Corporation took over all the business of both companies. Therefore, although the old company name remains in this document, it is a valid Renesas Electronics document. We appreciate your understanding.

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

April 1<sup>st</sup>, 2010 Renesas Electronics Corporation

Issued by: Renesas Electronics Corporation (http://www.renesas.com)

Send any inquiries to http://www.renesas.com/inquiry.

#### Notice

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



# H8/300H Tiny Series

# Outputting a Scale

# Introduction

A keyboard is connected to the parallel port, and musical notes corresponding to pressed keys are output from a speaker.

# **Target Device**

H8/36014

## Contents

| 1. | Specifications           | . 2 |
|----|--------------------------|-----|
| 2. | Description of Functions | . 3 |
| 3. | Principle of Operation   | . 4 |
| 4. | Description of Software  | . 7 |
| 5. | Flowchart                | 10  |
| 6. | Program Listing          | 12  |



## 1. Specifications

- 1. Figure 1.1 shows the hardware configuration for an example of a musical note output circuit connection. As shown in figure 1.1, the keyboard is connected to the I/O port (pins P10 to P12 and P70 to P73).
- 2. A square wave of the frequency corresponding to the key pressed on the keyboard is output from the speaker connected to the I/O port (pin P76).



Figure 1.1 Hardware Configuration

- 3. In this sample task, the H8/36014 operating voltage (Vcc) and analog power supply voltage (AVcc) are 5.0 V, and the OSC clock frequency is 16 MHz.
- 4. The keyboard used in this sample task is a numerical keypad used for input to a personal computer. Normally a 1bit serial signal is output, but in this example the keyboard is modified to enable parallel I/O.
- 5. Operation of this sample task is as follows:
  - A. Of the seven ports connected to the keyboard, P70 to P73 are sequentially switched to set to H level.
  - B. Then the states of the remaining three ports P10 to P12 are monitored, and a pressed key is identified through the ports at which H level is detected.
  - C. The frequency corresponding to the pressed key is output to port P76. The waveform is a rectangular waveform at H level.
  - D. For example, if "1" on the numerical keypad is pressed, the combination of ports P70 and P10 causes the frequency 261.63 Hz of the note "do" to be output.
  - E. The volume is adjusted using the variable resistor.



# 2. Description of Functions

Figure 2.1 is a block diagram of the H8/36014 functions used in this sample task. Table 2.1 shows function allocations.



Figure 2.1 Block Diagram of Functions

#### Table 2.1 Function Allocation

| Function Used | Function Allocation                                                                                                                               |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer V       | A compare-match function is used to toggle output. By setting the value in the time constant register A (TCORA), the output frequency is changed. |
| Port 1        | Keyboard input is detected on input pins P10 to P12 of port 1.                                                                                    |
| Port 7        | Successive switching to the H level is effected through the port 7 output pins P70 to P73. The frequency is output from P76.                      |



# 3. Principle of Operation

1. The principle of operation for producing a musical note output using the timer V is shown in figure 3.1. As illustrated in this figure, TMOV output is toggled in the cycle of compare-match of timer V to output the sound of A (440 Hz).



Figure 3.1 Principle of Operation for Musical Note Output Using Timer V

- RENESAS
- 2. Timer V settings
- Internal clock settings
- The system clock is  $\phi = 16$  MHz, and the internal clock  $\phi/128$  is selected.  $\phi/128 = 12500$  Hz.
- Counter values set in TCORA

#### Table 3.1 Description of Counter Values

| Note | Counter value | Output frequency | Calculated frequency |  |
|------|---------------|------------------|----------------------|--|
| С    | 239           | 261.51           | 261.63               |  |
| C#   | 225           | 277.78           | 277.18               |  |
| D    | 213           | 293.43           | 293.66               |  |
| D#   | 201           | 310.95           | 311.13               |  |
| E    | 190           | 328.95           | 329.63               |  |
| F    | 179           | 349.16           | 349.23               |  |
| F#   | 169           | 369.82           | 369.99               |  |
| G    | 159           | 393.08           | 392.00               |  |
| G#   | 150           | 416.67           | 415.30               |  |
| A    | 142           | 440.14           | 440.00               |  |
| A#   | 134           | 466.42           | 466.16               |  |
| В    | 127           | 492.13           | 493.88               |  |

[Legend]

| Musical notes:        | C (do) to B (ti)                           |
|-----------------------|--------------------------------------------|
| Counter value:        | (operating clock/2)/calculated frequency   |
| Output frequency:     | (operating clock/2)/counter value          |
| Calculated frequency: | Calculated frequency of each musical note. |

Note: The operating clock is divided by 2 because the ON/OFF action makes one cycle.

• Calculated frequency

The frequency for each note is calculated using the following formula: Calculated frequency =  $440 * 2^{(X/12)}$ 

Example: Calculate to two decimal places.

For the note of A:  $440 \times 2^{(0)/12} = 440$  Hz For the note of A#:  $440 \times 2^{(1)/12} = 466.16$  Hz For the note of G#:  $440 \times 2^{(-1)/12} = 415.30$  Hz

• Counter values

Calculate the counter values that are to be set in TCORA. Counter value = (operating clock/2)/calculated frequency. Example: Calculate as integers. For the note of A: 125000 / 2 / 440 = 142 For the note of A#: 125000 / 2 / 466.16 = 134 For the note of G#: 125000 / 2 / 415.30 = 150

• Output frequency

Calculate the frequency to be output from the speaker. Output frequency = (operating clock/2)/counter value.

Example: Calculated to two decimal places. For the note of A: 125000 / 2 / 142 = 440.14For the note of A#: 125000 / 2 / 134 = 466.42For the note of G#: 125000 / 2 / 150 = 416.67



#### 3. Keyboard input



Figure 3.2 Example of Keyboard Connection

| Table 3.2 | Correspondence | Between the Out | put Musical Note a | and the Key Pressed |
|-----------|----------------|-----------------|--------------------|---------------------|
|-----------|----------------|-----------------|--------------------|---------------------|

| Musical Note | Кеу      |
|--------------|----------|
| С            | 1        |
| C#           | 2        |
| D            | 3        |
| D#           | 4        |
| E            | 5        |
| F            | 6        |
| F#           | 7        |
| G            | 8        |
| G#           | 9        |
| A            | Num Lock |
| A#           | 1        |
| В            | *        |

P70 to P73 are sequentially switched to be driven to H level, and the states of P10 to P12 are monitored; the pressed key is identified from the ports at which H level is detected. The correspondence between the output musical note and the key pressed is indicated in table 3.2.



### 4. Description of Software

## 4.1 Modules

Table 4.1 describes the modules used in this sample task.

#### Table 4.1 Description of Modules

| Module Name        | Label Name | Function                                           |
|--------------------|------------|----------------------------------------------------|
| Main routine       | main       | Makes initial settings, outputs frequencies.       |
| Keyboard input     | input_key  | Scans keyboard and returns the corresponding code. |
| processing routine |            | If no key is pressed: -1                           |
|                    |            | If a key is pressed: 0 to 11                       |

# 4.2 Arguments

This sample task uses no arguments.

# 4.3 Internal Registers

The internal registers used in this sample task are described in table 4.2.

#### Table 4.2 Description of Internal Registers

| Register Name | Function                                                                                                                                                                                                          | Address     | Setting |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------|
| TCRV0         | Timer control register V0<br>Selects TCNTV input clock, sets condition for clearing of<br>TCNTV, and controls the individual timer V interrupt requests.                                                          | H'FFA0      | H'0B    |
| CMIEB         | Compare Match Interrupt Enable B:<br>When CMIEB = 0, interrupt requests on setting of the CMFB bi<br>in TCSRV are disabled.                                                                                       | Bit 7<br>it | 0       |
| CMIEA         | Compare Match Interrupt Enable A:<br>When CMIEA = 0, interrupt requests on setting of the CMFA bi<br>in TCSRV are disabled.                                                                                       | Bit 6<br>it | 0       |
| OVIE          | Timer Overflow Interrupt Enable:<br>When OVIE = 0, interrupt requests on setting of the OVF bit in<br>TCSRV are disabled.<br>When OVIE = 1, interrupt requests on setting of the OVF bit in<br>TCSRV are enabled. |             | 0       |
| CCLR1         | Counter Clear 1 and 0:                                                                                                                                                                                            | Bit 4       | 0       |
| CCLR0         | Sets the conditions for clearing of TCNTV.<br>When CCLR1 = 0 and CCLR0 = 1 are both set, TCNTV is<br>cleared on compare-match with A.                                                                             | Bit 3       | 1       |
| CKS2          | Clock Select 2 to 0:                                                                                                                                                                                              | Bit 2       | 0       |
| CKS1          | In combination with the ICKS0 bit of TCRV1, selects the clock                                                                                                                                                     | Bit 1       | 1       |
| CKS0          | signal for input to TCNTV and the condition to be counted.<br>With CKS2 = 0, CKS1 = 1, CKS0 = 1 and ICKS0=1, counting<br>by TCNTV is of the falling edges of the internal clock $\phi$ /128.                      | Bit 0       | 1       |

# RENESAS

| Register | Name  | Function                                                                                                  | Address | Setting           |
|----------|-------|-----------------------------------------------------------------------------------------------------------|---------|-------------------|
| TCSRV    |       | Timer Control/Status Register V:                                                                          | H'FFA1  | H'00              |
|          |       | Holds the overflow and compare-match status flags for timer V and controls output in response to a match. |         | (initial setting) |
|          | CMFB  | Compare Match Flag B:                                                                                     | Bit 7   | 0                 |
|          |       | When the values of TCNTV and TCORB match, CMFB is set                                                     |         |                   |
|          |       | to 1.                                                                                                     |         |                   |
|          | CMFA  | Compare Match Flag A:                                                                                     | Bit 6   | 0                 |
|          |       | When the values of TCNTV and TCORA match, CMFA is set                                                     |         |                   |
|          |       | to 1.                                                                                                     |         |                   |
|          | OVF   | Timer Overflow Flag:                                                                                      | Bit 5   | 0                 |
|          |       | When the value of TCNTV overflows, OVF is set to 1.                                                       |         |                   |
|          |       | This bit is cleared by reading it while it is set and then writing a                                      |         |                   |
|          |       | 0 to it.                                                                                                  |         |                   |
|          | OS3   | Output Select Bits 3 and 2:                                                                               | Bit 3   | 0                 |
|          | OS2   | Selects the output level on the TMOV pin in response to a                                                 | Bit 2   | 0                 |
|          |       | match for compare-match B.                                                                                |         |                   |
|          |       | When OS3 = 0 and OS2 = 0: No change                                                                       |         |                   |
|          | OS1   | Output Select Bits 1 and 0:                                                                               | Bit 1   | 0/1               |
|          | OS0   | Selects the output level on the TMOV pin in response to a                                                 | Bit 0   | 0/1               |
|          |       | match for compare-match A.                                                                                |         |                   |
|          |       | When OS = 0 and OS0 = 0: No change                                                                        |         |                   |
|          |       | When OS = 1 and OS0 = 1: Toggle output                                                                    |         |                   |
| CORA     |       | Time constant register A:                                                                                 | H'FFA2  | H'00              |
|          |       | TCORA is an 8-bit readable/writable register. In this sample                                              |         | (initial setting) |
|          |       | task, TCNTV is always compared with TCORA and the output                                                  |         |                   |
|          |       | is toggled upon a match.                                                                                  |         |                   |
| CNTV     |       | Timer counter V:                                                                                          | H'FFA4  | H'00              |
|          |       | An 8-bit count-up counter which takes as input the system                                                 |         |                   |
|          |       | clock- frequency divided by 128.                                                                          |         |                   |
| CRV1     |       | Timer Control Register V1:                                                                                | H'FFA5  | H'01              |
|          |       | Selects the input edge of the TRGV pin, enables TRGV input,                                               |         |                   |
|          |       | and selects the TCNTV input clock.                                                                        |         |                   |
|          | TVEG1 | TRGV Input Edge Selects 1 and 0:                                                                          | Bit 4   | 0                 |
|          | TVEG0 | Selects the input edge of the TRGV pin.                                                                   | Bit 3   | 0                 |
|          |       | In this case TVEG1 = 0 and TVEG0 = 0, so trigger input from                                               |         |                   |
|          |       | the TRGV pin is disabled.                                                                                 |         |                   |
|          | TRGE  | TRGV Input Enable:                                                                                        | Bit 2   | 0                 |
|          |       | Enables and disables incrementing of TCNTV count on the                                                   |         |                   |
|          |       | edge input selected by TVEG1 and TVEG0.                                                                   |         |                   |
|          |       | In this case TRGE = 0, so counting by TCNTV is not affected                                               |         |                   |
|          |       | by the input to the TRGV pin.                                                                             |         |                   |
|          | ICKS0 | Internal Clock Select 0:                                                                                  | Bit 0   | 1                 |
|          |       | Selects the clock input to TCNTV and condition counted, in                                                |         |                   |
|          |       | combination with the CKS2 to CKS0 bits of TCRV0.                                                          |         |                   |
|          |       | In this case CKS2=0, CKS1=1, CKS0=1 and ICKS0=1, so                                                       |         |                   |
|          |       | counting by TCNTV is of the falling edges of the internal clock                                           |         |                   |
|          |       | ф/128.                                                                                                    |         |                   |

# RENESAS

| Register Name | Function                                                                                                                                                                                                                                          | Address     | Setting                   |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------------|
| PCR1          | Port control register 1:<br>Provides pin-by-pin control of input/output selection for the pins<br>of port 2 that have been set as general purpose I/O pins.<br>When PCR1 = H'00, pins P10 to P12 function as general-<br>purpose input pins.      | H'FFE4      | H'00                      |
| PDR1          | Port data register:<br>General I/O port data register for port 1.                                                                                                                                                                                 | H'FFD4      | H'00                      |
| PCR7          | Port control register 7:<br>Provides pin-by-pin control of input/output selection for the pins<br>of port 7 that have been set as general purpose I/O pins.<br>When PCR7 = H'0F, the pins P70 to P73 function as general-<br>purpose output pins. | H'FFEA<br>5 | H'0F                      |
| PDR7          | Port data register 7:<br>General I/O port data register for port 7.                                                                                                                                                                               | H'FFDA      | H'00<br>(initial setting) |

# 4.4 Description of RAM

Table 4.3 describes the RAM used in this sample task.

#### Table 4.3Description of RAM

| Label Name | Function                                     | Address | Used in   |
|------------|----------------------------------------------|---------|-----------|
| key_data   | Stores input key data. (2 bytes)             | H'FB80  | main      |
| ole_key    | Stores previous key data. (2 bytes)          | H'FB82  | main      |
| i          | Stores loop counter for key scans. (2 bytes) | H'FB84  | input_key |
| j          | Stores loop counter for key scans. (2 bytes) | H'FB86  | input_key |
| key        | Key data for key scans (2 bytes)             | H'FB88  | input_key |



# 5. Flowchart

1. Main Routine (main)





#### 2. Keyboard Input Processing Routine (input\_key)





# 6. Program Listing

INIT.SRC (program list)

```
.export _INIT
.import _main
;
.section P,CODE
_INIT:
mov.w #h'ff80,r7
ldc.b #b'10000000,ccr
jmp @_main
;
.end
```

| =                                                                              | Series -H8/360 | 14- Application note  |                                    | */ |
|--------------------------------------------------------------------------------|----------------|-----------------------|------------------------------------|----|
| /* Application                                                                 |                |                       |                                    | */ |
| /* Outputting mu                                                               | isical notes   |                       |                                    | */ |
| #include <machine< td=""><td>.h&gt;</td><td></td><td></td><td></td></machine<> | .h>            |                       |                                    |    |
| /* Symbol defnit                                                               | ion            |                       |                                    | */ |
| struct BIT {                                                                   |                |                       |                                    |    |
| unsigned char                                                                  | b7:1;          | /* bit 7 */           |                                    |    |
| unsigned char                                                                  | b6:1;          | /* bit 6 */           |                                    |    |
| unsigned char                                                                  | b5:1;          | /* bit 5 */           |                                    |    |
| unsigned char                                                                  | : b4:1;        | /* bit 4 */           |                                    |    |
| unsigned char                                                                  | b3:1;          | /* bit 3 */           |                                    |    |
| unsigned char                                                                  |                | /* bit 2 */           |                                    |    |
| unsigned char                                                                  |                | /* bit 1 */           |                                    |    |
| unsigned char                                                                  | b0:1;          | /* bit 0 */           |                                    |    |
| };                                                                             |                |                       |                                    |    |
| #define PDR1                                                                   | *(volatile u   | nsigned char *)0xFFD4 | /* Port data register 1            | */ |
| #define PCR1                                                                   | *(volatile u   | nsigned char *)0xFFE4 | /* Port control register 1         | */ |
| #define PDR7                                                                   | *(volatile u   | nsigned char *)0xFFDA | /* Port data register 7            | */ |
| #define PCR7                                                                   |                | nsigned char *)0xFFEA | /* Port control register 7         | */ |
|                                                                                | (              | . ,                   |                                    | ,  |
| #define TCRV0                                                                  | *(volatile u   | nsigned char *)0xFFA0 | /* Timer control register VO       | */ |
| #define TCSRV                                                                  | *(volatile u   | nsigned char *)0xFFA1 | /* Timer control/status register V | */ |
| #define TCORA                                                                  | *(volatile u   | nsigned char *)0xFFA2 | /* Time constant register A        | */ |
| #define TCNTV                                                                  | *(volatile u   | nsigned char *)0xFFA4 | /* Timer counter V                 | */ |
| #define TCRV1                                                                  | *(volatile u   | nsigned char *)0xFFA5 | /* Timer control register V1       | */ |
| /* Function def:                                                               | ne             |                       |                                    | */ |
| extern void INIT(                                                              |                |                       | /* Stack pointer set               | */ |
| void main(void);                                                               | ,010,,         |                       | /* main routine                    | */ |
| voiu main(voiu);                                                               |                |                       | , main routine                     | /  |

/\* Input key

int input\_key(void);

\*/



const unsigned char tone\_data[12] = { 239, /\* C (261.63Hz) \*/ 225, /\* C#(277.18Hz) \*/ /\* D (293.66Hz) \*/ 213. 201, /\* D#(311.13Hz) \*/ 190, /\* E (329.63Hz) \*/ 179, /\* F (349.23Hz) \*/ \*/ 169, /\* F#(369.99Hz) \*/ 159. /\* G (392.00Hz) 150, /\* G#(415.30Hz) \*/ 142, \*/ /\* A (440.00Hz) 134, /\* A#(466.16Hz) \*/ /\* B (493.88Hz) \*/ 127 }; /\* RAM define \*/ int key\_data, old\_key; /\* Input key code New & Old \*/ \*/ int i,j; /\* Loop counter int key; /\* Input key code \*/ /\* Vector address \*/ #pragma section V1 /\* Vector section set \*/ void (\*const VEC\_TBL1[])(void) = { /\* H'0000 Reset vector \*/ INIT }; /\* P \*/ #pragma section \*/ /\* Main program void main(void) {  $PCR1 = 0 \times 00;$ /\* Port1 0-2bit input \*/ PCR7 = 0x0f; /\* Port7 0-3bit output \*/ TCRV0 = 0x0b;/\* Set clock(@/128) \*/  $TCRV1 = 0 \times 01;$ /\* Set clock( $\phi$ /128) \*/ key\_data = old\_key = -1; /\* Initialize key data \*/ while(1){ key\_data = input\_key(); /\* Input key \*/ if ( key\_data != -1) { if ( old\_key != key\_data ) { TCNTV = 0;/\* Clear Timer Counter \*/ TCORA = tone\_data[key\_data]; /\* Set tone data \*/ TCSRV = 0x03;\*/ /\* Start toggle output old key = key data; /\* Save current key data \*/ } } else {  $TCSRV = 0 \times 00;$ /\* Stop toggle output \*/ old\_key = -1; /\* Clear old input data \*/ } }

}



| /************************************** | *************************************** | ***/ |
|-----------------------------------------|-----------------------------------------|------|
| /* input key data                       |                                         | */   |
| /************************************** | *******                                 | ***/ |
| int input_key(void)                     |                                         |      |
| {                                       |                                         |      |
| key = 0;                                | /* Set start key code                   | */   |
| for ( j=0x01; j<=0x08; j<<=1 ) {        |                                         |      |
| PDR7 = j;                               | /* Output level to line                 | */   |
| for ( i=0x01; i<=0x04; i<<=1 ) {        |                                         |      |
| if ( PDR1 & i ) {                       | /* Read level from line                 | */   |
| return key;                             |                                         |      |
| }                                       |                                         |      |
| key++;                                  |                                         |      |
| }                                       |                                         |      |
| }                                       |                                         |      |
| return -1;                              |                                         |      |

}



# **Revision Record**

|      | Date      | Description |                      |  |
|------|-----------|-------------|----------------------|--|
| Rev. |           | Page        | Summary              |  |
| 1.00 | Sep.29.03 | _           | First edition issued |  |
|      |           |             |                      |  |
|      |           |             |                      |  |
|      |           |             |                      |  |
|      |           |             |                      |  |
|      |           |             |                      |  |



#### Keep safety first in your circuit designs!

1. Renesas Technology Corporation puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage.

Remember to give due consideration to safety when making your circuit designs, with appropriate measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of nonflammable material or (iii) prevention against any malfunction or mishap.

#### Notes regarding these materials

- 1. These materials are intended as a reference to assist our customers in the selection of the Renesas Technology Corporation product best suited to the customer's application; they do not convey any license under any intellectual property rights, or any other rights, belonging to Renesas Technology Corporation or a third party.
- 2. Renesas Technology Corporation assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts, programs, algorithms, or circuit application examples contained in these materials.
- 3. All information contained in these materials, including product data, diagrams, charts, programs and algorithms represents information on products at the time of publication of these materials, and are subject to change by Renesas Technology Corporation without notice due to product improvements or other reasons. It is therefore recommended that customers contact Renesas Technology Corporation product distributor for the latest product information before purchasing a product listed herein.

The information described here may contain technical inaccuracies or typographical errors. Renesas Technology Corporation assumes no responsibility for any damage, liability, or other loss rising from these inaccuracies or errors.

Please also pay attention to information published by Renesas Technology Corporation by various means, including the Renesas Technology Corporation Semiconductor home page (http://www.renesas.com).

- 4. When using any or all of the information contained in these materials, including product data, diagrams, charts, programs, and algorithms, please be sure to evaluate all information as a total system before making a final decision on the applicability of the information and products. Renesas Technology Corporation assumes no responsibility for any damage, liability or other loss resulting from the information contained herein.
- 5. Renesas Technology Corporation semiconductors are not designed or manufactured for use in a device or system that is used under circumstances in which human life is potentially at stake. Please contact Renesas Technology Corporation or an authorized Renesas Technology Corporation product distributor when considering the use of a product contained herein for any specific purposes, such as apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea repeater use.
- 6. The prior written approval of Renesas Technology Corporation is necessary to reprint or reproduce in whole or in part these materials.
- 7. If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the approved destination.

Any diversion or reexport contrary to the export control laws and regulations of Japan and/or the country of destination is prohibited.

8. Please contact Renesas Technology Corporation for further details on these materials or the products contained therein.