### 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.

### H8S/2400 Series

### Sine Wave Output Using 14-Bit PWM Timer

#### Introduction

This application note presents an example of using the 14-bit pulse width modulation (PWM) timer (PWMX) function to produce sine wave output.

The PWMX can be used as a 14-bit D/A converter by connecting a low-pass filter to an external pin of the device.

### **Target Devices**

• H8S/2472, H8S/2463, H8S/2462 Group

#### Preface

This program can be used with other H8S Family MCUs that have the same internal I/O registers as the devices on which operation has been confirmed. Check the latest version of the manual for any additions and modifications to functions.

Careful evaluation is recommended before using this application note.

#### Contents

| 1. | Specifications        | . 2 |
|----|-----------------------|-----|
| 2. | Applicable Conditions | . 3 |
| 3. | Functions Used        | . 4 |
| 4. | Operation             | . 7 |
| 5. | Functions             | . 9 |
| 6. | Reference Documents   | 19  |

#### 1. Specifications

The specifications of this application note cover using the compare match interrupt of the 16-bit free-running timer (FRT) to convert the PWMX duty value, and outputting a 1 Hz sine wave by connecting a low-pass filter to the external pin of the PWMX. The example presented in this application note covers PWMX operation before the connection with the low-pass filter.

The detailed specifications for the operations described in this application note are listed below. Figure 1 shows an overview of the operations described in this application note.

- The PWMX duty value is changed by using the FRT compare match interrupt.
- FRT compare matches are set to be generated with a period identical to one PWMX conversion cycle.
- The number of times the PWMX duty value changes per sine wave period is equal to the number of PWMX conversion cycles in one sine wave period.
- Data stored in the on-chip ROM is used as the basis for changing the PWMX duty value.
- The number of pulses (base cycles) generated during one PWMX conversion cycle is set at 64.
- The PWMX resolution (T) is set at one system clock cycle (tcyc).
- The PWMX output phase is set to inverted output.
- Pin PWX0 is used as the PWM output pin.



Figure 1 Operation Overview



#### **Applicable Conditions** 2.

#### Table 1 Applicable Conditions

| Item                                  | Description                                              |
|---------------------------------------|----------------------------------------------------------|
| Operating frequency                   | Input clock: 8.0 MHz                                     |
|                                       | System clock (                                           |
| Operating voltage                     | 3.3V                                                     |
| Operating mode                        | Mode 2 (MD2 = 1, MD1 = 1)                                |
| Evaluation board                      | Renesas Technology                                       |
|                                       | R0K402472D000BR                                          |
| Integrated development<br>environment | High-performance Embedded Workshop (HEW) Ver.4.04.01.001 |
| C/C++ compiler                        | Renesas Technology                                       |
|                                       | H8S,H8/300 C/C++ Compiler (V.6.02.00)                    |
| Compile options                       | -cpu=2600A:24, -optimize = 1                             |
| Optimizing linkage editor             | Renesas Technology                                       |
|                                       | Optimizing Linkage Editor (V9.03.00)                     |
| Linker options                        | start = PResetPRG,PIntPRG/0400,                          |
|                                       | P,C,C\$DSEC,C\$BSEC,D/0800,                              |
|                                       | B,R/0FF0800,                                             |
|                                       | S/0FFEE00                                                |
| Note: * The PLL multiplie             | er circuit multiplies the externally input clock by 4.   |

The PLL multiplier circuit multiplies the externally input clock by 4. Note:

#### H8S/2400 Series Sine Wave Output Using 14-Bit PWM Timer

#### 3. Functions Used

A PWM waveform like the one shown in figure 2 is output from the PWX pin. The value of DA13 to DA0 in the PWMX (D/A) control register (DADR) corresponds to the total 0-level width (TL) of the pulses output in one conversion cycle (256 pulses when CFS = 0, 64 pulses when CFS = 1). When OS = 0, the waveform is output directly. When OS = 1, the output waveform is inverted. In this case, the value of DA13 to DA0 in DADR corresponds to the total 1-level width (TH) of the output pulses. Figures 3 and 4 show the types of waveform output available.



Figure 2 PWMX (D/A) Operation

The PWM output level remains fixed unless DA13 to DA0 in DADR contain at least a certain minimum value. The correspondence between the value of the OS bit and the output waveform is shown in figures 3 and 4.



Figure 3 Output Waveform (OS = 0, DADR corresponds to  $T_L$ )





Figure 4 Output Waveform (OS = 1, DADR corresponds to  $T_H$ )

#### H8S/2400 Series Sine Wave Output Using 14-Bit PWM Timer

An example of the additional pulses when CFS = 1 (base cycle = resolution (T) × 256) and OS = 1 (inverted PWM output) is described below. When CFS = 1, the upper eight bits (DA13 to DA6) in DADR determine the duty ratio of the base pulse, and the next six bits (DA5 to DA0) determine the locations of the additional pulses as shown in figure 5.

| DA13                           | DA12 | DA11 | DA10 | DA9 | DA8 | DA7     | DA6      | DA5       | DA4    | DA3 | DA2 | DA1 | DA0 | CFS |  |
|--------------------------------|------|------|------|-----|-----|---------|----------|-----------|--------|-----|-----|-----|-----|-----|--|
| Duty cycle of base pulse Locat |      |      |      |     |     | Locatio | on of ad | lditional | pulses | /   | ´ 1 | 1   |     |     |  |

Figure 5 D/A Data Register Configuration when CFS = 1

In this example, DADR = H'0207 (B'0000 0010 0000 0111). Figure 6 shows the output waveform. Since CFS = 1 and the value of the upper eight bits is B'0000 0010, the base pulse has a duty ratio with a high width of  $2/256 \times (T)$ .



