## 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: <a href="http://www.renesas.com">http://www.renesas.com</a> April 1<sup>st</sup>, 2010 Renesas Electronics Corporation Issued by: Renesas Electronics Corporation (<a href="http://www.renesas.com">http://www.renesas.com</a>) 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 product for any application for which it is not intended without the prior written consent of Renesas Electronics. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an application categorized as "Specific" or for which the product is not intended where you have failed to obtain the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product is "Standard" unless otherwise expressly specified in a Renesas Electronics data sheets or data books, etc. - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots. - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anti-crime systems; safety equipment; and medical equipment not specifically designed for life support. - "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 majority-owned subsidiaries. - (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics. # SH7046 Group ## PWM 7-Phase Output ## 1. Specifications Seven-phase PWM output allowing the pulse high width and duty to be varied is performed as shown in figure 1. When operating with on-chip peripheral clock $P\phi = 20.0$ MHz, the output PWM period can be set arbitrarily in the range 100 ns to 3.27 ms. Figure 1 Example of PWM Output #### 2. Functions Used In this sample task, 7-phase PWM output is performed by synchronous operation of MTU ch0 to ch2. Figure 2 shows a block diagram of the MTU as used in this sample task. This sample task uses the following MTU functions. - A function that outputs pulses automatically by hardware without software intervention (output compare) - A function that clears a counter when a compare match occurs (counter clearing) - A function that reverses output each time a compare match occurs (toggle output) Figure 2 Block Diagram of Synchronous Clearing Table 1 shows the function assignments used in this task. PWM pulses are output by assigning MTU functions as shown in the table. ## **Table 1 MTU Function Assignments** | Pin or Register Name | Function | Function Assignment | |----------------------|-----------|----------------------------------------------------------------------| | TIOC0B | Pins | PWM pulse output pins | | TIOC0C | | | | TIOC0D | | | | TIOC1A | | | | TIOC1B | | | | TIOC2A | | | | TIOC2B | | | | TSYR | Register | Ch0/1/2 synchronous operation | | TCR_0/1/2 | Register | Selection of ch0/1/2 timer counter clearing sources and input clocks | | TGRA_0 | Register | PWM period setting | | TGRB_0 | Registers | Duty value setting | | TGRC_0 | | | | TGRD_0 | | | | TGRA_1 | | | | TGRB_1 | | | | TGRA_2 | | | | TGRB_2 | | | | TMDR_0/1/2 | Register | Operation of ch0/1/2 in PWM Mode 2 | ## 3. Operation Figure 3 illustrates the principles of operation of this sample task. Seven-phase PWM output is performed from the ch0/1/2 PWM output pins (TIOC0B/C/D, TIOC1A/B, TIOC2A/B) by SH7046 hardware and software processing as shown in the figure. Figure 3 Principles of Operation of PWM Output (7-Phase) Using Sawtooth Waveform Generation ## 4. Software ## (1) Modules | Module Name | Label | Function Assignment | |--------------|-------|----------------------------| | Main routine | pwm_2 | PFC and PWM output setting | ## (2) Arguments | Label or<br>Register<br>Name | Function Assignment | Data Length | Module | Input/<br>Output | |------------------------------|--------------------------------------------------------|-------------|--------------|------------------| | pul_cyc0a | Used to set timer value for pulse period | 1 word | Main routine | Input | | | Pulse period is calculated using following equation: | | | | | | Pulse period (ns) = timer value $\times \phi$ period | | | | | | (50.0 ns at 20.0 MHz | | | | | | operation) | | | | | pul_duty0b | Used to set TIOC pin output waveform transition timing | | | | | pul_duty0c | | | | | | pul_duty0d | | | | | | pul_duty1a | | | | | | pul_duty1b | | | | | | pul_duty2a | | | | | | pul_duty2b | | | | | ## (3) Internal Registers Used | P_STBY.MSTCR2 Module standby mode clearing H'FFF861E H'd2fd P_PORTE.PEIORL Used to set multiplex pins as timer output pins H'FFF83B4 H'00fe P_PORTE.PECRL2 TIOC0B/C/D, TIOC1A/B, TIOC2A/B H'FFF83BA H'5554 P_MTU34.TSYR Synchronous operation set for timer counters 0/1/2 H'FFF8241 H'07 P_MTU0.TCR_0 Used to select TGRA_0 compare match set as H'FFF8260 H'20 P_MTU1.TCR_1 timer counter clearing source, and P\(\phi/1\) as input H'FFF8280 H'60 P_MTU2.TCR_2 clock H'FFF82A0 H'60 P_MTU0.TGRA_0 PWM period setting H'FFF8268 pul_cyc0 P_MTU0.TGRB_0 Used to set timer counter value causing high H'FFF826A pul_duty0b output from TIOC0B P_MTU0.TGRC_0 Used to set timer counter value causing high H'FFF826C pul_duty0c output from TIOC0C P_MTU0.TGRD_0 Used to set timer counter value causing high H'FFF826E pul_duty0d output from TIOC0D P_MTU0.TGRD_1 Used to set timer counter value causing high H'FFF826B pul_duty0d output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high H'FFF828A pul_duty1a output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high H'FFF828A pul_duty1b output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high H'FFF82AA pul_duty2a output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFF82AA pul_duty2a output from TIOC2A | Register Name | Function Assignment | Address | Set Value | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------|------------|------------| | P_PORTE.PECRL2 TIOCOB/C/D, TIOC1A/B, TIOC2A/B H'FFFF83BA H'5554 P_MTU34.TSYR Synchronous operation set for timer counters 0/1/2 H'FFFF8241 H'07 P_MTU0.TCR_0 Used to select TGRA_0 compare match set as H'FFFF8260 H'20 P_MTU1.TCR_1 timer counter clearing source, and P\(\phi\)/1 as input H'FFFF8280 H'60 P_MTU2.TCR_2 clock H'FFFF82A0 H'60 P_MTU0.TGRA_0 PWM period setting H'FFFF8268 pul_cyc0 P_MTU0.TGRB_0 Used to set timer counter value causing high H'FFFF826A pul_duty0b output from TIOC0B P_MTU0.TGRC_0 Used to set timer counter value causing high H'FFFF826C pul_duty0c output from TIOC0C P_MTU0.TGRD_0 Used to set timer counter value causing high H'FFFF826E pul_duty0d output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high H'FFFF828A pul_duty1a output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high H'FFFF828A pul_duty1b output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high H'FFFF82AA pul_duty2a output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFFF82AA pul_duty2b | P_STBY.MSTCR2 | Module standby mode clearing | H'FFFF861E | H'd2fd | | P_MTU3.TSYR Synchronous operation set for timer counters 0/1/2 H'FFFF8241 H'07 P_MTU0.TCR_0 Used to select TGRA_0 compare match set as H'FFFF8260 H'20 P_MTU1.TCR_1 timer counter clearing source, and P\(\phi/1\) as input H'FFFF8280 H'60 P_MTU2.TCR_2 clock H'FFFF82A0 H'60 P_MTU0.TGRA_0 PWM period setting H'FFFF8268 pul_cyc0 P_MTU0.TGRB_0 Used to set timer counter value causing high H'FFFF826A pul_duty0b output from TIOC0B P_MTU0.TGRC_0 Used to set timer counter value causing high H'FFFF826C pul_duty0c output from TIOC0C P_MTU0.TGRD_0 Used to set timer counter value causing high H'FFFF826E pul_duty0d output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high H'FFFF828A pul_duty1a output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high H'FFFF828A pul_duty1b output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high H'FFFF828A pul_duty2a output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFFF82AA pul_duty2b | _ | | | | | P_MTU0.TCR_0 Used to select TGRA_0 compare match set as H'FFF8260 H'20 P_MTU1.TCR_1 timer counter clearing source, and Pφ/1 as input H'FFF8280 H'60 P_MTU2.TCR_2 clock H'FFF82A0 H'60 P_MTU0.TGRA_0 PWM period setting H'FFF8268 pul_cyc0 P_MTU0.TGRB_0 Used to set timer counter value causing high h'FFF826A pul_duty0b output from TIOC0B P_MTU0.TGRC_0 Used to set timer counter value causing high H'FFF826C pul_duty0c output from TIOC0C P_MTU0.TGRD_0 Used to set timer counter value causing high H'FFF826E pul_duty0d output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high h'FFF8288 pul_duty1a output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high h'FFF828A pul_duty1b output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high h'FFFF82A8 pul_duty2a output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high h'FFFF82AA pul_duty2b | P_PORTE.PECRL2 | TIOC0B/C/D, TIOC1A/B, TIOC2A/B | H'FFFF83BA | H'5554 | | P_MTU1.TCR_1 timer counter clearing source, and P\(p\)/1 as input H'FFFF8280 H'60 P_MTU2.TCR_2 clock H'FFF82A0 H'60 P_MTU0.TGRA_0 PWM period setting H'FFF8268 pul_cyc0 P_MTU0.TGRB_0 Used to set timer counter value causing high output from TIOCOB P_MTU0.TGRC_0 Used to set timer counter value causing high H'FFF826C pul_duty0c output from TIOCOC P_MTU0.TGRD_0 Used to set timer counter value causing high H'FFF826E pul_duty0d output from TIOCOD P_MTU1.TGRA_1 Used to set timer counter value causing high H'FFF8288 pul_duty1a output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high H'FFF828A pul_duty1b output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high H'FFF82A8 pul_duty2a output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFF82AA pul_duty2b | P_MTU34.TSYR | Synchronous operation set for timer counters 0/1/2 | H'FFFF8241 | H'07 | | P_MTU2.TCR_2 clock H'FFFF82A0 H'60 P_MTU0.TGRA_0 PWM period setting H'FFFF8268 pul_cyc0 P_MTU0.TGRB_0 Used to set timer counter value causing high output from TIOC0B P_MTU0.TGRC_0 Used to set timer counter value causing high output from TIOC0C P_MTU0.TGRD_0 Used to set timer counter value causing high output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFFF82AA pul_duty2a Output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFFF82AA pul_duty2b | | <del>-</del> · | H'FFFF8260 | H'20 | | P_MTU0.TGRA_0 PWM period setting H'FFF8268 pul_cyc0 P_MTU0.TGRB_0 Used to set timer counter value causing high output from TIOC0B P_MTU0.TGRC_0 Used to set timer counter value causing high output from TIOC0C P_MTU0.TGRD_0 Used to set timer counter value causing high output from TIOC0C P_MTU0.TGRD_1 Used to set timer counter value causing high output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFF82AA pul_duty2b | P_MTU1.TCR_1 | timer counter clearing source, and P₀/1 as input | H'FFFF8280 | H'60 | | P_MTU0.TGRB_0 Used to set timer counter value causing high output from TIOC0B P_MTU0.TGRC_0 Used to set timer counter value causing high output from TIOC0C P_MTU0.TGRD_0 Used to set timer counter value causing high output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFFF82AA pul_duty2b | P_MTU2.TCR_2 | clock | H'FFFF82A0 | H'60 | | Output from TIOC0B P_MTU0.TGRC_0 Used to set timer counter value causing high output from TIOC0C P_MTU0.TGRD_0 Used to set timer counter value causing high output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFF82AA pul_duty2b | P_MTU0.TGRA_0 | PWM period setting | H'FFFF8268 | pul_cyc0 | | P_MTU0.TGRC_0 Used to set timer counter value causing high output from TIOC0C P_MTU0.TGRD_0 Used to set timer counter value causing high output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFFF82AA pul_duty2b | P_MTU0.TGRB_0 | Used to set timer counter value causing high | H'FFFF826A | pul_duty0b | | output from TIOC0C P_MTU0.TGRD_0 Used to set timer counter value causing high output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFFF82AA pul_duty2b | | output from TIOC0B | | | | P_MTU0.TGRD_0 Used to set timer counter value causing high output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high h'FFFF82AA pul_duty2a | P_MTU0.TGRC_0 | Used to set timer counter value causing high | H'FFFF826C | pul_duty0c | | output from TIOC0D P_MTU1.TGRA_1 Used to set timer counter value causing high output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFFF82AA pul_duty2b | | output from TIOC0C | | | | P_MTU1.TGRA_1 Used to set timer counter value causing high output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFFF82AA pul_duty2b | P_MTU0.TGRD_0 | Used to set timer counter value causing high | H'FFFF826E | pul_duty0d | | output from TIOC1A P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFF82AA pul_duty2a pul_duty2b | | output from TIOC0D | | | | P_MTU1.TGRB_1 Used to set timer counter value causing high output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFF82AA pul_duty2b | P_MTU1.TGRA_1 | Used to set timer counter value causing high | H'FFFF8288 | pul_duty1a | | output from TIOC1B P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFF82AA pul_duty2b | | output from TIOC1A | | | | P_MTU2.TGRA_2 Used to set timer counter value causing high output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFF82AA pul_duty2b | P_MTU1.TGRB_1 | Used to set timer counter value causing high | H'FFFF828A | pul_duty1b | | output from TIOC2A P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFF82AA pul_duty2b | | output from TIOC1B | | | | P_MTU2.TGRB_2 Used to set timer counter value causing high H'FFF82AA pul_duty2b | P_MTU2.TGRA_2 | Used to set timer counter value causing high | H'FFFF82A8 | pul_duty2a | | | | output from TIOC2A | | | | output from TIOC2B | P_MTU2.TGRB_2 | Used to set timer counter value causing high | H'FFFF82AA | pul_duty2b | | | | output from TIOC2B | | | | Register Name | Function Assignment | Address | Set Value | |----------------|---------------------------------------------------------------------------------------------------------------|------------|-----------| | P_MTU0.TIORH_0 | Sets TGRA_0 initial output 0, 0 output on output compare, TGRB_0 initial output 0, 1 output on output compare | H'FFFF8262 | H'20 | | P_MTU0.TIORL_0 | Sets TGRC_0 initial output 0, 1 output on output compare, TGRD_0 initial output 0, 1 output on output compare | H'FFFF8263 | H'22 | | P_MTU1.TIOR_1 | Sets TGRA_1 initial output 0, 1 output on output compare, TGRB_1 initial output 0, 1 output on output compare | H'FFFF8282 | H'22 | | P_MTU1.TIOR_2 | Sets TGRA_2 initial output 0, 1 output on output compare, TGRB_2 initial output 0, 1 output on output compare | H'FFFF82A2 | H'22 | | P_MTU0.TMDR_0 | Used to set PWM Mode 2 as operating mode of | H'FFFF8261 | H'c3 | | P_MTU1.TMDR_1 | each channel | H'FFFF8281 | H'c3 | | P_MTU2.TMDR_2 | | H'FFFF82A1 | H'c3 | ## (4) RAM Used This sample task does not use any RAM apart from the arguments. **Note:** SH7046 header file names are used for register label names. #### 5. Flowcharts #### (1) Main routine #### 6. Program Listing ``` INCLUDE FILE #include<machine.h> #include"iodefine_7046.h" * / PROTOTYPE void pwm_2(void); RAM ALLOCATION #define pul_cyc0 (*(unsigned short *)0xffffd000) #define pul_duty0b (*(unsigned short *)0xffffd002) #define pul_duty0c (*(unsigned short *)0xffffd004) #define pul_duty0d (*(unsigned short *)0xffffd006) #define pul_dutyla (*(unsigned short *)0xffffd008) #define pul_duty1b (*(unsigned short *)0xffffd00a) #define pul_duty2a (*(unsigned short *)0xffffd00c) #define pul_duty2b (*(unsigned short *)0xffffd00e) MAIN PROGRAM void pwm_2(void) P_STBY.MSTCR2.WORD =0xd2fd; /* Clear module standby mode */ P_DODGE_DETOR_MORD = 0x00fo: /* TIOCOB/C/D_TIOCOB/R TIOCOB/R P_PORTE.PEIORL.WORD = 0x00fe; /* TIOC0B/C/D,TIOC1A/B,TIOC2A/B output */ P_PORTE.PECRL2.WORD = 0x5554; P_MTU0.TCR_0.BYTE = 0x20; /* Counter clear by TGRA_0 */ P_MTU0.TIORH_0.BYTE = 0x20; P_MTU0.TIORL_0.BYTE = 0x22; P_MTU0.TCNT_0 = 0x0000; P_MTU0.TGRA_0 = pul_cyc0; /* Set general register */ P_MTU0.TGRB_0 = pul_duty0b; P_MTU0.TGRC_0 = pul_duty0c; P_MTU0.TGRD_0 = pul_duty0d; /* PWM mode2 */ P_MTU0.TMDR_0.BYTE = 0xc3; /* Counter clear by TGRA_0 */ P_MTU1.TCR_1.BYTE = 0x60; P_MTU1.TIOR_1.BYTE = 0x22; P_MTU1.TCNT_1 = 0x0000; P_MTU1.TGRA_1 = pul_duty1a; /* Set general register */ P_MTU1.TGRB_1 = pul_duty1b; P_MTU1.TMDR_1.BYTE = 0xc3; /* PWM mode2 */ P_MTU2.TCR_2.BYTE = 0x60; /* Counter clear by TGRA_0 */ P_MTU2.TIOR_2.BYTE = 0x22; P_MTU2.TCNT_2 = 0x0000; P_MTU2.TGRA_2 = pul_duty2a; /* Set general register */ P_MTU2.TGRB_2 = pul_duty2b; P_MTU2.TMDR_2.BYTE = 0xc3; /* PWM mode2 */ ``` #### Keep safety first in your circuit designs! 1. Renesas Technology Corp. 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 Corp. 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 Corp. or a third party. - 2. Renesas Technology Corp. 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 Corp. without notice due to product improvements or other reasons. It is therefore recommended that customers contact Renesas Technology Corp. or an authorized Renesas Technology Corp. 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 Corp. 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 Corp. by various means, including the Renesas Technology Corp. 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 Corp. assumes no responsibility for any damage, liability or other loss resulting from the information contained herein. - 5. Renesas Technology Corp. 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 Corp. or an authorized Renesas Technology Corp. 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 Corp. 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 Corp. for further details on these materials or the products contained therein.