Figure 6 Output Waveform when DADR = H'0207 (OS = 1)

However, when CFS = 0 (base cycle = resolution (T) × 64), the duty ratio of the base pulse is determined by the upper six bits and the locations of the additional pulses by the next eight bits, in a manner similar to the above.



#### 4. Operation

The example below illustrate calculating the number of PWMX duty changes in one sine wave period and generating sine wave data.

• Example: Calculating the Number of PWMX Duty Changes in One Sine Wave Period When the sine wave output resolution is equal to one PWMX conversion cycle  $(T \times 2^{14})$ :

1 Hz / (tcyc × 16,384) = 1 Hz / 512  $\mu$ s ≈ 1,953 points

Therefore, the number of PWMX duty changes in one sine wave period is 1,953.

Note that in the interests of efficient utilization of the available ROM capacity, the program presented in this application note uses 977 bytes of sine wave data, approximately half the available capacity, and the PWMX duty value is changed by shifting the sine wave data reference offset back and forth.



Figure 7 Sine Wave Conceptual View

• Example: Generating Sine Wave Data

The sine wave data (14 bits) is set in DA13 to DA0 in PWMX (D/A) data register A (DADRA). Note that the PWM output level is fixed when bits DA13 to DA0 in DADRA are set to a value outside the range H'0040 to H'3FFF. Therefore, in this example setting values for bits DA13 to DA0 (sine wave data) are generates within the range H'003F to H'3FFF (H'3FC0).

 $\sin \theta \times (H'3FC0 / 2) + (H'3FC0 / 2) + H'3F = \text{sine wave data}$ 



Figure 8 shows the operation described in this application note.



Figure 8 Operation



#### 5. Functions

#### 5.1 Symbolic Constants

#### Table 2 List of Symbolic Constants

| Constant Name    | Set Value | Description                                  | Used by<br>Functions |
|------------------|-----------|----------------------------------------------|----------------------|
| MAX_PWM_DATA_CNT | 977       | Number of data bytes in sine wave data table | INT_OCIA_FRT         |

#### 5.2 ROM Variables

#### Table 3 List of ROM Variables

| Туре         | Variable Name      | Set Value        | Description          | Used by<br>Functions |
|--------------|--------------------|------------------|----------------------|----------------------|
| const        | pwm_table          | 0x00FF, 0x00FF,, | Sine wave data table | INT_OCIA_FRT         |
| unsigned int | [MAX_PWM_DATA_CNT] | , 0xFFFB, 0xFFFB |                      |                      |

#### 5.3 RAM Variables

#### Table 4List of RAM Variables

| Туре         | Variable Name | Set Value | Description                                       | Used by<br>Functions |
|--------------|---------------|-----------|---------------------------------------------------|----------------------|
| unsigned int | pwm_count     | 0x00      | Sine wave data table reference count value        | init<br>INT_OCIA_FRT |
| signed int   | pwm_add_value | 0x01      | Sine wave data table reference count change value | init<br>INT_OCIA_FRT |

#### 5.4 List of Functions

#### Table 5 List of Functions

| Function Name | Description                                                                                                                                                                |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PowerON_Reset | <ul> <li>Initial settings function<br/>Initializes status pointer (SP), sets interrupt mask bits, sets uninitialized/initialized<br/>data, calls main function.</li> </ul> |
| main          | <ul> <li>Main function<br/>Calls init function and starts PWMX output.</li> </ul>                                                                                          |
| init          | <ul> <li>I/O register initialization function<br/>Initializes registers.</li> </ul>                                                                                        |
| INT_OCIA_FRT  | <ul> <li>FRT interrupt handling function<br/>Changes the PWMX output pulse duty.</li> </ul>                                                                                |

#### 5.5 Functions

#### 5.5.1 PowerON\_Reset Function

(1) Functional Overview

The PowerON\_Reset function initializes the status pointer (SP) and uses embedded functions and standard library functions to set interrupt mask bits and set uninitialized/initialized data. Then it calls the main function.

- (2) Arguments
- None
- (3) Returned values None
- (4) Description of internal I/O registers used None
- (5) Flowchart



Figure 9 Power-On Reset Flowchart (PowerON\_Reset)



#### 5.5.2 main Function

#### (1) Functional Overview

The main function calls the init function to perform register initialization and start PWMX pulse output.

(2) Arguments

None

- (3) Returned values None
- (4) Description of internal I/O registers used None
- (5) Flowchart



Figure 10 Main Flowchart (main)



#### 5.5.3 init Function

#### (1) Functional Overview

The init function initializes registers and starts PWM pulse output.

(2) Arguments

None

- (3) Returned values None
- (4) Description of internal I/O registers used

The internal I/O registers used by this function are shown below. Note that the setting values shown are those used in this application note and differ from the initial values.

• Mode Control Register (MDCR) - Number of bits: 8, Address: H'FFFFC5

|     |          | Set   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|----------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2   | MDS2     | _     | R   | Mode Select 2 and 1                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1   | MDS1     | _     | R   | These bits indicate the input levels at mode pins ( $\overline{\text{MD2}}$ and $\overline{\text{MD1}}$ ) (the current operating mode). Bits MDS2 and MDS1 correspond to $\overline{\text{MD2}}$ and MD1, respectively. MDS2 and MDS1 are read-only bits and they cannot be written to. The mode pin ( $\overline{\text{MD2}}$ and MD1) input levels are latched into these bits when MDCR is read. These latches are canceled by a reset. |

• Standby Control Register (SBYCR) - Number of bits: 8, Address: H'FFFF84

|     |          | Set   |     |                                                                 |
|-----|----------|-------|-----|-----------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                    |
| 2   | SCK2     | 0     | R/W | System Clock Select                                             |
| 1   | SCK1     | 0     | R/W | Select a clock for the bus master in high-speed mode or medium- |
| 0   | SCK0     | 0     | R/W | speed mode.                                                     |
|     |          |       |     | 000: High-speed mode                                            |

- MSTPCR is used to put individual on-chip peripheral modules into module stop mode. Setting a bit to 1 makes the corresponding module enter the module stop mode.
- Module Stop Control Register A (MSTPCRA) Number of bits: 8, Address: H'FFFE43

|     |          | Set   |     |                           |
|-----|----------|-------|-----|---------------------------|
| Bit | Bit Name | Value | R/W | Descriptions              |
| 1   | MSTPA1   | 0     | R/W | 14-bit PWM timer (PWMX_0) |

• Module Stop Control Register H (MSTPCRH) - Number of bits: 8, Address: H'FFFF86

|     |          | Set   |     |                                 |
|-----|----------|-------|-----|---------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                    |
| 5   | MSTP13   | 0     | R/W | 16-bit free-running timer (FRT) |
| 3   | MSTP11   | 0     | R/W | 14-bit PWM timer (PWMX)         |

REJ06B0817-0100/Rev.1.00



• Timer Interrupt Enable Register (TIER) - Number of bits: 8, Address: H'FFFF90

|     |          | Set   |     |                                                               |
|-----|----------|-------|-----|---------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                  |
| 3   | OCIAE    | 1     | R/W | Output Compare Interrupt A Enable                             |
|     |          |       |     | Selects whether to enable output compare interrupt A request  |
|     |          |       |     | (OCIA) when output compare flag A (OCFA) in TCSR is set to 1. |
|     |          |       |     | 1: OCIA requested by OCFA is enabled                          |

#### • Timer Control/Status Register (TCSR) - Number of bits: 8, Address: H'FFFF91

| Bit | Bit Name | Set<br>Value | R/W | Descriptions                                                                                      |
|-----|----------|--------------|-----|---------------------------------------------------------------------------------------------------|
| 0   | CCLRA    | 1            | R/W | Counter Clear A                                                                                   |
|     |          |              |     | Selects whether the FRC is to be cleared on compare-match A (when the FRC and OCRA values match). |
|     |          |              |     | 1: FRC is cleared on compare-match A                                                              |

#### • Timer Control Register (TCR) - Number of bits: 8, Address: H'FFFF96

|     |          | Set   |     |                               |
|-----|----------|-------|-----|-------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                  |
| 1   | CKS1     | 0     | R/W | Select clock source for FRC.  |
| 0   | CKS0     | 0     | R/W | 00: φ/2 internal clock source |

• Timer Output Compare Control Register (TOCR) - Number of bits: 8, Address: H'FFFF97

| Bit | Bit Name | Set<br>Value | R/W | Descriptions                                                                                                                                                                                                                        |
|-----|----------|--------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | OCRAMS   | 0            | R/W | Output Compare A Mode Select<br>Specifies whether OCRA is used in the normal operating mode or<br>in the operating mode using OCRAR and OCRAF.<br>0: The normal operating mode is specified for OCRA                                |
| 5   | ICRS     | 0            | R/W | Input Capture Register Select<br>Controls the access to OCRAR and OCRAF.<br>0: Access is disabled                                                                                                                                   |
| 4   | OCRS     | 0            | R/W | Output Compare Register Select<br>OCRA and OCRB share the same address. When this address is<br>accessed, the OCRS bit selects which register is accessed. The<br>operation of OCRA or OCRB is not affected.<br>0: OCRA is selected |



#### H8S/2400 Series Sine Wave Output Using 14-Bit PWM Timer

• Output Compare Register A (OCRA) - Number of bits: 16, Address: H'FFFF92

Function: Each OCR register is a 16-bit readable/writable register. The FRT has two OCR registers, and their contents are continually compared with the FRC value. When the values match (compare match), the OCFA or OCFB flag in TCSR is set to 1. The OCR registers cannot be accessed in 8-bit units. They should always be accessed in 16-bit units.

Setting value: H'2000

• Port Control Register 0 (PTCNT0) - Number of bits: 8, Address: H'FFFEFE

|     |          | Set   |     |                                                                                                      |
|-----|----------|-------|-----|------------------------------------------------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                                                         |
| 3   | PWMXS    | 0     | R/W | Selects pins for 14-bit PWM timer outputs.<br>0: P60/PWX0, P61/PWX1, P62/PWX2, P63/PWX3 are selected |

• PWMX (D/A) Data Register A (DADRA) - Number of bits: 16, Address: H'FFFFA0

|         |          | Set   |     |                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|----------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit     | Bit Name | Value | R/W | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15 to 2 | DA13 to  | All 0 | R/W | D/A Data 13 to 0                                                                                                                                                                                                                                                                                                                                                                                                          |
|         | DA0      |       |     | These bits set a digital value to be converted to an analog value.                                                                                                                                                                                                                                                                                                                                                        |
|         |          |       |     | In each base cycle, the DACNT value is continually compared with<br>the DADR value to determine the duty cycle of the output<br>waveform, and to decide whether to output a fine-adjustment pulse<br>equal in width to the resolution. To enable this operation, this<br>register must be set within a range that depends on the CFS bit. If<br>the DADR value is outside this range, the PWM output is held<br>constant. |
|         |          |       |     | A channel can be operated with 12-bit precision by fixing DA0 and                                                                                                                                                                                                                                                                                                                                                         |
|         |          |       |     | DA1 to 0. The two data bits are not compared with UC12 and                                                                                                                                                                                                                                                                                                                                                                |
|         |          |       |     | UC13 of DACNT.                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1       | CFS      | 1     | R/W | Carrier Frequency Select                                                                                                                                                                                                                                                                                                                                                                                                  |
|         |          |       |     | 1: Base cycle = resolution (T) $\times$ 256                                                                                                                                                                                                                                                                                                                                                                               |
|         |          |       |     | The range of DA13 to DA0: H'0040 to H'3FFF                                                                                                                                                                                                                                                                                                                                                                                |

• PWMX (D/A) Data Register B (DADRB) - Number of bits: 16, Address: H'FFFFA6

|     |          | Set   |     |                                                                                                                                                                                                                                                                                                            |
|-----|----------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                                                                                                                                                                                                                                                               |
| 0   | REGS     | 0/1   | R/W | Register Select<br>DADRA and DACR, and DADRB and DACNT, are located at the<br>same addresses. The REGS bit specifies which registers can be<br>accessed. When changing the register to be accessed, set this bit<br>in advance.<br>0: DADRA and DADRB can be accessed<br>1: DACR and DACNT can be accessed |

• PWMX (D/A) Counter (DACNT) - Number of bits: 16, Address: H'FFFFA6

### H8S/2400 Series Sine Wave Output Using 14-Bit PWM Timer

|         |                | Set   |     |                                                                                                                                                                                                                                                                                                            |
|---------|----------------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit     | Bit Name       | Value | R/W | Descriptions                                                                                                                                                                                                                                                                                               |
| 15 to 8 | UC7 to<br>UC0  | all 0 | R/W | Lower Up-Counter                                                                                                                                                                                                                                                                                           |
| 7 to 2  | UC8 to<br>UC13 | all 0 | R/W | Upper Up-Counter                                                                                                                                                                                                                                                                                           |
| 0       | REGS           | 0/1   | R/W | Register Select<br>DADRA and DACR, and DADRB and DACNT, are located at the<br>same addresses. The REGS bit specifies which registers can be<br>accessed. When changing the register to be accessed, set this bit<br>in advance.<br>0: DADRA and DADRB can be accessed<br>1: DACR and DACNT can be accessed |

• PWMX (D/A) Control Register (DACR) - Number of bits: 8, Address: H'FFFFA0

|     |          | Set   |     |                                                                       |
|-----|----------|-------|-----|-----------------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                          |
| 6   | PWME     | 0     | R/W | PWMX Enable                                                           |
|     |          |       |     | Starts or stops the PWM D/A counter (DACNT).                          |
|     |          |       |     | 0: DACNT operates as a 14-bit up-counter                              |
| 2   | OEA      | 1     | R/W | Output Enable A                                                       |
|     |          |       |     | Enables or disables output on PWMX (D/A) channel A.                   |
|     |          |       |     | 1: PWMX (D/A) channel A output (at the PWX0, PWX2 pins) is            |
|     |          |       |     | enabled                                                               |
| 1   | OS       | 1     | R/W | Output Select                                                         |
|     |          |       |     | Selects the phase of the PWMX (D/A) output.                           |
|     |          |       |     | 1: Inverted PWMX (D/A) output                                         |
| 0   | CKS      | 0     | R/W | Clock Select                                                          |
|     |          |       |     | Selects the PWMX (D/A) resolution. Eight kinds of resolution can      |
|     |          |       |     | be selected.                                                          |
|     |          |       |     | 0: Operates at resolution (T) = system clock cycle time ( $t_{cyc}$ ) |



(5) Flowchart

| init                                       |                                                                                                                                                                                                |
|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dummy = SYSTEM.MDCR.BYTE                   | Read MDCR.                                                                                                                                                                                     |
| SYSTEM.SBYCR.BYTE = 0x00                   | Specify high-speed mode.                                                                                                                                                                       |
| pwm_count = 0                              | } Initialize data table reference count.                                                                                                                                                       |
| pwm_add_value = 1                          | } Initialize data table reference count change value.                                                                                                                                          |
| SYSTEM.MSTPCRA = 0x00                      | Clear 14-bit PWM timer (PWMX_0) module stop bit.                                                                                                                                               |
| SYSTEM.MSTPCRH.BIT.MSTP11 = 0              | Clear 14-bit PWM timer (PWMX) module stop bit.                                                                                                                                                 |
| SYSTEM.MSTPCRH.BIT.MSTP13 = 0              | Clear 16-bit free-running timer (FRT) module stop bit.                                                                                                                                         |
| FRT.TIER.BYTE = 0x08                       | Enable interrupt requests triggered by OCFA flag.                                                                                                                                              |
| FRT.TCSR.BYTE = 0x01                       | Clear FRC at compare match A.                                                                                                                                                                  |
| FRT.TCR.BYTE = 0x00                        | Specify internal clock PHI/2 as count source.                                                                                                                                                  |
| FRT.TOCR.BYTE = 0x00                       | Set OCRA to normal operation mode.                                                                                                                                                             |
| FRT.OCRA = 0x2000                          | Set to generate interrupts at approx.<br>1,953 Hz to match single PWMX conversion cycles.                                                                                                      |
| PORT.PTCNT0.BIT.PWMS = 0                   | Select P60/PWX0 as 14 -bit PWM output pin.                                                                                                                                                     |
| PWMX0.DADRB.BIT.REGS = 0*                  | Enable access to DADRA and DADRB.                                                                                                                                                              |
| PWMX0.DADRA.WORD = 0x0003*                 | Set initial duty setting to 0%.<br>Set base cycle = resolution (T) $\times$ 256.                                                                                                               |
| PWMX0.DADRB.BIT.REGS = 1*                  | Enable access to DACR and DACNT.                                                                                                                                                               |
| PWMX0.DADRB.WORD = 0x0003*                 | } Initialize DACNT counter to 0.                                                                                                                                                               |
| PWMX0.DADRA.WORD = 0x3600*                 | Make DACR settings.<br>Set DACNT as 14-bit up-counter.<br>Enable PWMX (D/A) output (PWX0 output pin).<br>Set PWMX (D/A) to inverted output.<br>Set resolution (T) = system clock cycle (tcyc). |
| PWMX0.DADRB.BIT.REGS = 0*                  | Enable access to DADRA and DADRB.                                                                                                                                                              |
| end                                        |                                                                                                                                                                                                |
| Note: * DADRA and DACR are assigned to the | e same address, as are DADRB and DACNT.                                                                                                                                                        |
| L                                          |                                                                                                                                                                                                |





#### 5.5.4 INT\_OCIA\_FRT Function

#### (1) Functional Overview

The INT\_OCIA\_FRT function changes the PWMX output pulse duty.

(2) Arguments

None

- (3) Returned values None
- (4) Description of internal I/O registers used

The internal I/O registers used by this function are shown below. Note that the setting values shown are those used in this application note and differ from the initial values.

• Timer Control/Status Register (TCSR) - Number of bits: 8, Address: H'FFFF91

| Bit Name | Value | R/W    | Descriptions                                         |
|----------|-------|--------|------------------------------------------------------|
| OCFA     | 0     | R/(W)* | Output Compare Flag A                                |
|          |       |        | Indicates that the FRC value matches the OCRA value. |
|          |       |        | Only 0 can be written to clear the flag.             |
|          |       |        | [Setting condition]                                  |
|          |       |        | When FRC = OCRA                                      |
|          |       |        | [Clearing condition]                                 |
|          |       |        | Read OCFA when OCFA = 1, then write 0 to OCFA        |
|          |       |        |                                                      |

Note: \* Only 0 can be written to clear the flag.

• PWMX (D/A) Data Register A (DADRA) - Number of bits: 16, Address: H'FFFFA0

|         |          | Set   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|----------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit     | Bit Name | Value | R/W | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15 to 2 | DA13 to  | All 1 | R/W | D/A Data 13 to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         | DA0      |       |     | These bits set a digital value to be converted to an analog value.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         |          |       |     | In each base cycle, the DACNT value is continually compared with<br>the DADR value to determine the duty cycle of the output<br>waveform, and to decide whether to output a fine-adjustment pulse<br>equal in width to the resolution. To enable this operation, this<br>register must be set within a range that depends on the CFS bit. If<br>the DADR value is outside this range, the PWM output is held<br>constant.<br>A channel can be operated with 12-bit precision by fixing DA0 and |
|         |          |       |     | DA1 to 0. The two data bits are not compared with UC12 and UC13 of DACNT.                                                                                                                                                                                                                                                                                                                                                                                                                      |



(5) Flowchart



Figure 12 FRT OCIA Interrupt Flowchart (INT\_OCIA\_FRT)



#### 6. Reference Documents

- Hardware Manual H8S/2472, H8S/2463, H8S/2462 Group Hardware Manual (The latest version can be downloaded from the Renesas Technology Web site.)
- Development Environment Manual H8S/300, H8/300 Series C/C++ Compiler Package User's Manual (The latest version can be downloaded from the Renesas Technology Web site.)
- Technical News/Technical Updates (The latest information can be downloaded from the Renesas Technology Web site.)



#### Website and Support

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

Inquiries <u>http://www.renesas.com/inquiry</u> <u>csc@renesas.com</u>

#### **Revision Record**

|      |           | Descripti | ion                  |
|------|-----------|-----------|----------------------|
| Rev. | Date      | Page      | Summary              |
| 1.00 | Jan.26.09 | —         | First edition issued |

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



#### H8S/2400 Series Sine Wave Output Using 14-Bit PWM Timer

#### Notes regarding these materials

- This document is provided for reference purposes only so that Renesas customers may select the appropriate Renesas products for their use. Renesas neither makes warranties or representations with respect to the accuracy or completeness of the information contained in this document nor grants any license to any intellectual property rights or any other rights of Renesas or any third party with respect to the information in this document.
- 2. Renesas shall have no liability for damages or infringement of any intellectual property or other rights arising out of the use of any information in this document, including, but not limited to, product data, diagrams, charts, programs, algorithms, and application circuit examples.
- 3. You should not use the products or the technology described in this document for the purpose of military applications such as the development of weapons of mass destruction or for the purpose of any other military use. When exporting the products or technology described herein, you should follow the applicable export control laws and regulations, and procedures required by such laws and regulations.
- 4. All information included in this document such as product data, diagrams, charts, programs, algorithms, and application circuit examples, 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 products listed in this document, please confirm the latest product information with a Renesas sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas such as that disclosed through our website. (http://www.renesas.com )
- Renesas has used reasonable care in compiling the information included in this document, but Renesas assumes no liability whatsoever for any damages incurred as a result of errors or omissions in the information included in this document.
- 6. When using or otherwise relying on the information in this document, you should evaluate the information in light of the total system before deciding about the applicability of such information to the intended application. Renesas makes no representations, warranties or guaranties regarding the suitability of its products for any particular application and specifically disclaims any liability arising out of the application and use of the information in this document or Renesas products.
- 7. With the exception of products specified by Renesas as suitable for automobile applications, Renesas products are not designed, manufactured or tested for applications or otherwise in systems the failure or malfunction of which may cause a direct threat to human life or create a risk of human injury or which require especially high quality and reliability such as safety systems, or equipment or systems for transportation and traffic, healthcare, combustion control, aerospace and aeronautics, nuclear power, or undersea communication transmission. If you are considering the use of our products for such purposes, please contact a Renesas sales office beforehand. Renesas shall have no liability for damages arising out of the uses set forth above.
- 8. Notwithstanding the preceding paragraph, you should not use Renesas products for the purposes listed below: (1) artificial life support devices or systems
  - (2) surgical implantations
  - (3) healthcare intervention (e.g., excision, administration of medication, etc.)
  - (4) any other purposes that pose a direct threat to human life

Renesas shall have no liability for damages arising out of the uses set forth in the above and purchasers who elect to use Renesas products in any of the foregoing applications shall indemnify and hold harmless Renesas Technology Corp., its affiliated companies and their officers, directors, and employees against any and all damages arising out of such applications.

- 9. You should use the products described herein within the range specified by Renesas, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas shall have no liability for malfunctions or damages arising out of the use of Renesas products beyond such specified ranges.
- 10. Although Renesas endeavors to improve the quality and reliability of its products, IC products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Please be sure to implement safety measures to guard against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas 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 applicable measures. Among others, since the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you.
- 11. In case Renesas products listed in this document are detached from the products to which the Renesas products are attached or affixed, the risk of accident such as swallowing by infants and small children is very high. You should implement safety measures so that Renesas products may not be easily detached from your products. Renesas shall have no liability for damages arising out of such detachment.
- 12. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written approval from Renesas.
- 13. Please contact a Renesas sales office if you have any questions regarding the information contained in this document, Renesas semiconductor products, or if you have any other inquiries.

#### © 2009. Renesas Technology Corp., All rights reserved.