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

- 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 for 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 product is "Standard" unless otherwise expressly specified in a Renesas Electronics atta abooks, 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.
- 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.

# Regarding the change of names mentioned in the document, such as Hitachi Electric and Hitachi XX, to Renesas Technology Corp.

The semiconductor operations of Mitsubishi Electric and Hitachi were transferred to Renesas Technology Corporation on April 1st 2003. These operations include microcomputer, logic, analog and discrete devices, and memory chips other than DRAMs (flash memory, SRAMs etc.) Accordingly, although Hitachi, Hitachi, Ltd., Hitachi Semiconductors, and other Hitachi brand names are mentioned in the document, these names have in fact all been changed to Renesas Technology Corp. Thank you for your understanding. Except for our corporate trademark, logo and corporate statement, no changes whatsoever have been made to the contents of the document, and these changes do not constitute any alteration to the contents of the document itself.

Renesas Technology Home Page: http://www.renesas.com

Renesas Technology Corp. Customer Support Dept. April 1, 2003



#### Cautions

Keep safety first in your circuit designs!

 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 or an authorized 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.



8

# H8/300 Series, H8/300L Series Application Note - Software

Renesas Electronics www.renesas.com

2003.03

# Notice

When using this document, keep the following in mind:

- 1. This document may, wholly or partially, be subject to change without notice.
- 2. All rights are reserved: No one is permitted to reproduce or duplicate, in any form, the whole or part of this document without Hitachi's permission.
- 3. Hitachi will not be held responsible for any damage to the user that may result from accidents or any other reasons during operation of the user's unit according to this document.
- 4. Circuitry and other examples described herein are meant merely to indicate the characteristics and performance of Hitachi's semiconductor products. Hitachi assumes no responsibility for any intellectual property claims or other problems that may result from applications based on the examples described herein.
- 5. No license is granted by implication or otherwise under any patents or other rights of any third party or Hitachi, Ltd.
- 6. MEDICAL APPLICATIONS: Hitachi's products are not authorized for use in MEDICAL APPLICATIONS without the written consent of the appropriate officer of Hitachi's sales company. Such use includes, but is not limited to, use in life support systems. Buyers of Hitachi's products are requested to notify the relevant Hitachi sales offices when planning to use the products in MEDICAL APPLICATIONS.

## Contents < Table of Contents>

| Section 1   |        | Move Data                                   | 1  |
|-------------|--------|---------------------------------------------|----|
| 1.1 Set Con |        | nstants                                     | 1  |
|             | 1.1.1  | Function                                    | 1  |
|             | 1.1.2  | Arguments                                   | 1  |
|             | 1.1.3  | Internal Register and Flag Changes          | 1  |
|             | 1.1.4  | Specifications                              | 2  |
|             | 1.1.5  | Note                                        | 2  |
|             | 1.1.6  | Description                                 | 2  |
|             | 1.1.7  | Flowchart                                   | 5  |
|             | 1.1.8  | Program List                                | 6  |
| 1.2         | Move I | Block 1                                     | 7  |
|             | 1.2.1  | Function                                    | 7  |
|             | 1.2.2  | Arguments                                   | 7  |
|             | 1.2.3  | Internal Register and Flag Changes          | 7  |
|             | 1.2.4  | Specifications                              | 8  |
|             | 1.2.5  | Note                                        | 8  |
|             | 1.2.6  | Description                                 | 8  |
|             | 1.2.7  | Flowchart                                   | 12 |
|             | 1.2.8  | Program List                                | 13 |
| 1.3         | Move I | Block 2 (Example of the EEPMOV Instruction) | 14 |
|             | 1.3.1  | Function                                    | 14 |
|             | 1.3.2  | Arguments                                   | 14 |
|             | 1.3.3  | Internal Register and Flag Changes          | 14 |
|             | 1.3.4  | Specifications                              | 15 |
|             | 1.3.5  | Note                                        | 15 |
|             | 1.3.6  | Description                                 | 15 |
|             | 1.3.7  | Flowchart                                   | 20 |
|             | 1.3.8  | Program List                                | 22 |
| 1.4         | Move ( | Character Strings                           | 23 |
|             | 1.4.1  | Function                                    | 23 |
|             | 1.4.2  | Arguments                                   | 23 |
|             | 1.4.3  | Internal Register and Flag Changes          | 23 |
|             | 1.4.4  | Specifications                              | 24 |
|             | 1.4.5  | Note                                        | 24 |
|             | 1.4.6  | Description                                 | 25 |
|             | 1.4.7  | Flowchart                                   | 28 |
|             | 1.4.8  | Program List                                | 29 |

| Section 2 Branch by Table                                 | 31 |
|-----------------------------------------------------------|----|
| 2.1 Branch by Table                                       |    |
| 2.1.1 Function                                            |    |
| 2.1.2 Arguments                                           | 31 |
| 2.1.3 Internal Register and Flag Changes                  |    |
| 2.1.4 Specifications                                      | 32 |
| 2.1.5 Note                                                |    |
| 2.1.6 Description                                         | 32 |
| 2.1.7 Flowchart                                           | 37 |
| 2.1.8 Program List                                        |    |
| Section 3 ASCII CODE PROCESSING                           |    |
| 3.1 Change ASCII Code from Lowercase to Uppercase         |    |
| 3.1.1 Function                                            |    |
| 3.1.2 Arguments                                           |    |
| 3.1.3 Internal Register and Flag Changes                  |    |
| 3.1.4 Specifications                                      | 40 |
| 3.1.5 Description                                         |    |
| 3.1.6 Flowchart                                           | 43 |
| 3.1.7 Program List                                        | 44 |
| 3.2 Change an ASCII Code to a 1-Byte Hexadecimal Number   |    |
| 3.2.1 Function                                            |    |
| 3.2.2 Arguments                                           |    |
| 3.2.3 Internal Register and Flag Changes                  |    |
| 3.2.4 Specifications                                      |    |
| 3.2.5 Description                                         |    |
| 3.2.6 Flowchart                                           |    |
| 3.2.7 Program List                                        |    |
| 3.3 Change an 8-Bit Binary Number to a 2-Byte ASCII Code  |    |
| 3.3.1 Function                                            |    |
| 3.3.2 Arguments                                           |    |
| 3.3.3 Internal Register and Flag Changes                  |    |
| 3.3.4 Specifications                                      |    |
| 3.3.5 Description                                         |    |
| 3.3.6 Flowchart                                           |    |
| 3.3.7 Program List                                        |    |
| Section 4 BIT PROCESSING                                  |    |
| 4.1 Count the Number of Logic 1 Bits in 8-Bit Data (HCNT) |    |
| 4.1.1 Function                                            |    |
| 4.1.2 Arguments                                           |    |
| 4.1.3 Internal Register and Flag Changes                  |    |

|       | 4.1.4    | Specifications                     | 60 |
|-------|----------|------------------------------------|----|
|       | Notes    | 60                                 |    |
|       | 4.1.6    | Description                        | 60 |
|       | 4.1.7    | Flowchart                          | 62 |
|       | 4.1.8    | Program List                       | 63 |
| 4.2   | Shift 16 | 5-Bit Binary to Right (SHR)        | 64 |
|       | 4.2.1    | Function                           | 64 |
|       | 4.2.2    | Arguments                          | 64 |
|       | 4.2.3    | Internal Register and Flag Changes | 64 |
|       | 4.2.4    | Specifications                     | 65 |
|       | 4.2.5    | Notes                              | 65 |
|       | 4.2.6    | Description                        | 65 |
|       | 4.2.7    | Flowchart                          | 68 |
|       | 4.2.8    | Program List                       | 69 |
|       |          |                                    |    |
| Secti | on 5     | COUNTER                            | 71 |
| 5.1   | 4-Digit  | Decimal Counter                    | 71 |
|       | 5.1.1    | Function                           | 71 |
|       | 5.1.2    | Arguments                          | 71 |
|       | 5.1.3    | Internal Register and Flag Changes | 71 |
|       | 5.1.4    | Specifications                     | 72 |
|       | 5.1.5    | Description                        | 72 |
|       | 5.1.6    | Flowchart                          | 75 |
|       | 5.1.7    | Program List                       | 76 |
|       |          |                                    |    |
| Secti | on 6     | COMPARISO                          | 77 |
| 6.1   | Compa    | re 32-Bit Binary Numbers           | 77 |
|       | 6.1.1    | Function                           | 77 |
|       | 6.1.2    | Arguments                          | 77 |
|       | 6.1.3    | Internal Register and Flag Changes | 77 |
|       | 6.1.4    | Specifications                     | 78 |
|       | 6.1.5    | Description                        | 78 |
|       | 6.1.6    | Flowchart                          | 81 |
|       | 6.1.7    | Program List                       | 81 |
| a     | _        |                                    |    |
| Secti |          | ARITHMETIC OPERATION               | 83 |
| 7.1   |          | n of 32-Bit Binary Numbers         | 83 |
|       | 7.1.1    | Function                           | 83 |
|       | 7.1.2    | Arguments                          | 83 |
|       | 7.1.3    | Internal Register and Flag Changes | 83 |
|       | 7.1.4    | Specifications                     | 84 |
|       | 7.1.5    | Description                        | 84 |
|       | 7.1.6    | Flowchart                          | 88 |

|     | 7.1.7   | Program List                               | 89  |
|-----|---------|--------------------------------------------|-----|
| 7.2 | Subtra  | ction of 32-Bit Binary Numbers             | 90  |
|     | 7.2.1   | Function                                   | 90  |
|     | 7.2.2   | Arguments                                  | 90  |
|     | 7.2.3   | Internal Register and Flag Changes         | 90  |
|     | 7.2.4   | Specifications                             | 91  |
|     | 7.2.5   | Description                                | 91  |
|     | 7.2.6   | Flowchart                                  | 95  |
|     | 7.2.7   | Program List                               | 96  |
| 7.3 | Multip  | lication of 16-Bit Binary Numbers          | 97  |
|     | 7.3.1   | Function                                   | 97  |
|     | 7.3.2   | Arguments                                  | 97  |
|     | 7.3.3   | Internal Register and Flag Changes         | 97  |
|     | 7.3.4   | Specifications                             | 98  |
|     | 7.3.5   | Description                                | 98  |
|     | 7.3.6   | Flowchart                                  | 102 |
|     | 7.3.7   | Program List                               | 103 |
| 7.4 | Divisio | on of 32-Bit Binary Numbers                | 104 |
|     | 7.4.1   | Function                                   | 104 |
|     | 7.4.2   | Arguments                                  | 104 |
|     | 7.4.3   | Internal Register and Flag Changes         | 104 |
|     | 7.4.4   | Specifications                             | 105 |
|     | 7.4.5   | Description                                | 105 |
|     | 7.4.6   | Flowchart                                  | 110 |
|     | 7.4.7   | Program List                               | 112 |
| 7.5 | Additi  | on of Multiple-Precision Binary Numbers    | 113 |
|     | 7.5.1   | Function                                   | 113 |
|     | 7.5.2   | Arguments                                  | 113 |
|     | 7.5.3   | Internal Register and Flag Changes         | 113 |
|     | 7.5.4   | Specifications                             | 114 |
|     | 7.5.5   | Notes                                      | 114 |
|     | 7.5.6   | Description                                | 114 |
|     | 7.5.7   | Flowchart                                  | 118 |
|     | 7.5.8   | Program List                               | 120 |
| 7.6 | Subtra  | ction of Multiple-Precision Binary Numbers | 121 |
|     | 7.6.1   | Function                                   | 121 |
|     | 7.6.2   | Arguments                                  | 121 |
|     | 7.6.3   | Internal Register and Flag Changes         | 121 |
|     | 7.6.4   | Specifications                             | 122 |
|     | 7.6.5   | Notes                                      | 122 |
|     | 7.6.6   | Description                                | 122 |
|     | 7.6.7   | Flowchart                                  | 126 |
|     | 7.6.8   | Program List                               | 128 |

| 7.7  | Additic | on of 8-Digit BCD Numbers            | 129 |
|------|---------|--------------------------------------|-----|
|      | 7.7.1   | Function                             | 129 |
|      | 7.7.2   | Arguments                            | 129 |
|      | 7.7.3   | Internal Register and Flag Changes   | 129 |
|      | 7.7.4   | Specifications                       | 130 |
|      | 7.7.5   | Description                          | 130 |
|      | 7.7.6   | Flowchart                            | 135 |
|      | 7.7.7   | Program List                         | 136 |
| 7.8  | Subtrac | tion of 8-Digit BCD Numbers          | 137 |
|      | 7.8.1   | Function                             | 137 |
|      | 7.8.2   | Arguments                            | 137 |
|      | 7.8.3   | Internal Register and Flag Changes   | 137 |
|      | 7.8.4   | Specifications                       |     |
|      | 7.8.5   | Description                          | 138 |
|      | 7.8.6   | Flowchart                            | 143 |
|      | 7.8.7   | Program List                         | 144 |
| 7.9  | Multipl | ication of 4-Digit BCD Numbers       | 145 |
|      | 7.9.1   | Function                             | 145 |
|      | 7.9.2   | Arguments                            | 145 |
|      | 7.9.3   | Internal Register and Flag Changes   | 145 |
|      | 7.9.4   | Specifications                       | 146 |
|      | 7.9.5   | Notes                                | 146 |
|      | 7.9.6   | Description                          | 146 |
|      | 7.9.7   | Flowchart                            | 151 |
|      | 7.9.8   | Program List                         | 153 |
| 7.10 | Divisio | n of 8-Digit BCD Numbers             | 154 |
|      | 7.10.1  | Function                             | 154 |
|      | 7.10.2  | Arguments                            | 154 |
|      | 7.10.3  | Internal Register and Flag Changes   | 154 |
|      | 7.10.4  | Specifications                       | 155 |
|      | 7.10.5  | Notes                                | 155 |
|      | 7.10.6  | Description                          | 156 |
|      | 7.10.7  | Flowchart                            | 160 |
|      | 7.10.8  | Program List                         | 163 |
| 7.11 | Additic | on of Multiple-Precision BCD Numbers | 165 |
|      | 7.11.1  | Function                             | 165 |
|      | 7.11.2  | Arguments                            | 165 |
|      | 7.11.3  | Internal Register and Flag Changes   | 165 |
|      | 7.11.4  | Specifications                       | 166 |
|      | 7.11.5  | Notes                                | 166 |
|      | 7.11.6  | Description                          | 166 |
|      | 7.11.7  | Flowchart                            | 171 |
|      | 7.11.8  | Program List                         | 173 |

| 7.12 | Subtrac | tion of Multiple-Precision BCD Numbers                            | 174 |
|------|---------|-------------------------------------------------------------------|-----|
|      | 7.12.1  | Function                                                          | 174 |
|      | 7.12.2  | Arguments                                                         | 174 |
|      | 7.12.3  | Internal Register and Flag Changes                                | 174 |
|      | 7.12.4  | Specifications                                                    | 175 |
|      | 7.12.5  | Notes                                                             | 175 |
|      | 7.12.6  | Description                                                       | 175 |
|      | 7.12.7  | Flowchart                                                         | 179 |
|      | 7.12.8  | Program List                                                      | 181 |
| 7.13 | Additic | on of Signed 32-Bit Binary Numbers                                | 182 |
|      | 7.13.1  | Function                                                          | 182 |
|      | 7.13.2  | Arguments                                                         | 182 |
|      | 7.13.3  | Internal Register and Flag Changes                                | 182 |
|      |         | Specifications                                                    |     |
|      | 7.13.5  | Description                                                       | 183 |
|      |         | Flowchart                                                         |     |
|      | 7.13.7  | Program List                                                      | 189 |
| 7.14 |         | ication of Signed 16-Bit Binary Numbers                           |     |
|      | -       | Function                                                          |     |
|      | 7.14.2  | Arguments                                                         | 190 |
|      | 7.14.3  | Internal Register and Flag Changes                                | 190 |
|      | 7.14.4  |                                                                   |     |
|      | 7.14.5  | Notes                                                             | 191 |
|      | 7.14.6  | Description                                                       | 191 |
|      | 7.14.7  | Flowchart                                                         | 195 |
|      | 7.14.8  | Program List                                                      | 197 |
| 7.15 |         | of a Short Floating-Point Number to a Signed 32-Bit Binary Number |     |
|      | -       | Function                                                          |     |
|      | 7.15.2  |                                                                   |     |
|      | 7.15.3  | Internal Register and Flag Changes                                |     |
|      |         | Specifications                                                    |     |
|      |         | Notes                                                             |     |
|      | 7.15.6  | Description                                                       | 201 |
|      | 7.15.7  | Flowchart                                                         | 204 |
|      | 7.15.8  | Program List                                                      | 207 |
| 7.16 | Change  | of a Signed 32-Bit Binary Number to a Short Floating-Point Number | 209 |
|      | -       | Function                                                          |     |
|      | 7.16.2  | Arguments                                                         |     |
|      | 7.16.3  | Internal Register and Flag Changes                                |     |
|      | 7.16.4  | Specifications                                                    | 210 |
|      | 7.16.5  | Notes                                                             | 210 |
|      | 7.16.6  | Description                                                       | 210 |
|      |         | Flowchart                                                         | 213 |

|       | 7.16.8                                      | Program List                                              | 216 |  |
|-------|---------------------------------------------|-----------------------------------------------------------|-----|--|
| 7.17  | 17 Addition of Short Floating-Point Numbers |                                                           |     |  |
|       | 7.17.1                                      | Function                                                  | 218 |  |
|       | 7.17.2                                      | Arguments                                                 | 218 |  |
|       | 7.17.3                                      | Internal Register and Flag Changes                        | 218 |  |
|       | 7.17.4                                      | Specifications                                            | 219 |  |
|       | 7.17.5                                      | Notes                                                     | 219 |  |
|       | 7.17.6                                      | Description                                               | 220 |  |
|       | 7.17.7                                      | Flowchart                                                 | 224 |  |
|       | 7.17.8                                      | Program List                                              | 232 |  |
| 7.18  | Multipl                                     | ication of Short Floating-Point Numbers                   | 235 |  |
|       | 7.18                                        | Function                                                  | 235 |  |
|       | 7.18.1                                      | Arguments                                                 | 235 |  |
|       | 7.18.2                                      | Internal Register and Flag Changes                        | 235 |  |
|       | 7.18.3                                      | Specifications                                            | 236 |  |
|       | 7.18.4                                      | Notes                                                     | 236 |  |
|       | 7.18.5                                      | Description                                               | 236 |  |
|       | 7.18.6                                      | Flowchart                                                 | 241 |  |
|       | 7.18.7                                      | Program List                                              | 251 |  |
| 7.19  | Square                                      | Root of a 32-Bit Binary Number                            | 255 |  |
|       | 7.19.1                                      | Function                                                  | 255 |  |
|       | 7.19.2                                      | Arguments                                                 | 255 |  |
|       | 7.19.3                                      | Internal Register and Flag Changes                        | 255 |  |
|       | 7.19.4                                      | Specifications                                            | 256 |  |
|       | 7.19.5                                      | Notes                                                     | 256 |  |
|       | 7.19.6                                      | Description                                               | 256 |  |
|       | 7.19.7                                      | Flowchart                                                 | 260 |  |
|       | 7.19.8                                      | Program List                                              | 263 |  |
|       |                                             |                                                           |     |  |
| Secti | on 8                                        | $DECIMAL \leftrightarrow HEXADECIMAL\ CHANGE.$            | 265 |  |
| 8.1   | Change                                      | e a 2-Byte Hexadecimal Number to a 5-Character BCD Number | 265 |  |
|       | 8.1.1                                       | Function                                                  | 265 |  |
|       | 8.1.2                                       | Arguments                                                 | 265 |  |
|       | 8.1.3                                       | Internal Register and Flag Changes                        | 265 |  |
|       | 8.1.4                                       | Specifications                                            | 266 |  |
|       | 8.1.5                                       | Description                                               | 266 |  |
|       | 8.1.6                                       | Flowchart                                                 | 270 |  |
|       | 8.1.7                                       | Program List                                              | 271 |  |
| 8.2   | Change                                      | e a 5-Character BCD Number to a 2-Byte Hexadecimal Number | 272 |  |
|       | 8.2.1                                       | Function                                                  | 272 |  |
|       | 8.2.2                                       | Arguments                                                 |     |  |
|       | 8.2.3                                       | Internal Register and Flag Changes                        | 272 |  |
|       | 8.2.4                                       | Specifications                                            | 273 |  |

|       | 8.2.5               | Description 2                      |     |  |  |
|-------|---------------------|------------------------------------|-----|--|--|
|       | 8.2.6               | Flowchart                          |     |  |  |
|       | 8.2.7 Program List  |                                    |     |  |  |
|       |                     |                                    |     |  |  |
| Secti | on 9                | Sorting                            | 281 |  |  |
| 9.1   | Set Cor             | nstants                            | 281 |  |  |
|       | 9.1.1               | Function                           | 281 |  |  |
|       | 9.1.2               | Arguments                          | 281 |  |  |
|       | 9.1.3               | Internal Register and Flag Changes | 281 |  |  |
|       | 9.1.4               | Specifications                     | 282 |  |  |
|       | 9.1.5               | Note                               | 282 |  |  |
|       | 9.1.6               | Description                        | 282 |  |  |
|       | 9.1.7               | Flowchart                          | 286 |  |  |
|       | 9.1.8               | Program List                       | 287 |  |  |
|       |                     |                                    |     |  |  |
| Secti | on 10               | ARRAY                              | 289 |  |  |
| 10.1  | 2-Dime              | ensional Array (ARRAY)             | 289 |  |  |
|       | 10.1.1              | Function                           | 289 |  |  |
|       | 10.1.2              | Arguments                          | 289 |  |  |
|       | 10.1.3              | Internal Register and Flag Changes | 289 |  |  |
|       | 10.1.4              | Specifications                     | 290 |  |  |
|       | 10.1.5              | Note                               | 290 |  |  |
|       | 10.1.6              | Description                        | 291 |  |  |
|       | 10.1.7              | Flowchart                          | 295 |  |  |
|       | 10.1.8 Program List |                                    |     |  |  |

## Section 1 Move Data

## 1.1 Set Constants

MCU: H8/300 Series H8/300L Series

Label name: FILL

#### 1.1.1 Function

- 1. The software FILL places 1-byte constants in the data memory area.
- 2. The data memory area can have a free size.
- 3. Constants can have any length within the range 1 to 255 bytes.
- 4. This function is useful in initializing a RAM area.

#### 1.1.2 Arguments

| Descript | ion                          | Memory area | Data length (bytes) |
|----------|------------------------------|-------------|---------------------|
| Input    | Byte count (number of bytes) | R0L         | 1                   |
|          | Constants                    | R0H         | 1                   |
|          | Start address                | R1          | 2                   |
| Output   | —                            | _           | _                   |

#### 1.1.3 Internal Register and Flag Changes

| R0I | H R0 | L R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|-----|------|------|----|----|----|----|----|----|--|
| ×   | ×    | ×    | •  | •  | •  | •  | •  | •  |  |
|     |      |      |    |    |    |    |    |    |  |
| I   |      | U    | Н  | U  | Ν  | Z  | V  | С  |  |
| •   |      | •    | •  | •  | ×  | ×  | ×  | •  |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |  |
|------------------------|--|
| 10                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 3068                   |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |

## 1.1.5 Note

The specified clock cycle count (3068) is for 255 bytes of constants.

## 1.1.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software FILL:
    - R0L: Contains, as an input argument, the number of bytes to be placed in the data memory area holding constants.
    - R0H: Contains, as an input argument, 1-byte constants to be placed in the data memory area.
    - R1: Contains, as an input argument, the start address of the data memory area holding constants.

b. Figure 1.1 shows an example of the software FILL being executed.When the input arguments are set as shown in (1), the constant H'34 set in R0H is placed in the data memory area as shown in (2).



Figure 1.1 Example of Software FILL Execution

- 2. Notes on usage
  - a. ROL is one byte long and should satisfy the relation  $H'01 \le ROL \le H'FF$ .
  - b. Do not set "0" in R0L; otherwise, the software FILL can no longer be terminated.
- 3. Data memory

The software FILL does not use the data memory.

#### 4. Example of use

Set a constant, a byte count, and a start address in the arguments and call the software FILL as a subroutine.

| WORK1 | . DATA. B   | 0           | Reserves a data memory area (1 byte:<br>contents=H'00) in which the user program<br>places the number of bytes to be moved. |
|-------|-------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| WORK2 | . DATA. B   | 0           | Reserves a data memory area (1 byte:<br>contents=H'00) in which the user program<br>places constants.                       |
| WORK3 | . RES. B    | 10          | Reserves a data memory area (10 bytes) that is set by the software FILL.                                                    |
|       | і<br>MOV. В | @WORK1, R0L | Places the number of bytes set by the user program in the R0L input argument.                                               |
|       | MOV. B      | @WORK2, R0H | Places the constants set by the user program in the R0H argument.                                                           |
|       | MOV. W      | #WORK3, R1  | Places the start address of the data<br>memory area allocated by the user<br>program in the R1 argument.                    |
|       | JSR         | @FILL       | Calls the software FILL as a subroutine.                                                                                    |

- 5. Operation
  - a. R1 is used as the pointer that indicates the address of the data memory area in which constants are placed.
  - b. The constants set in R0H in 16-bit absolute addressing mode are stored sequentially in the data memory area.
  - c. ROL is used as the pointer that indicates the number of bytes in the data memory area in which constants are placed. ROL is decremented each time a constant is placed in the data memory area until it reaches 0.



## 1.1.8 Program List

\*\*\* H8/300 ASSEMBLER VER 1.0B \*\* 08/18/92 11:04:12 PROGRAM NAME = 1 2 ;\* 3 ;\* 00 - NAME :FILL OF CONSTANT DATA (FILL) 4 ;\* 5 6 ;\* 7 ;\* ENTRY :ROL (Byte counter) 8 ;\* ROH (Constant data) 9 ; \* R1 (Start address) 10 ;\* 11 ;\* RETURN :NOTHING 12 ;\* 13 14 ; .SECTION FILL\_code,CODE,ALIGN=2 .EXPORT FILL 15 FILL\_cod C 0000 16 17 ; LL.EQU \$ ;Entry Point MOV.B ROH.@R1 ;Store constant data 18 FILL\_cod C 00000000 FILL .EQU \$ 19 FILL\_cod C 0000 6890 ADDS.W #1,R1 20 FILL\_cod C 0002 0B01 ;Increment address pointer 21 FILL\_cod C 0004 1A08 DEC.B ROL ;Decrement byte counter BNE FILL 22 FILL\_cod C 0006 46F8 Branch if Z flag = 0 23 ; 24 FILL\_cod C 0008 5470 RTS 25 ; 26 .END \*\*\*\*\*TOTAL ERRORS 0 \*\*\*\*\*TOTAL WARNINGS 0

## 1.2 Move Block 1

MCU: H8/300 Series H8/300L Series

Label name: MOVE1

## 1.2.1 Function

- 1. The software MOVE1 moves block data from one data memory area to another.
- 2. The source and destination data memory areas can have a free size.
- 3. The block data can have any length within the range 1 to 255 bytes.

#### 1.2.2 Arguments

| Descript | ion                               | Memory area | Data length (bytes) |
|----------|-----------------------------------|-------------|---------------------|
| Input    | Byte count (number of bytes)      | R0L         | 1                   |
|          | Start address of source area      | R1          | 2                   |
|          | Start address of destination area | R2          | 2                   |
| Output   |                                   |             | ·                   |

#### 1.2.3 Internal Register and Flag Changes

| R0 | H RO | L R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|------|------|----|----|----|----|----|----|--|
| ×  | ×    | ×    | ×  | •  | •  | •  | •  | •  |  |
|    |      |      |    |    |    |    |    |    |  |
| I  |      | U    | н  | U  | Ν  | Z  | V  | С  |  |
| •  |      | •    | •  | •  | ×  | ×  | ×  | •  |  |

× : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |
|------------------------|
| 14                     |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 4598                   |
| Reentrant              |
| Possible               |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |
|                        |

## 1.2.5 Note

The specified clock cycle count (4598) is for 255 bytes of block data.

#### 1.2.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software MOVE1:
    - R0L: Contains, as an input argument, the number of bytes of block data.
    - R1: Contains, as an input argument, the start address of the source data memory area.
    - R2: Contains, as an input argument, the start address of the destination data memory area.

b. Figure 1.2 shows an example of the software MOVE1 being executed.When the input arguments are set as shown in (1), the data is moved block by block from the source (H'FD80 to H'FD89) to the destination (H'FE80 to H'FE89) as shown in (2).



Figure 1.2 Example of Software MOVE1 Execution

- 2. Notes on usage
  - a. ROL is one byte long and should satisfy the relation  $H'01 \le ROL \le H'FF$ .
  - b. Do not set "0" in R0L; otherwise, the software MOVE1 can no longer be terminated.
  - c. Set the input arguments, ensuring that the source data memory area (A) does not overlap the destination data memory area (C) as shown in figure 1.3. In the case of figure 1.3, the overlapped block data (B) at the source is destroyed.



Figure 1.3 Moving Block Data with Overlapped Data Memory Areas

3. Data memory

The software MOVE1 does not use the data memory.

#### 4. Example of use

Set the start address of a source, the start address of a destination, and the number of bytes to be moved in the arguments and call the software MOVE1 as a subroutine.

| WORK1 | . DATA. B      | 10          |                                                                                                                                        |
|-------|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
|       | . ALIGN        | 2           | Places the data memory area (WORK1) at an even address.                                                                                |
| WORK2 | . DATA. W      | 0           | Reserves a data memory area (2 bytes:<br>contents=H'0000) in which the<br>userprogram places the start address of<br>the source.       |
| WORK3 | . DATA. W<br>: | 0           | Reserves a data memory area (2 bytes:<br>contents=H'0000) in which the user<br>program places the start address of the<br>destination. |
|       | i<br>MOV. B    | @WORK1, R0L | Places the number of bytes set by the user program in the R0L argument.                                                                |
|       | MOV. W         | @WORK2, R1  | Places the start address of the source set by the user program.                                                                        |
|       | MOV. W         | @WORK3, R2  | Places the start address of the destination set by the user program.                                                                   |
|       | JSR            | @MOVE1      | Calls the software MOVE1 as a subroutine.                                                                                              |

- 5. Operation
  - a. R1 is used as the pointer that indicates the address of the source and R2 the pointer that indicates the address of the destination.
  - b. The cycle of storing the data at the source in the work register (R0H) and then at the destination is repeated in 16-bit absolute addressing mode.
  - c. ROL is used as the counter that indicates the number of bytes moved. It is decremented each time 1-byte data is moved until it reaches 0.



## 1.2.8 Program List

| OGRAM NAME =       |         |      |         |         |         |                                         |
|--------------------|---------|------|---------|---------|---------|-----------------------------------------|
| 1                  |         | ;*** | ******  | ******  | ******  | * * * * * * * * * * * * * * * * * * * * |
| 2                  |         | ;*   |         |         |         |                                         |
| 3                  |         | ;*   | 00-NAME |         | : BROCK | DATA TRANSFER (MOVE1)                   |
| 4                  |         | ;*   |         |         |         |                                         |
| 5                  |         | ;*** | ******  | ******  | ******  | * * * * * * * * * * * * * * * * * * * * |
| 6                  |         | ;*   |         |         |         |                                         |
| 7                  |         | ;*   | ENTRY   |         | :R0L    | (Byte counter)                          |
| 8                  |         | ;*   |         |         | Rl      | (Source data start address)             |
| 9                  |         | ; *  |         |         | R2      | (Destination data start address)        |
| 10                 |         | ; *  |         |         |         |                                         |
| 11                 |         | ; *  | RETURN  |         | :NOTHIN | NG                                      |
| 12                 |         | ; *  |         |         |         |                                         |
| 13                 |         | ;*** | ******  | ******  | ******  | ************                            |
| 14                 |         | ;    |         |         |         |                                         |
| 15 MOVE1_co C 0000 |         |      | .SECTIO | N       | MOVE1_c | code,CODE,ALIGN=2                       |
| 16                 |         |      | .EXPORT |         | MOVE1   |                                         |
| 17                 |         | ,    |         |         |         |                                         |
| 18 MOVE1_co C      | 0000000 | MOVE | 1       | .EQU    | \$      | Entry point                             |
| 19 MOVE1_co C 0000 | 6810    |      | MOV.B   | @R1,R0H |         | ;Load source address data to ROH        |
| 20 MOVE1_co C 0002 | 68A0    |      | MOV.B   | ROH,@R2 |         | ;Store ROH to destination address       |
| 21 MOVE1_co C 0004 | 0B01    |      | ADDS.W  | #1,R1   |         | ;Increment source address pointer       |
| 22 MOVE1_co C 0006 | 0B02    |      | ADDS.W  | #1,R2   |         | ;Increment destination address pointer  |
| 23 MOVE1_co C 0008 |         |      | DEC     | ROL     |         | ;Decrement byte counter                 |
| 24 MOVE1_CO C 000A | 46F4    |      | BNE     | MOVE1   |         | ;Branch if byte counter = 0             |
| 25                 |         | ;    |         |         |         |                                         |
| 26 MOVE1_co C 000C | 5470    |      | RTS     |         |         |                                         |
| 27                 |         | ;    |         |         |         |                                         |
| 28                 |         |      | .END    |         |         |                                         |

## **1.3** Move Block 2 (Example of the EEPMOV Instruction)

MCU: H8/300 Series H8/300L Series

Label name: MOVE2

#### 1.3.1 Function

- 1. The software MOVE2 moves block data from one data memory area to another.
- 2. The source and destination data memory areas can have a free size.
- 3. Data can be moved even where the source data memory area overlaps the destination data memory area.
- 4. This is an example of the application software EEPMOV (move block instruction).

#### 1.3.2 Arguments

| Descript | ion                               | Memory area  | Data length (bytes) |
|----------|-----------------------------------|--------------|---------------------|
| Input    | Byte count (number of bytes)      | R4L          | 1                   |
|          | Start address of source area      | R5           | 2                   |
|          | Start address of destination area | R6           | 2                   |
| Output   | Error                             | C flag (CCR) |                     |

#### 1.3.3 Internal Register and Flag Changes

| R0H | H ROI | L R1 | R2 | R3 | R4H | R4L R | 5 R6 | R7 |  |
|-----|-------|------|----|----|-----|-------|------|----|--|
| ×   | ×     | •    | ×  | ×  | ×   | × ×   | ×    | •  |  |
|     |       |      |    |    |     |       |      |    |  |
| I   |       | U    | н  | U  | Ν   | Z     | v    | С  |  |
| •   |       | •    | ×  | •  | ×   | ×     | ×    | \$ |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |
|------------------------|
| 58                     |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 1083                   |
| Reentrant              |
| Possible               |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |
|                        |

## 1.3.5 Note

The specified clock cycle count (1083) is for 255 bytes of block data.

#### 1.3.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software MOVE2:
    - R4L: Contains, as an input argument, the number of bytes of block data.
    - R5: Contains, as an input argument, the start address of the source data memory area.
    - R6: Contains, as an input argument, the start address of the destination data memory area.
    - C flag (CCR): Determines the presence or absence of an error in the data length or address of the software MOVE2.
    - C=0: All data has been moved.
    - C=1: An input argument has an error.

b. Figure 1.4 shows an example of the software MOVE2 being executed.When the input arguments are set as shown in (1), the data is moved block by block from the source (H'FD80 to H'FD89) to the destination (H'FE80 to H'FE89) as shown in (2).



Figure 1.4 Example of Software MOVE2 Execution

- 2. Notes on usage
  - a. R4L is one byte long and should satisfy the relation  $H'01 \le R4L \le H'FF$ .
  - b. The source or destination data memory area must not extend over the end address (H'FFFF) to the start address (H'0000) as shown in figure 1.5; otherwise, the software MOVE2 fails.



#### Figure 1.5 Moving Block Data with Data Memory Area Extending over the Higher to Lower Addresses

3. Data memory

The software MOVE2 does not use the data memory.

#### 4. Example of use

Set the start address of a source, the start address of a destination, and the number of bytes to be moved in the arguments and call the software MOVE2 as a subroutine.

| WORK1 | . DATA. B | 10          |                                                                                                                                        |
|-------|-----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
|       | . ALIGN   | 2           | Places the data memory area (WORK1) at an even address.                                                                                |
| WORK2 | . DATA. W | 0           | Reserves a data memory area (2 bytes:<br>contents=H'0000) in which the user<br>program places the start address of the<br>source.      |
| WORK3 | . DATA. W | 0           | Reserves a data memory area (2 bytes:<br>contents=H'0000) in which the user<br>program places the start address of the<br>destination. |
|       | MOV. B    | @WORK1, R4L | Places the number of bytes set by the user program in the R0L argument.                                                                |
|       | MOV. W    | @WORK2, R5  | Places the start address of the source set by the user program.                                                                        |
|       | MOV. W    | @WORK3, R6  | Places the start address of the destination set by the user program.                                                                   |
|       | JSR       | @MOVE2      | Calls the software MOVE2 as a subroutine.                                                                                              |

- 5. Operation
  - a. R5 is used as the pointer that indicates the address of the source and R6 the pointer that indicates the address of the destination.
  - b. R4L is used as the counter that indicates the number of bytes moved. It is decremented each time 1-byte data is moved until it reaches 0.
  - c. When the input argument R4L is 0 or the start address of the source equals that of the destination, the C flag is set to 1 (error indicator) and the software MOVE2 terminates.

d. When the start address (B) of the destination data memory area is between the start address (A) and the end address (A + n - 1) of the source data memory area (A < B < A + n - 1; see figure 1.6), the data is moved sequentially from the higher address of the source in 16-bit absolute addressing mode.</li>



Figure 1.6 Moving Data with Overlapped Data Memory Areas

e. Except in the case of d., the EEPMOV instruction is used to move the data sequentially from the lower address.




# 1.3.8 Program List

| GRAM NAME =                                        |                         |                | *****                               |
|----------------------------------------------------|-------------------------|----------------|-------------------------------------|
| 1 2                                                | ;*                      |                |                                     |
| 3                                                  | ;* 00 - N               | 2.040          | BROCK DATA TRANSFER (MOVE2)         |
| 4                                                  | ;* 00 - N               | AME            | BROCK DATA TRANSFER (MOVEZ)         |
| *<br>5                                             |                         | ****           | *****                               |
| 6                                                  | ;*                      |                |                                     |
| 7                                                  | , * ENTRY               | : P41.         | (Byte counter)                      |
| 8                                                  | ;*                      | R5             | (Source data start address)         |
| 9                                                  | ;*                      | R6             |                                     |
| 10                                                 | ;*                      | 100            | (bebeinderen date beare addrebb)    |
| 11                                                 | ;* RETURN               | :сь            | it of CCR (C=0;TRUE , C=1;FALSE)    |
| 12                                                 | ;*                      |                |                                     |
| 13                                                 | ; * * * * * * * * * * * | ****           | *****                               |
| 14                                                 | ;                       |                |                                     |
| 15 MOVE2_co C 0000                                 | .SECTI                  | ON MOVE        | 2_code,CODE,ALIGN=2                 |
| 16                                                 | . EXPOR                 | T MOVE         | 2                                   |
| 17                                                 | ;                       |                |                                     |
| 18 MOVE2_co C 00000000                             | MOVE 2                  | .EQU \$        | ;Entry point                        |
| 19 MOVE2_co C 0000 0CC8                            |                         | R4L,R0L        |                                     |
| 20 MOVE2_co C 0002 F000                            |                         | #H'00,R0H      |                                     |
| 21 MOVE2_co C 0004 0C88                            |                         | ROL,ROL        |                                     |
| 22 MOVE2_co C 0006 472E                            | BEQ                     |                | ; If byte counter="0" then exit     |
| 23 MOVE2_co C 0008 1D56                            |                         | R5,R6          |                                     |
| 24 MOVE2_co C 000A 472A                            | BEQ                     | EXIT           | ;If R5=R6 then exit                 |
| 25 MOVE2_co C 000C 1A08                            | DEC.B                   |                |                                     |
| 26 MOVE2_co C 000E 0D52<br>27 MOVE2_co C 0010 0D63 | MOV.W                   | R5,R2<br>R6,R3 |                                     |
| 27 MOVE2_CO C 0010 0D03<br>28 MOVE2_CO C 0012 0902 | MOV.W<br>ADD.W          |                | ;Set end address of source data     |
| 29 MOVE2_co C 0012 0902                            |                         | R0,R2<br>R0,R3 | Set end address of destination data |
| 30 MOVE2_co C 0016 1D26                            |                         | R2,R6          | Set end address of destination data |
| 31 MOVE2_co C 0018 4214                            | BHI                     | EP_MOV         | Branch if R6>R2                     |
| 32 MOVE2_co C 001A 1D65                            |                         | R6,R5          |                                     |
| 33 MOVE2_co C 001C 4210                            |                         | EP_MOV         | ;Branch if R5>R6                    |
| 34 MOVE2_co C 001E                                 | B_MOV                   |                |                                     |
| 35 MOVE2_co C 001E 6824                            | MOV.B                   | @R2,R4H        | ;Load source data to R4H            |
| 36 MOVE2_co C 0020 68B4                            |                         | R4H,@R3        | ;Store R4H to destination           |
| 37 MOVE2_co C 0022 1B02                            | SUBS.W                  | #1,R2          | ;Decrement source data pointer      |
| 38 MOVE2_co C 0024 1B03                            | SUBS.W                  | #1,R3          | ;Decrement destination data pointer |
| 39 MOVE2_co C 0026 1A0C                            | DEC.B                   | R4L            |                                     |
| 40 MOVE2_co C 0028 46F4                            | BNE                     | B_MOV          | ;Branch if R4L=0                    |
| 41 MOVE2_co C 002A                                 | EX1                     |                |                                     |
| 42 MOVE2_co C 002A 06FE                            |                         | #H'FE,CCR      | ;Clear C flag of CCR                |
| 43 MOVE2_co C 002C                                 | EX2                     |                |                                     |
| 44 MOVE2_co C 002C 5470                            | RTS                     |                |                                     |
| 45 MOVE2_co C 002E                                 | EP_MOV                  |                |                                     |
| 46 MOVE2_co C 002E 7B5C598F                        | EEPMOV                  |                |                                     |
| 47 MOVE2_co C 0032 06FE                            |                         | #H'FE,CCR      | ;Clear C flag of CCR                |
| 48 MOVE2_co C 0034 40F4                            | BRA                     | EX1            |                                     |
| 49 MOVE2_co C 0036                                 | EXIT                    | #11.01 000     | 10-t - flag for f l                 |
| 50 MOVE2_co C 0036 0401                            | ORC.B<br>BRA            | #H'01,CCR      | ;Set c flag for false               |
| 51 MOVE2_co C 0038 40F2<br>52                      |                         | ±12            |                                     |
| 52                                                 | ;<br>. END              |                |                                     |
| ****TOTAL ERRORS 0                                 | . END                   |                |                                     |

# **1.4** Move Character Strings

MCU: H8/300 Series H8/300L Series

Label name: MOVES

#### 1.4.1 Function

- 1. The software MOVES moves character string block data from one data memory area to another.
- 2. When the delimiting H'00 appears in the block data, the software MOVES terminates.
- 3. The source or destination data memory area can have a free size.

#### 1.4.2 Arguments

| Descripti | ion                               | Memory area | Data length (bytes) |
|-----------|-----------------------------------|-------------|---------------------|
| Input     | Start address of source area      | R1          | 2                   |
|           | Start address of destination area | R2          | 2                   |
| Output    |                                   |             | _                   |

#### 1.4.3 Internal Register and Flag Changes

| R0 | H RO | L R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|------|------|----|----|----|----|----|----|--|
| •  | ×    | ×    | ×  | •  | •  | •  | •  | •  |  |
|    |      |      |    |    |    |    |    |    |  |
| Ι  |      | U    | н  | U  | Ν  | Z  | V  | С  |  |
| •  |      | •    | •  | •  | ×  | ×  | ×  | •  |  |

× : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |  |
|------------------------|--|
| 14                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 5116                   |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |
|                        |  |

# 1.4.5 Note

The specified clock cycle count (4598) is for 255 bytes of character string block data.

#### 1.4.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software MOVES:
    - R1: Contains, as an input argument, the start address of the source data memory area.
    - R2: Contains, as an input argument, the start address of the destination data memory area.
  - b. Figure 1.7 shows an example of the software MOVES being executed.

When the input arguments are set as shown in (1), the data is moved block by block from the source (H'A000 to H'A009) to the destination (H'B000 to H'B009) as shown in (2).



Figure 1.7 Example of Software MOVES Execution

- 2. Notes on usage
  - a. Do not set H'00 in the source block data because H'00 is used as delimiting data; otherwise, the software MOVES terminates.
  - b. Set input arguments, ensuring that the source data memory area (A) does not overlap the destination data memory area (C) as shown in figure 1.8. In the case of figure 1.8, the overlapped block data (B) at the source is destroyed.



Figure 1.8 Moving Block Data with Overlapped Data Memory Areas

3. Data memory

The software MOVES does not use the data memory.

#### 4. Example of use

Set the start address of a source and the start address of a destination in the arguments and call the software MOVES as a subroutine.



- 5. Operation
  - a. R1 is used as the pointer that indicates the address of the source and R2 the pointer that indicates the address of the destination.
  - b. The cycle of storing the data at the source in the work register (R0L) and then at the destination is repeated in 16-bit absolute addressing mode.
  - c. During the cycle, whether the R0L data is delimiting data is determined. If it is delimiting data (H'00), the software MOVES terminates; if not, moving the data continues.



# 1.4.8 Program List

| ROGRAM NAME =        |         |           |         |        |         |                                        |
|----------------------|---------|-----------|---------|--------|---------|----------------------------------------|
|                      |         |           |         |        |         |                                        |
| 1                    |         | ; * * *   | ******  | ****** | ******  | *****                                  |
| 2                    |         | ; *       |         |        |         |                                        |
| 3                    |         | ; *       | 00 - NA | ME     |         | :TRANSFER OF STRING (MOVES)            |
| 4                    |         | ; *       |         |        |         |                                        |
| 5                    |         | ;***      | ******  | ****** | ******  | ******                                 |
| 6                    |         | ;*        |         |        |         |                                        |
| 7                    |         | ;*        | ENTRY   |        | :R1     | (Source address)                       |
| 8                    |         | ;*        |         |        | R2      | (Destination address)                  |
| 9                    |         | ;*        |         |        |         |                                        |
| 10                   |         | ;*        | RETURN  |        | :NOTHIN | 1G                                     |
| 11                   |         | ;*        |         |        |         |                                        |
| 12                   |         | '         | ******  | ****** | ******* | *************                          |
| 13                   |         | ;         |         |        |         |                                        |
| 14 MOVES_co C 0000   |         |           | .SECTIO |        | -       | code,CODE,ALIGN=2                      |
| 15                   |         |           | .EXPORT |        | MOVES   |                                        |
|                      | 0000000 | ;<br>MOVE | ~       |        | BOU     | \$ ;Entry point                        |
| 18 MOVES_CO C 0000 6 |         | MOVE      |         |        | .EQU    | ; Load source address data to ROL      |
| 19 MOVES co C 0000 4 |         |           | BEO     | EXIT   |         | Branch if ROH = ROL                    |
| 20 MOVES co C 0002 4 |         |           | ~       |        |         | Store ROH to destination address       |
| 21 MOVES co C 0006 0 |         |           | ADDS.W  |        |         | ;Increment source address pointer      |
| 22 MOVES co C 0008 0 |         |           | ADDS.W  |        |         | ;Increment destination address pointer |
| 23 MOVES co C 000A 4 |         |           | BRA     | MOVES  |         | Branch always                          |
| 24                   |         | ;         |         |        |         |                                        |
| 25 MOVES_co C 000C   |         | EXIT      |         |        |         |                                        |
| 26 MOVES_co C 000C 5 | 5470    |           | RTS     |        |         |                                        |
| 27                   |         | ;         |         |        |         |                                        |
| 28                   |         |           | .END    |        |         |                                        |
| *****TOTAL ERRORS    | 0       |           |         |        |         |                                        |

# Section 2 Branch by Table

# 2.1 Branch by Table

MCU: H8/300 Series H8/300L Series

Label name: CCASE

#### 2.1.1 Function

- 1. The software CCASE determines the start address of a processing routine for a 1-word (2-byte) command.
- 2. This function is useful in decoding data input from the keyboard or performing a process appropriate for input data.

#### 2.1.2 Arguments

| Descript | ion                                 | Memory area  | Data length (bytes) |
|----------|-------------------------------------|--------------|---------------------|
| Input    | Command                             | R0           | 2                   |
|          | Start address of data table         | R1           | 2                   |
| Output   | Start address of processing routine | R4           | 2                   |
|          | Command                             | C flag (CCR) |                     |

#### 2.1.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| ×  | ×  | ×  | •  | \$ | ٠  | ×  | ٠  |  |
|    |    |    |    |    |    |    |    |  |
| 1  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | ×  | ×  | \$ |  |

 $\times$  : Unchanged

• : Indeterminate

\$ : Result

| Program memory (bytes) |  |
|------------------------|--|
| 28                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 74                     |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |
|                        |  |

# 2.1.5 Note

The specified clock cycle count (74) is for the example of figure 2.1 being executed.

#### 2.1.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software CCASE:
    - R0: Contains, as an input argument, 2-byte commands.
    - R1: Contains, as an input argument, the start address of a data table storing the command (R0) and the start address of a processing routine.
    - R4: Contains, as an output argument, the start address (2 bytes) of the processing routine for the command (R0).
    - C flag (CCR):Determines the state of data after the software CCASE has been executed.
    - C flag = 1: The data matching the command set in R0 was on the data table.
    - C flag = 0: The data matching the command set in R0 was not on the data table.

- b. Figure 2.1 shows an example of the software CCASE being executed.When the input arguments are set as shown in (1), the program refers to the data table (see figure 2.1 and places the start address of the processing routine in R4 as shown in (2).
- c. Executing the software CCASE requires a data table as shown in figure 2.1. The data table is as follows:
  - (i) The table contains data groups each consisting of 4 bytes (2 words) beginning with address H'FD80 and delimiting data H'0000 indicating the end of the table.
  - (ii) The first word of each data group (2 words) contains a command and the second word contains the start address of the processing routine in the order of the upper bytes followed by the lower bytes.



Figure 2.1 Example of Software CCASE Execution



Figure 2.2 Example of Data Table

2. Notes on usage

Do not use H'0000 as a command in the data table because H'0000 is used as delimiting data.

3. Data memory

The software CCASE does not use the data memory.

4. Example of use

Set commands and the start address of the data table in the arguments and call.the software CCASE as a subroutine.



The software CCASE merely places the start address of a processing routine in R4. Branching to a processing routine requires the following program:



- 5. Operation
  - a. R1 is used as the pointer that indicates the address of the data table.
  - b. The commands are read sequentially from the start address of the data table in register indirect addressing mode. Then the contents of each command on the data table are compared with those of each input command (R0).
  - c. When a command on the table matches R0, the start address of the processing routine placed at the address next to the command is set in R4. Then the C flag is set to 1 and the software CCASE terminates.
  - d. When the command on the data table is H'0000, the C flag is cleared to 0 and the software CCASE terminates.

#### Renesas



# 2.1.8 Program List

| *** H8/300 ASSEMBLER        | VER 1.0B ** 08/1 | 8/92 09:47:08 |                               |
|-----------------------------|------------------|---------------|-------------------------------|
| PROGRAM NAME =              |                  |               |                               |
|                             |                  |               |                               |
| 1                           |                  | ***********   | **************                |
| 2                           | ;*               |               |                               |
| 3                           | ;* 00 - N        | IAME          | :TABLE BRANCH (CCASE)         |
| 4                           | ;*               |               |                               |
| 5                           |                  | *******       | ***********                   |
| 6                           | ;*               |               |                               |
| 7                           | ;* ENTRY         |               |                               |
| 8                           | ;*               | Rl            | DATA TABLE START ADDRESS      |
| 9                           | ;*               |               |                               |
| 10                          | ;* RETURN        |               | MODULE START ADDRESS          |
| 11                          | ;*<br>;*         | C bi          | t of CCR C=1;TRUE , C=0;FALSE |
| 12                          |                  | ***********   | *****                         |
| 13                          |                  |               |                               |
| 14<br>15 CCASE CO C 0000    | ;                | ON COLOR      | code, CODE, ALIGN=2           |
| 16                          | .EXPOR           |               |                               |
| 17                          | ;                | CCADE         |                               |
| 18 CCASE CO C 00000000      | CCASE            | .EQU \$       | Entry point                   |
| 19 CCASE co C 0000 79060004 |                  | #H'0004,R6    |                               |
| 20 CCASE co C 0004          | LBL              |               |                               |
| 21 CCASE co C 0004 6912     | MOV.W            | @R1,R2        |                               |
| 22 CCASE co C 0006 4710     | BEQ              | FALSE         | ;If table "END" then exit     |
| 23 CCASE CO C 0008 1D02     | CMP.W            | R0,R2         |                               |
| 24 CCASE_co C 000A 4704     | BEQ              | TRUE          | Branch if command find        |
| 25 CCASE_co C 000C 0961     | ADD.W            | R6,R1         | ;Increment table address      |
| 26 CCASE_co C 000E 40F4     | BRA              | LBL           | Branch always                 |
| 27 CCASE_co C 0010          | TRUE             |               |                               |
| 28 CCASE_co C 0010 6F140002 | MOV.W            | @(H'2,R1),R4  | ;Load module start address    |
| 29 CCASE_co C 0014 0401     | ORC              | #H'01,CCR     | ;Set C flag for true          |
| 30 CCASE_co C 0016          | EX1              |               |                               |
| 31 CCASE_co C 0016 5470     | RTS              |               |                               |
| 32 CCASE_co C 0018          | FALSE            |               |                               |
| 33 CCASE_co C 0018 06FE     | ANDC             | #H'FE,CCR     | ;Clear C flag for false       |
| 34 CCASE_co C 001A 40FA     | BRA              | EX1           |                               |
| 35                          | ;                |               |                               |
| 36                          | . END            |               |                               |
| ****TOTAL ERRORS 0          |                  |               |                               |
| *****TOTAL WARNINGS 0       |                  |               |                               |

# Section 3 ASCII CODE PROCESSING

# 3.1 Change ASCII Code from Lowercase to Uppercase

MCU: H8/300 Series H8/300L Series

Label name: TPR

## 3.1.1 Function

- 1. The software TPR changes a lowercase ASCII code to a corresponding uppercase ASCII code.
- 2. All data used with the software TPR is ASCII code.

#### 3.1.2 Arguments

| Descript | ion                  | Memory area | Data length (bytes) |
|----------|----------------------|-------------|---------------------|
| Input    | Lowercase ASCII code | R0L         | 1                   |
| Output   | Uppercase ASCII code | R0L         | 1                   |

### 3.1.3 Internal Register and Flag Changes

| R0H | H ROI | L R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|-----|-------|------|----|----|----|----|----|----|--|
| ×   | \$    | •    | •  | •  | •  | •  | •  | •  |  |
|     |       |      |    |    |    |    |    |    |  |
| I   |       | U    | н  | U  | Ν  | Z  | V  | С  |  |
| •   |       | •    | ×  | •  | ×  | ×  | ×  | ×  |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |  |
|------------------------|--|
| 14                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 24                     |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |

#### 3.1.5 Description

- 1. Details of functions
  - a. The following argument is used with the software TPR:

R0L: Contains, as an input argument, a lowercase ASCII code. After execution of the software TPR, the corresponding uppercase ASCII code is placed in R0L.

b. Figure 3.1 shows an example of the software TPR being executed. When the lowercase ASCII code 'a' (H'61) is set as shown in (1), it is converted to the uppercase ASCII code 'A' (H'41), which then is placed in R0L as shown in (2).



Figure 3.1 Example of Software TPR Execution

2. Notes on usage

R0L must contain a lowercase ASCII code. If any other code is placed in R0L, the input data is retained in R0L.

3. Data memory

The software TPR does not use the data memory.

#### 4. Example of use

Set a lowercase ASCII code in the input argument and call the software TPR as a subroutine.



- 5. Operation
  - a. compare instruction (CMP.B) is used to determine whether the input data set in R0L is a lowercase ASCII code.
  - b. H'20 is subtracted from the lowercase ASCII code to obtain a corresponding uppercase ASCII code.
  - c. If the input data is not a lowercase ASCII code, the program retains the input data and terminates processing.



# 3.1.7 Program List

| OGRAM NAME =                                       |      |              |                  |        |                                 |
|----------------------------------------------------|------|--------------|------------------|--------|---------------------------------|
| 1                                                  | ;*** | ******       | ******           | *****  | *****                           |
| 2                                                  | ;*   |              |                  |        |                                 |
| 3                                                  | ;*   | 00 - NA      | ME               |        | CHANGE ASCII CODE LOWERCASE     |
| 4                                                  | ;*   |              |                  |        | TO UPPERCASE (TPR)              |
| 5                                                  | ;*   |              |                  |        |                                 |
| 6                                                  | ;*** | ******       | ******           | ****** | *******                         |
| 7                                                  | ;*   |              |                  |        |                                 |
| 8                                                  | ; *  | ENTRY        |                  | :ROL   | (ASCII CODE LOWERCASE)          |
| 9                                                  | ;*   |              |                  |        |                                 |
| 10                                                 | ;*   | RETURN       |                  | :R0L   | (ASCII CODE UPPERCASE)          |
| 11                                                 | ;*   |              |                  |        |                                 |
| 12                                                 | ;*** | ******       | *******          | ****** | ******                          |
| 13                                                 | ;    |              |                  |        |                                 |
| 14 TPR_code C 0000                                 |      |              |                  | _      | ode,CODE,ALIGN=2                |
| 15                                                 |      | .EXPORI      |                  | TPR    |                                 |
| 16                                                 | ;    |              |                  |        |                                 |
| 17 TPR_code C 00000000                             | TPR  | .EQU         |                  |        | ;Entry point                    |
| 18 TPR_code C 0000 A861<br>19 TPR code C 0002 4508 |      |              | #H'61,R(         |        |                                 |
| 19 TPR_code C 0002 4508<br>20 TPR code C 0004 A87A |      | BCS          | EXIT<br>#H'7A,R( |        | ;Branch if ROL<#H'60            |
| 21 TPR code C 0006 4204                            |      | CMP.B<br>BHT |                  |        | ;Branch if ROL>#H'7B            |
| 22 TPR code C 0008 F020                            |      |              | #H'20,R0         |        | /Branch II Kol>mi /B            |
| 23 TPR code C 0008 1020                            |      |              | ROH,ROL          |        | ;Lowercase - #H'20 -> Uppercase |
| 24 TPR code C 000C                                 | EXIT |              | 1011/1012        |        | Deweleabe an is a oppercase     |
| 25 TPR code C 000C 5470                            |      | RTS          |                  |        |                                 |
| 26                                                 | ;    |              |                  |        |                                 |
| 27                                                 |      | .END         |                  |        |                                 |
| ****TOTAL ERRORS 0                                 |      |              |                  |        |                                 |

# 3.2 Change an ASCII Code to a 1-Byte Hexadecimal Number

MCU: H8/300 Series H8/300L Series

Label name: NIBBLE

# 3.2.1 Function

- 1. The software NIBBLE changes an ASCII code ('0' to '9' and 'A' to 'F') to a corresponding 1byte hexadecimal number.
- 2. All data used with the software NIBBLE is ASCII code.

#### 3.2.2 Arguments

| Descript       | ion                       | Memory area  | Data length (bytes) |
|----------------|---------------------------|--------------|---------------------|
| Input          | ASCII code                | R0L          | 1                   |
| Output         | 1-byte hexadecimal number | R0L          | 1                   |
| Convert or not |                           | C flag (CCR) | ï                   |

#### 3.2.3 Internal Register and Flag Changes

| R0ł | H ROI | L R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|-----|-------|------|----|----|----|----|----|----|--|
| •   | \$    | •    | ٠  | •  | •  | •  | •  | •  |  |
|     |       |      |    |    |    |    |    |    |  |
| I   |       | U    | Н  | U  | Ν  | Z  | V  | С  |  |
| •   |       | •    | ×  | •  | ×  | ×  | ×  | ×  |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |  |
|------------------------|--|
| 24                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 38                     |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |

#### 3.2.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software NIBBLE:
    - R0L: Contains, as an input argument, an ASCII code. After execution of the software NIBBLE, the corresponding 1-byte hexadecimal number is placed in R0L.
    - C flag (CCR): Holds, as an output argument, the state of ASCII code after execution of the software NIBBLE.
    - C flag = 1: The input ASCII code is any other than '0' to '9' or 'A' to 'F'.
    - C flag = 0: The input ASCII code is '0' to '9' or 'A' to 'F'.
  - b. Figure 3.2 shows an example of the software NIBBLE being executed. When the input argument is set as shown in (1), a corresponding 1-byte hexadecimal number (H'0F) is placed in R0L as shown in (2).



Figure 3.2 Example of Software NIBBLE Execution

2. Notes on usage

If any data other than ASCII code '0' to '9' or 'A' to 'F' is set in R0L, the data is destroyed after execution of the software NIBBLE.

3. Data memory

The software NIBBLE does not use the data memory.

#### 4. Example of use

Set an ASCII code in the input argument and call the software NIBBLE as a subroutine.



- 5. Operation
  - a. On the basis of the status of the C flag showing the result of operations, the software NIBBLE determines whether the data set in R0L falls in the '0' to 'F' range of the ASCII code table ([ \_\_\_\_\_\_] ] in table 3.1).
  - b. The software further perform operations to delete the ':' to '@' range ([ ] in table 3.1).
  - c. If the input data is outside the '0' to '9' and 'A' to 'F' ranges, 1 is set in the C flag in the processes a. and b..

| MSD    | 0   | 1               | 2   | 3   | 4   | 5            | 6     | 7   |
|--------|-----|-----------------|-----|-----|-----|--------------|-------|-----|
|        | 000 | 001             | 010 | 011 | 100 | 101          | 1 1 0 | 111 |
| 0 0000 | NUL | DLE             | SP  | 0   | @   | Р            | `     | р   |
| 1 0001 | SOH | DC1             | !   | 1   | A   | Q            | а     | q   |
| 2 0010 | STX | DC <sub>2</sub> | "   | 2   | в   | R            | b     | r   |
| 3 0011 | ЕТХ | DC₃             | #   | 3   | с   | S            | с     | s   |
| 4 0100 | EOT | DC4             | \$  | 4   | D   | т            | d     | t   |
| 5 0101 | ENG | NAK             | %   | 5   | E   | U            | е     | u   |
| 6 0110 | ACK | SYN             | &   | 6   | F   | V            | f     | v   |
| 7 0111 | BEL | ETB             | '   | 7   | G   | W            | g     | w   |
| 8 1000 | BS  | CAN             | (   | 8   | н   | х            | h     | x   |
| 9 1001 | НТ  | EM              | )   | 9   | I   | Y            | i     | у   |
| A 1010 | LF  | SUB             | *   |     | J   | z            | j     | z   |
| B 1011 | VT  | ESC             | +   | ;   | к   | ſ            | k     | {   |
| C 1100 | FF  | FS              | ,   | <   | L   | ١            | I     | I   |
| D 1101 | CR  | GS              | -   | =   | м   | J            | m     | }   |
| E 1110 | SO  | RS              | •   | >   | N   | <b>↑</b>     | n     | ~   |
| F 1111 | SI  | VS              | /   | ?   | 0   | $\leftarrow$ | о     | DEL |

#### Table 3.1 ASCII Code Table



#### 3.2.7 Program List

\*\*\* H8/300 ASSEMBLER VER 1.0B \*\* 08/18/92 20:08:15 PROGRAM NAME = 1 2 ;\* ;\* 00 - NAME CHANGE 1 BYTE ASCII CODE 3 4 ;\* TO 4 BIT HEXAGON (NIBBLE) 5 ;\* 6 7 ;\* 8 ;\* ENTRY ROL (1 BYTE ASCII CODE) 9 ;\* 10 ;\* RETURN :ROL (4 BIT HEXADECIMAL) 11 ;\* C flag of CCR (C=0;FALSE , C=1;TRUE) 12 ;\* 13 14 ; 15 NIBBLE\_c C 0000 .SECTION NIBBLE\_code,CODE,ALIGN=2 16 .EXPORT NIBBLE 17 ; 18 NIBBLE\_C C 0000 NIBBLE 19 NIBBLE\_C C 0000 F030 MOV.B #H'30,R0H 20 NIBBLE\_C C 0002 1808 SUB.B ROH,ROL ;ROL - #H'30 -> ROL 21 NIBBLE\_C C 0004 4510 BCS EXIT ;Branch if ROL<'0' 22 NIBBLE\_C C 0006 88E9 ADD.B #H'E9,ROL 23 NIBBLE\_C C 0008 450C BCS EXIT ;Branch if ROL<'F' 24 NIBBLE\_C C 000A 8806 ADD.B #H'06,ROL 25 NIBBLE\_C C 000C 4504 BCS LBL Branch if ROL<=H'FF 26 NIBBLE\_C C 000E 8807 ADD.B #H'07,ROL 27 NIBBLE\_c C 0010 4504 BCS EXIT ;Branch if ROL<=H'FF 28 NIBBLE\_C C 0012 LBL 29 NIBBLE\_C C 0012 880A ADD.B #H'0A,R0L ;Change R0L to ASCII CODE ANDC #H'FE,CCR ;Clear C flag of CCR 30 NIBBLE\_c C 0014 06FE 31 NIBBLE\_c C 0016 EXIT 32 NIBBLE\_C C 0016 5470 RTS 33 . 34 .END \*\*\*\*\*TOTAL ERRORS 0 \*\*\*\*\*TOTAL WARNINGS 0

# 3.3 Change an 8-Bit Binary Number to a 2-Byte ASCII Code

MCU: H8/300 Series H8/300L Series

Label name: COBYTE

# 3.3.1 Function

1. The software COBYTE changes an 8-bit binary number to a corresponding 2-byte ASCII code.

2. All data used with the software COBYTE is ASCII code.

#### 3.3.2 Arguments

| Descript | ion                 | Memory area | Data length (bytes) |
|----------|---------------------|-------------|---------------------|
| Input    | 8-bit binary number | R0L         | 1                   |
| Output   | 2-byte ASCII code   | R1          | 2                   |

#### 3.3.3 Internal Register and Flag Changes

| R0ł | H ROL | _ R1 | R2H | R2L | R3 | R4 | R5 | R6 | R7 |  |
|-----|-------|------|-----|-----|----|----|----|----|----|--|
| ×   | Х     | \$   | •   | ×   | •  | •  | ٠  | •  | •  |  |
|     |       |      |     |     |    |    |    |    |    |  |
| I   |       | U    | н   |     | U  | Ν  | Z  | V  | С  |  |
| •   |       | •    | ×   |     | •  | ×  | ×  | ×  | ×  |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result



#### 3.3.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software COBYTE:
    - R0L: Contains, as an input argument, an 8-bit binary number to be changed to a corresponding ASCII code.
    - R1: Contains, as an output argument, 1-byte ASCII code data in the upper 4 bits and the lower 4 bits each of the 8-bit binary number.
  - b. Figure 8-1 shows an example of the software COBYTE being executed. When the input argument is set as shown in á@, 2-byte ASCII code data is placed in R1 as shown in áA.



Figure 3.3 Example of Software COBYTE Execution

2. Notes on usage

The 8-bit binary number set in R0L is destroyed after execution of the software COBYTE.

3. Data memory

The software COBYTE does not use the data memory.

4. Example of use

Set an 8-bit binary number in the input argument and call the software COBYTE as a subroutine.

| WORK1 · | .RES. B           | 1           | <br>Reserves a data memory area in which the user program places an 8-bit binary number.                 |
|---------|-------------------|-------------|----------------------------------------------------------------------------------------------------------|
|         | .ALIGN<br>.RES. W | 1           | <br>Reserves a data memory area in which the user program places a corresponding 2-<br>byte ASCII code.  |
|         | MOV. B            | @WORK1, R0L | <br>Places the 8-bit binary number set by the user program in R0L.                                       |
|         | JSR (             | @COBYTE     | <br>Calls the software COBYTE as a subroutine.                                                           |
|         | MOV. W            | R1, @WORK2  | <br>Places the 2-byte ASCII code set in the output argument in the data memory area of the user program. |
|         |                   |             |                                                                                                          |

- 5. Operation
  - a. The 8-bit binary number is separated into two bit groups, the upper 4 bits and the lower 4 bits.
  - b. A compare instruction is used to determine whether the data (the upper 4 bits + the lower 4 bits) is in the H'00 to H'09 range ([ ] in table 3.2) or in the H'0A to H'0F range ([ ] in table 3.2). H'30 is added to the data if it falls in the H'00 to H'09 range and H'37 to the data if it falls in the H'0A to H'0F range for change to a corresponding ASCII code.

| MSD    | 0   | 1   | 2   | 3   | 4   | 5            | 6     | 7   |
|--------|-----|-----|-----|-----|-----|--------------|-------|-----|
|        | 000 | 001 | 010 | 011 | 100 | 101          | 1 1 0 | 111 |
| 0 0000 | NUL | DLE | SP  | 0   | @   | Р            | `     | р   |
| 1 0001 | SOH | DC1 | !   | 1   | A   | Q            | а     | q   |
| 2 0010 | STX | DC2 | "   | 2   | в   | R            | b     | r   |
| 3 0011 | ЕТХ | DC3 | #   | 3   | с   | s            | с     | s   |
| 4 0100 | EOT | DC4 | \$  | 4   | D   | т            | d     | t   |
| 5 0101 | ENG | NAK | %   | 5   | E   | U            | е     | u   |
| 6 0110 | ACK | SYN | &   | 6   | F   | V            | f     | v   |
| 7 0111 | BEL | ЕТВ | ,   | 7   | G   | w            | g     | w   |
| 8 1000 | BS  | CAN | (   | 8   | н   | x            | h     | x   |
| 9 1001 | нт  | EM  | )   | 9   | I   | Y            | i     | у   |
| A 1010 | LF  | SUB | *   | :   | J   | z            | j     | z   |
| B 1011 | VT  | ESC | +   | ;   | к   | ſ            | k     | {   |
| C 1100 | FF  | FS  | ,   | <   | L   | ١            | I     | I   |
| D 1101 | CR  | GS  | -   | =   | М   | J            | m     | }   |
| E 1110 | so  | RS  | •   | >   | N   | ↑            | n     | ~   |
| F 1111 | SI  | VS  | /   | ?   | 0   | $\leftarrow$ | о     | DEL |

### Table 3.2ASCII Code Table


# 3.3.7 Program List

| GRAM NAME =                              |         |            |         |         |        |                                         |
|------------------------------------------|---------|------------|---------|---------|--------|-----------------------------------------|
|                                          |         |            | ******  |         | ****** |                                         |
| 1                                        |         | ;***<br>;* | *****   | ******* | *****  | *************************************** |
| 3                                        |         |            | 00 - NA |         |        | CHANGE 1 BYTE HEXADECIMAL               |
| 4                                        |         | ;*         | 00 - M  | AME     |        | TO 2 BYTE ASCII CODE (COBYTE)           |
| 5                                        |         | ;*         |         |         |        | 10 2 BILL ASCII CODE (COBILE)           |
| 6                                        |         |            | ******  | ******* | ****** | *****                                   |
| 7                                        |         | ;*         |         |         |        |                                         |
| 8                                        |         |            | ENTRY   |         | POT    | (1 BYTE HEXADECIMAL)                    |
| 9                                        |         | ;*         | 200100  |         | .101   | (1 bitb mmbbctime)                      |
| 10                                       |         | ;*         | RETURN  |         | :R1    | (2 BYTE ASCII CODE)                     |
| 11                                       |         | ;*         |         |         |        | , ,                                     |
| 12                                       |         |            | ******  | ******  | *****  | *****                                   |
| 13                                       |         | ;          |         |         |        |                                         |
| 14 COBYTE_c C 0000                       |         |            | .SECTIO | ON      | COBYTI | E_code,CODE,ALIGN=2                     |
| 15                                       |         |            | .EXPOR  |         | COBYTI |                                         |
| 16                                       |         | ;          |         |         |        |                                         |
| 17 COBYTE_c C                            | 0000000 | COBY       | TE      | .EQU    | \$     | ;Entry Point                            |
| 18 COBYTE_C C 0000                       | 0C80    |            | MOV.B   | ROL,ROH |        |                                         |
| 19                                       |         | ;          |         |         |        |                                         |
| 20 COBYTE_c C 0002                       | 1100    |            | SHLR    | ROH     |        |                                         |
| 21 COBYTE_c C 0004                       | 1100    |            | SHLR    | ROH     |        |                                         |
| 22 COBYTE_c C 0006                       | 1100    |            | SHLR    | ROH     |        |                                         |
| 23 COBYTE_C C 0008                       | 1100    |            | SHLR    | ROH     |        | ;Select upper 4 bit hexadecimal(ROH)    |
| 24                                       |         | ;          |         |         |        |                                         |
| 25 COBYTE_C C 000A                       | E80F    |            | AND.B   | #H'OF,R | OL     | ;Select lower 4 bit hexadecimal(ROL)    |
| 26                                       |         | ;          |         |         |        |                                         |
| 27 COBYTE_c C 000C                       |         |            |         | ROH,R2L |        |                                         |
| 28 COBYTE_C C 000E                       |         |            | BSR     | CONIB   |        | Branch subroutine CONIB                 |
| 29 COBYTE_C C 0010                       | 0CA1    |            | MOV.B   | R2L,R1H |        | ;Set 1st ASCII code to R1H              |
| 30                                       |         | ;          |         |         |        |                                         |
| 31 COBYTE_c C 0012                       |         |            |         | ROL,R2L |        |                                         |
| 32 COBYTE_c C 0014                       |         |            |         | CONIB   |        | Branch subroutine CONIB                 |
| 33 COBYTE_c C 0016                       | UCA9    |            | MOV.B   | R2L,R1L |        | ;Set 2nd ASCII code to R1L              |
| 34<br>35 GODVER - G 0010                 | 5 4 7 0 | ;          | RTS     |         |        |                                         |
| 35 COBYTE_C C 0018<br>36                 | 54/U    |            |         |         |        |                                         |
|                                          |         |            |         |         |        |                                         |
| 37 COBYTE_C C 001A<br>38 COBYTE_C C 001A |         | CONI       |         | #H'0A,R | 21.    | ;Change R2L to ASCII code               |
| 38 COBYTE_C C 001A<br>39 COBYTE c C 001C |         |            | BCC     | HH'UA,R |        | Branch if R2L ASCII "A"-"F"             |
| 40 COBYTE_C C 001C                       |         |            |         | #H'30,R |        | Reshape R2L ASCII "0"- "9"              |
| 40 COBITE_C C 001E<br>41 COBYTE_C C 0020 |         |            | RTS     |         |        | ACCOUNTER AND ADDELL 0 9                |
| 42 COBYTE_C C 0022                       |         | LBL        |         |         |        |                                         |
| 42 COBITE_C C 0022<br>43 COBYTE_C C 0022 |         | 100        | ADD. B  | #H'37,R | 21.    |                                         |
| 44 COBYTE_C C 0022                       |         |            | RTS     |         |        |                                         |
| 45                                       |         | ;          |         |         |        |                                         |
| 46                                       |         |            | .END    |         |        |                                         |
|                                          | 0       |            |         |         |        |                                         |

# Section 4 BIT PROCESSING

# 4.1 Count the Number of Logic 1 Bits in 8-Bit Data (HCNT)

MCU: H8/300 Series H8/300L Series

Label name: HCNT

# 4.1.1 Function

- 1. The software HCNT counts how many logic-1 bits exist in 8 bits of data.
- 2. This function is useful in performing parity check.

### 4.1.2 Arguments

| Descript | ion                    | Memory area | Data length (bytes) |
|----------|------------------------|-------------|---------------------|
| Input    | 8-bit data             | R0L         | 1                   |
| Output   | Number of logic-1 bits | R1L         | 1                   |

### 4.1.3 Internal Register and Flag Changes

| R0H | I ROL | _ R1H | R1L | R2 | R3 | R4 | R5 | R6 | R7 |  |
|-----|-------|-------|-----|----|----|----|----|----|----|--|
| •   | ×     | ×     | \$  | •  | •  | •  | •  | •  | •  |  |
|     |       |       |     |    |    |    |    |    |    |  |
| I   |       | U     |     | н  | U  | Ν  | Z  | V  | С  |  |
| •   |       | •     |     | •  | •  | ×  | ×  | ×  | ×  |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program men | nory (bytes) |
|-------------|--------------|
| 18          | 3            |
| Data memo   | ory (bytes)  |
| 0           |              |
| Stack (I    | bytes)       |
| 0           |              |
| Clock cyc   | le count     |
| 16          | 2            |
| Reent       | trant        |
| Poss        | ible         |
| Reloca      | ation        |
| Poss        | ible         |
| Interr      | rupt         |
| Poss        | ible         |

### 4.1.5 Notes

The specified clock cycle count (162) is for 8-bit data = "FF".

### 4.1.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software HCNT:
    - R0L: Contains, as an input argument, 8-bit data that may have logic-1 bits to be counted.
    - R1: Contains, as an output argument, the number of logic-1 bits that have been found and counted in the 8-bit data.
  - b. Figure 4.1 shows an example of the software HCNT being executed. When the input argument is set as shown in (1), the number of logic-1 bits that have been found in the 8-bit data is placed in R1L as shown in (2).
  - c. The contents of ROL are retained after execution of the software HCNT.



Figure 4.1 Example of Software HCNT Execution

2. Notes on usage

To count the logic-0 bits, complement the logic 1 in R0L (by using the NOT instruction) before executing the software HCNT.

3. Data memory

The software HCNT does not use the data memory.

4. Example of use

Set 8-bit data in the input argument and call the software HCNT as a subroutine.



- 5. Operation
  - a. R1H is used as the counter that indicates an 8-bit data rotation count.
  - b. The ROTXL instruction is used to set data (R0L) bit by bit in the C flag.
  - c. R1L is incremented when the C flag is 1. No operation occurs when the C flag is 0.
  - d. R1H is decremented each time the b.-c. process is performed. The process is repeated until R1H reaches 0.



# 4.1.8 Program List

| OGRAM NAME =                |         |          |         |          |                              |
|-----------------------------|---------|----------|---------|----------|------------------------------|
| 1                           | : * * * | *******  | ******  | *******  |                              |
| 2                           | ;*      |          |         |          |                              |
| 3                           |         | 00 - NAI | ME.     |          | :HIGH LEVEL BIT COUNT (HCNT) |
| 4                           | ;*      | 00 111   |         |          | and high bir cooki (hear)    |
| 5                           | ;***    | ******   | ******  | ******   | *******                      |
| 6                           | ;*      |          |         |          |                              |
| 7                           | ;*      | ENTRY    |         | :R0L     | (8 BIT DATA)                 |
| 8                           | ;*      |          |         |          |                              |
| 9                           | ;*      | RETURN   |         | :R1L     | (HIGH LEVEL BIT COUNTER)     |
| 10                          | ;*      |          |         |          |                              |
| 11                          | ;***    | *****    | ******  | ******   | ******                       |
| 12                          | ;       |          |         |          |                              |
| 13 HCNT_cod C 0000          |         | .SECTIO  | N       | HCNT_co  | de,CODE,ALIGN=2              |
| 14                          |         | .EXPORT  |         | HCNT     |                              |
| 15                          | ;       |          |         |          |                              |
| 16 HCNT_cod C 00000000      | HCNT    | .EQU     | \$      | ;Entry p | point                        |
| 17 HCNT_cod C 0000 79010900 |         | MOV.W    | #H'0900 | ,R1      |                              |
| 18 HCNT_cod C 0004          | LBL     |          |         |          |                              |
| 19 HCNT_cod C 0004 1A01     |         | DEC      | RlH     |          |                              |
| 20 HCNT_cod C 0006 4708     |         | BEQ      | EXIT    | ;If R1H  | = 0 then exit                |
| 21 HCNT_cod C 0008 1288     |         | ROTL     | ROL     |          |                              |
| 22 HCNT_cod C 000A 44F8     |         | BCC      | LBL     | ;Branch  | if C flag = 0                |
| 23 HCNT_cod C 000C 0A09     |         | INC      | R1L     |          |                              |
| 24 HCNT_cod C 000E 40F4     |         | BRA      | LBL     | ;Branch  | always                       |
| 25 HCNT_cod C 0010          | EXIT    |          |         |          |                              |
| 26 HCNT_cod C 0010 5470     |         | RTS      |         |          |                              |
| 27                          | ;       |          |         |          |                              |
| 28                          |         | .END     |         |          |                              |

# 4.2 Shift 16-Bit Binary to Right (SHR)

MCU: H8/300 Series H8/300L Series

Label name: SHR

### 4.2.1 Function

- 1. The software SHR shifts a 16-bit binary number to the right.
- 2. Shift count: 1 to 16.
- 3 This function is useful in multiplying a 16-bit binary number by 2-n (n=shift count).

### 4.2.2 Arguments

| Descript | ion                               | Memory area | Data length (bytes) |
|----------|-----------------------------------|-------------|---------------------|
| Input    | 16-bit binary to be shifted right | R0          | 2                   |
|          | Shift count                       | R1L         | 1                   |
| Output   | Result of shift                   | R0          | 2                   |

# 4.2.3 Internal Register and Flag Changes

| R0 | R1H R1L | R2 | R3 | R4 | R5 | R6 | R7 |
|----|---------|----|----|----|----|----|----|
| \$ | • ×     | •  | •  | •  | •  | •  | •  |
|    |         |    |    |    |    |    |    |
| I  | U       | н  | U  | Ν  | Z  | V  | С  |
| •  | •       | •  | •  | ×  | ×  | ×  | ×  |

 $\times$  : Unchanged

Indeterminate

t : Result

| Program memory (bytes) |
|------------------------|
| 10                     |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 168                    |
| Reentrant              |
| Possible               |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |
|                        |

# 4.2.5 Notes

The specified clock cycle count (162) is for shifting right 16 bits.

### 4.2.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software SHR:
    - R0: Contains, as an input argument, a 16-bit binary number to be right-shifted. The result of shift is placed in R0 after execution of the software SHR.
    - R1L: Contains, as an input argument, the right-shift count of a 16-bit binary number.
  - b. Figure 4.2 shows an example of the software SHR being executed. When the arguments are set as shown in (1), the 16-bit binary number is shifted right as shown in (2). 0's are placed in the remaining upper bits.



Figure 4.2 Example of Software SHR Execution

2. Notes on usage

R1L must satisfy the condition H'01≤R1L≤H'0F; otherwise, R0 contains all 0's.

3. Data memory

The software SHR does not use the data memory.

4. Example of use

Set a 16-bit binary number and a shift count in the input arguments and call the software SHR as a subroutine.

| WORK1 | .RES. W | 1           |   | Reserves a data memory area in which the user program places the 16-bit binary number. |
|-------|---------|-------------|---|----------------------------------------------------------------------------------------|
| WORK2 | .RES. B | 1           |   | Reserves a data memory area in which the user program places the 16-bit binary number. |
|       | MOV. W  | @WORK1, R0  |   | Places the 16-bit binary number set by the user program in the input argument.         |
|       | MOV. B  | @WORK2, R1L |   | Places the shift count set by the user program in the input argument.                  |
|       | JSR     | @SHR        | ( | Calls the software SHR as a subroutine.                                                |
|       |         |             |   |                                                                                        |

- 5. Operation
  - a. The upper 8 bits of a 16-bit binary number is shifted right and the least significant bit in the C flag. Then the lower 8 bits are rotated right. This causes the least significant bit (in the C flag) moves to the most significant bit of the lower 8 bits.



### Figure 4.3 Example of Register Changes

b. R1L is used as the counter that indicates the shift count.

R1L is decremented each time the process a. is executed. This process is repeated until R1L reaches 0.



# 4.2.8 Program List

| OGRAM NAME =                             |      |          |         |            |          |                           |
|------------------------------------------|------|----------|---------|------------|----------|---------------------------|
| 1                                        |      | ;***     | ******  | ******     | ******   | *****                     |
| 2                                        |      | ;*       |         |            |          |                           |
| 3                                        |      | ;*       | 00 - N. | AME        | SHIFT    | OF 16 BIT DATA (SHR)      |
| 4                                        |      | ;*       |         |            |          |                           |
| 5                                        |      | ;***     | ******  | ******     | ******   | ************              |
| 6                                        |      | ;*       |         |            |          |                           |
| 7                                        |      | ;*       | ENTRY   |            |          | (16 BIT BINARY DATA)      |
| 8                                        |      | ;*       |         |            | R1L      | (SHIFT COUNTER)           |
| 9                                        |      | ;*       |         |            |          |                           |
| 10                                       |      | ;*       | RETURN  |            | :R0      | (16 BIT BINARY DATA)      |
| 11                                       |      | ;*       |         |            |          |                           |
| 12                                       |      | ,        | ******  | ******     | *******  | ***********               |
| 13                                       |      | ;        |         |            |          |                           |
| 14 SHR_code C 0000                       |      |          |         |            | -        | de,CODE,ALIGN=2           |
| 15                                       |      |          | .EXPOR  | т          | SHR      |                           |
| 16                                       |      | ;        |         |            |          |                           |
| 17 SHR_code C                            |      | SHR      | . EQU   |            | ;Entry   | -                         |
| 18 SHR_code C 0000<br>19 SHR code C 0002 |      |          | SHLR    | ROH<br>ROL | ;snift   | 16 bit binary 1 bit right |
| 20 SHR_code C 0002                       |      |          | DEC     |            | Dearer   | ment Shift counter        |
| 21 SHR code C 0004                       |      |          | BNE     |            |          | h if not R1L=0            |
| 21 SHR_code C 0000<br>22 SHR code C 0008 |      |          | RTS     | Siik       | , branc. | I II NOC KIN-0            |
| 22 SHR_COUE C 0008                       | 5110 | ;        | 1110    |            |          |                           |
| 24                                       |      | <i>,</i> | . END   |            |          |                           |
| *****TOTAL ERRORS                        | 0    |          |         |            |          |                           |

# Section 5 COUNTER

# 5.1 4-Digit Decimal Counter

MCU: H8/300 Series H8/300L Series

Label name: DECNT

# 5.1.1 Function

- 1. The software DCNT increments a 4-digit binary-coded decimal (BCD) counter by 1.
- 2. This function is useful in counting interrupts (external interrupts, timer interrupts, etc.).

### 5.1.2 Arguments

| Descript | ion                 | Memory area  | Data length (bytes) |  |
|----------|---------------------|--------------|---------------------|--|
| Input    | —                   | —            | —                   |  |
| Output   | 4-digit BCD counter | DCNTR (RAM)  | 2                   |  |
|          | Counter overflow    | C flag (CCR) | 1                   |  |

#### 5.1.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| ×  | •  | •  | •  | •  | •  | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I. | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| ٠  | •  | ×  | •  | ×  | ×  | ×  | \$ |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |
|------------------------|
| 18                     |
| Data memory (bytes)    |
| 2                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 28                     |
| Reentrant              |
| Impossible             |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |
|                        |

# 5.1.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software DECNT:
    - DCNT: Used as a 4-digit BCD counter that is incremented by 1 each time the software DECNT is executed.
    - C flag (CCR): Indicates the state of the counter after execution of the software DECNT.
    - C flag = 1: The counter overflowed. (See figure 5.2.)
    - C flag = 0: The counter was incremented normally.
  - b. Figure 5.1 shows an example of the software DECNT being executed. When the software DECNT is executed, the 4-digit BCD counter is incremented as shown in (2).

#### 2. Notes on usage

Figure 5.2 Example of Software DECNT Execution



Figure 5.1 Example of Software DECNT Execution



Figure 5.2 Example of Software DECNT Execution

#### 3. Data memory

| Label name | Bit 7 Bit | 0 |                                       |  |
|------------|-----------|---|---------------------------------------|--|
| DCNTR      | Upper     |   | Containe e 1 digit PCD equator value  |  |
| DCINTR     | Lower     |   | Contains a 4-digit BCD counter value. |  |
|            |           |   |                                       |  |



# 5. Operation

- a. The software DECNT uses data memory (DCNTR) as a 4-digit BCD counter.
- b. Each time the software DECNT is executed as a subroutine, DCNTR is incremented to repeat decimal correction.



### 5.1.7 Program List

\*\*\* H8/300 ASSEMBLER VER 1.0B \*\* 08/18/92 09:52:01 PROGRAM NAME = ;\*\*\*\*\* 1 2 ;\* ;\* 00-NAME :4 FIGURE BCD COUNTER(DECNT) 3 4 ;\* ;\*\*\*\*\* 5 ;\* 6 :NOTHING 7 ;\* ENTRY 8 ;\* 9 ;\* RETURNS :DCNTR (BCD COUNTER) 10 ;\* C flag OF CCR (C=0 IS TRUE/C=1 IS OVER FLOW) 11 ;\* ;\*\*\*\*\* 12 13 ; .SECTION DECNT\_code,CODE,ALIGN=2 14 DECNT\_co C 0000 15 .EXPORT DECNT 16 ; 17 DECNT\_CO C 00000000 DECNT .EQU \$ ;Entry point MOV.W @DCNTR,R0 ;Load DCNTR to R0 ADD.B #H'01,R0L ;R0L + #H'01 -> R0L 18 DECNT\_CO C 0000 6B000000 19 DECNT\_co C 0004 8801 20 DECNT\_co C 0006 0F08 DAA ROL ;Decimal adjust ROL ADDX.B #H'00,ROH ;BeCIMAI adjust KOL ADDX.B #H'00,ROH ;BeCIMAI adjust KOH DAA ROH ;Decimal adjust ROH MOV.W R0,@DCNTR ;Store R0 to DCNTR 21 DECNT\_CO C 0008 9000 22 DECNT\_CO C 000A 0F00 23 DECNT\_CO C 000C 6B800000 24 DECNT\_CO C 0010 5470 RTS 25 ; 26 ;-----27 ; .SECTION DATA\_data,DATA,ALIGN=2 .EXPORT DCNTR 28 DATA\_dat D 0000 29 30 ; DCNTR .DATA.W H'0000 31 DATA\_dat D 0000 0000 32 ; 33 ------34 ; 35 .END \*\*\*\*\*TOTAL ERRORS 0

\*\*\*\*\*TOTAL WARNINGS 0

# Section 6 COMPARISO

# 6.1 Compare 32-Bit Binary Numbers

MCU: H8/300 Series H8/300L Series

Label name: COMP

#### 6.1.1 Function

- 1. The software COMP compares two 32-bit binary numbers and sets the result (>, =, <) in the C and Z flags (CCR).
- 2. All arguments are unsigned integers.

#### 6.1.2 Arguments

| Descript | lion                 | Memory area          | Data length (bytes) |
|----------|----------------------|----------------------|---------------------|
| Input    | Comparand            | R0, R1               | 4                   |
|          | Source number        | R2, R3               | 4                   |
| Output   | Result of comparison | C flag, Z flag (CCR) |                     |

#### 6.1.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| •  | •  | •  | •  | •  | •  | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | \$ | ×  | \$ |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |
|------------------------|
| 8                      |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 16                     |
| Reentrant              |
| Possible               |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |

# 6.1.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software COMP:
    - R0, R1: Contain a 32-bit binary comparand as input arguments. (See figure 6.1.)
    - R2, R3: Contain a source 32-bit binary number as input arguments. (See figure 6.1.)

| R0 | Upper |
|----|-------|
| R1 | Lower |
| R2 | Upper |
| R3 | Lower |

32-bit binary comparand

32-bit binary number (source)



b. Table 6.1 shows an example of the software COMP being executed.

The C and Z flags are set according to the input arguments.

| Input argu | iments | Output ar | guments |      |        |        |
|------------|--------|-----------|---------|------|--------|--------|
| Comparan   | d      | Large     | Sign    |      | CCR    |        |
| R0         | R1     | Small     | R2      | R3   | C flag | Z flag |
| F67D       | 2001   | <         | 2200    | 4001 | 0      | 0      |
| 2010       | 2020   | =         | 2010    | 2020 | 0      | 1      |
| 4001       | F000   | >         | A000    | BB00 | 1      | 0      |

# Table 6.1 Example of Software COMP Execution

c. The input arguments are stored even after execution of the software COMP.

### 2. Notes on usage

When not using upper bits, set 0's in them; otherwise, no correct result of comparison can be obtained because comparison is made on the numbers including indeterminate data set in the upper bits.

3. Data memory

The software COMP does not use the data memory.

4. Example of use

Set a source binary number and a comparand in the input arguments and call the software COMP as a subroutine.



- 5. Operation
  - a. Comparison of two or more words can be done by performing a series of 1-word comparisons.
  - b. The output arguments are the C and Z flags after execution of the compare instruction (CMP.W).
  - c. The upper words are compared by using the word compare instruction (CMP.W). If the upper words are not equal, the software COMP terminates. If the upper words are equal, then the lower words are compared.



# 6.1.7 Program List

| 1                       | ;*** | ******          | ****** | ******   | *****                        |
|-------------------------|------|-----------------|--------|----------|------------------------------|
| 2                       | ;*   |                 |        |          |                              |
| 3                       | ;*   | 00 - NZ         | ME     |          | :32 BIT COMPARISON (COMP)    |
| 4                       | ;*   |                 |        |          |                              |
| 5                       | ;*** | * * * * * * * * | ****** | ******   | ******                       |
| 6                       | ;*   |                 |        |          |                              |
| 7                       | ;*   | ENTRY           |        | :R0      | (COMPARAND DATA HIGH)        |
| 8                       | ;*   |                 |        | Rl       | (COMPARAND DATA LOW)         |
| 9                       | ;*   |                 |        | R2       | (COMPARATIVE DATA HIGH)      |
| 10                      | ;*   |                 |        | R3       | (COMPARATIVE DATA LOW)       |
| 11                      | ;*   |                 |        |          |                              |
| 12                      | ;*   | RETURNS         | 3      | :C flag  | & Z flag (COMPARISON RESULT) |
| 13                      | ;*   |                 |        |          |                              |
| 14                      | ;*** | ******          | ****** | ******   | ************                 |
| 15                      | ;    |                 |        |          |                              |
| 16 COMP_cod C 0000      |      | .SECTIO         | DN     | COMP_cod | de,CODE,ALIGN=2              |
| 17                      |      | .EXPORT         | 2      | COMP     |                              |
| 18                      | ;    |                 |        |          |                              |
| 19 COMP_cod C 0000000   | COMP | .EQU            | \$     |          | ;Entry point                 |
| 20 COMP_cod C 0000 1D20 |      | CMP.W           |        |          |                              |
| 21 COMP_cod C 0002 4602 |      | BNE             | LBL    |          | ;Branch if Z=0               |
| 22 COMP_cod C 0004 1D31 |      | CMP.W           | R3,R1  |          |                              |
| 23 COMP_cod C 0006      | LBL  |                 |        |          |                              |
| 24 COMP_cod C 0006 5470 |      | RTS             |        |          |                              |
| 25                      | ;    |                 |        |          |                              |
| 26                      |      | .END            |        |          |                              |

# Section 7 ARITHMETIC OPERATION

# 7.1 Addition of 32-Bit Binary Numbers

MCU: H8/300 Series H8/300L Series

Label name: ADD1

#### 7.1.1 Function

- 1. The software ADD1 adds a 32-bit binary number to another 32-bit binary number and places the result (a 32-bit binary number) in a general-purpose register.
- 2. The arguments used with the software ADD1 are unsigned integers.
- 3. All data is manipulated on general-purpose registers.

#### 7.1.2 Arguments

| Descript     | lion               | Memory area  | Data length (bytes) |
|--------------|--------------------|--------------|---------------------|
| Input Augend |                    | R0, R1       | 4                   |
|              | Addend             | R2, R3       | 4                   |
| Output       | Result of addition | RO, R1       | 4                   |
|              | Carry              | C flag (CCR) |                     |

#### 7.1.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| \$ | \$ | •  | •  | •  | •  | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | ×  | ×  | \$ |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |
|------------------------|
| 8                      |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 14                     |
| Reentrant              |
| Possible               |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |
|                        |

# 7.1.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software ADD1:
    - R0, R1: Contain a 32-bit binary augend as an input argument. The result of addition is placed in these registers after execution of the software ADD1.
    - R2, R3: Contain a 32-bit binary addend as an input argument.
    - C flag (CCR): Determines the presence or absence of a carry as an output argument after execution of the software ADD1.
    - C flag = 1: A carry occurred in the result. (See figure 7.1)
    - C flag = 0: No carry occurred in the result.



Figure 7.1 Example of Addition with a Carry

b. Figure 7.2 shows an example of the software ADD1 being executed. When the input arguments are set as shown in (1), the result of addition is placed in R0 and R1 as shown in (2).



Figure 7.2 Example of Software ADD1 Execution

2. Notes on usage

When upper bits are not used (see figure 7.3), set 0's in them; otherwise, no correct result can be obtained because addition is done on the numbers including indeterminate data.



Figure 7.3 Example of Addition with Upper Bits Unused

- b. After execution of the software ADD1, the augend is destroyed because the result is placed in R0 and R1. If the augend is necessary after software ADD1 execution, save it on memory.
- 3. Data memory

The software ADD1 does not use the data memory.

#### 4. Example of use

Set an augend and an addend in the input arguments and call the software ADD1 as a subroutine.



- 5. Operation
  - a. Addition of 3 bytes or more can be done by repeating 1-byte additions.
  - b. A 1-word add instruction (ADD.W), which does not involve the state of the C flag, is used to add the lower word shown by equation 1. The C flag is set if a carry occurs after execution of the equation.

 $R1+R3 \rightarrow R1$  ..... equation 1

c. A 1-byte add instruction (ADDX.B), which involves the state of the C flag, is used twice to add the upper word shown by equation 2.

 $\left. \begin{array}{c} R0L + R2L + C \rightarrow R0L \\ R0H + R2H + C \rightarrow R0H \end{array} \right\} \quad \mbox{.....} equation 1$ 

The C flag indicates a carry that may occur in the result of addition of the lower word executed in b. and the lower bytes of the upper word.

# 7.1.6 Flowchart



# 7.1.7 Program List

| *** H8/300 ASSEMBLER    | VER 1.0B ** 08/18/92 09:53:09            |         |
|-------------------------|------------------------------------------|---------|
| PROGRAM NAME =          |                                          |         |
|                         |                                          |         |
| 1                       | ; * * * * * * * * * * * * * * * * * * *  | ******  |
| 2                       | ;*                                       |         |
| 3                       | ;* 00-NAME :32 BIT ADDITION (ADD1)       |         |
| 4                       | ;*                                       |         |
| 5                       | ;**************************************  | ******  |
| 6                       | ;*                                       |         |
| 7                       | ;* ENTRY :R0,R1 (SUMMAND)                |         |
| 8                       | ;* R2,R3 (ADDEND)                        |         |
| 9                       | ;*                                       |         |
| 10                      | ;* RETURNS :R0,R1 (SUM)                  |         |
| 11                      | ;* C flag OF CCR (C=0;TRUE , C=1;OVERFLC | JW )    |
| 12                      | ;*                                       |         |
| 13                      | ; * * * * * * * * * * * * * * * * * * *  | ******* |
| 14                      | ;                                        |         |
| 15 ADD1_cod C 0000      | .SECTION ADD1_code, CODE, ALIGN=2        |         |
| 16                      | .EXPORT ADD1                             |         |
| 17                      | ;                                        |         |
| 18 ADD1_cod C 00000000  | ADD1 .EQU \$ ;Entry point                |         |
| 19 ADD1_cod C 0000 0931 | ADD.W R3,R1 ;Adjust lower word           |         |
| 20 ADD1_cod C 0002 0EA8 | ADDX.B R2L,R0L ;Adjust upper word        |         |
| 21 ADD1_cod C 0004 0E20 | ADDX.B R2H,R0H ;                         |         |
| 22 ADD1_cod C 0006 5470 | RTS                                      |         |
| 23                      | ;                                        |         |
| 24                      | .END                                     |         |
| *****TOTAL ERRORS 0     |                                          |         |
| ****TOTAL WARNINGS 0    |                                          |         |

# 7.2 Subtraction of 32-Bit Binary Numbers

MCU: H8/300 Series H8/300L Series

Label name: SUB1

### 7.2.1 Function

- 1. The software SUB1 subtracts a 32-bit binary number from another 32-bit binary number and places the result (a 32-bit binary number) in a general-purpose register.
- 2. The arguments used with the software SUB1 are unsigned integers.
- 3. All data is manipulated on general-purpose registers.

#### 7.2.2 Arguments

| Descript | tion                  | Memory area  | Data length (bytes)<br>4 |  |  |
|----------|-----------------------|--------------|--------------------------|--|--|
| Input    | Minuend               | R0, R1       |                          |  |  |
|          | Subtrahend            | R2, R3       | 4                        |  |  |
| Output   | Result of subtraction | R0, R1       | 4                        |  |  |
|          | Borrow                | C flag (CCR) |                          |  |  |

### 7.2.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| \$ | \$ | ×  | ×  | •  | •  | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | ×  | ×  | \$ |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |
|------------------------|
| 8                      |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 14                     |
| Reentrant              |
| Possible               |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |
|                        |

### 7.2.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software SUB1:
    - R0, R1: Contain a 32-bit binary minuend as an input argument. The result of subtraction is placed in these registers after execution of the software SUB1.
    - R2, R3: Contain a 32-bit binary subtrahend as an input argument.
    - C flag (CCR): Determines the presence or absence of a borrow as an output argument after execution of the software SUB1.
    - C flag = 1: A borrow occurred in the result. (See figure 7.4)
    - C flag = 0: No borrow occurred in the result.



Figure 7.4 Example of Subtraction with a Borrow

b. Figure 7.5 shows an example of the software SUB1 being executed. When the input arguments are set as shown in (1), the result of subtraction is placed in R0 and R1 as shown in (2).



Figure 7.5 Example of Software SUB1 Execution
- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.6), set 0's in them; otherwise, no correct result can be obtained because subtraction is done on the numbers including indeterminate data.



Figure 7.6 Example of Subtraction with Upper Bits Unused

- b. After execution of the software SUB1, the minuend is destroyed because the result is contained in R0 and R1. If the minuend is necessary after software SUB1 execution, save it on memory.
- 3. Data memory

The software SUB1 does not use the data memory.

#### 4. Example of use

Set a minuend and a subtrahend in the input arguments and call the software SUB1 as a subroutine.

| [      |                       |                              |   |                                                                                                          |
|--------|-----------------------|------------------------------|---|----------------------------------------------------------------------------------------------------------|
| WORK1  | .RES. W               | 2                            |   | Reserves a data memory area in which the user program places a 32-bit binary minuend.                    |
| WORK2  | .RES. W               | 2                            |   | Reserves a data memory area in which the<br>user program places a 32-bit binary<br>subtrahend.           |
| WORK3  | .RES. W               | 2                            |   | Reserves a data memory area for storage of the result of subtraction.                                    |
|        | i<br>Mov. W<br>Mov. W | @WORK1, R0<br>@WORK1+2, R1 ∫ |   | Places in the input arguments (R0 and R1)<br>the 32-bit binary minuend set by the user<br>program.       |
|        | MOV. W<br>MOV. W      | e,                           |   | Places in the input arguments (R2 and R3)<br>the 32-bit binary subtrahend set by the<br>user program.    |
|        | JSR                   | @SUB1                        | ( | Calls the software SUB1 as a subroutine.                                                                 |
|        | BCS                   | BORROW                       |   | Branches to the borrow processing routine if a borrow has occurred in the result.                        |
|        |                       | R0, @WORK3<br>R1, @WORK3+2   |   | Places the result (set in the output<br>arguments (R0 and R1) in the data<br>memory of the user program. |
| BORROW | Borrow                | processing routine           |   |                                                                                                          |
|        |                       |                              | _ |                                                                                                          |

#### 5. Operation

- a. Subtraction of 3 bytes or more can be done by repeating 1-byte subtractions.
- b. A 1-word subtract instruction (SUB.W), which does not involve the state of the C flag, is used to subtract the lower word shown by equation 1. The C flag is set if a borrow occurs after execution of the equation.

 $R1-R3 \rightarrow R1$  ..... equation 1

c. A 1-byte subtract instruction (SUBX.B), which involves the state of the C flag, is used twice to subtract the upper word shown by equation 2.

 $\left. \begin{array}{c} R0L-R2L-C \rightarrow R0 \\ R0H-R2H-C \rightarrow R0 \end{array} \right\} \cdots \cdots equation \ 2$ 

The C flag indicates a borrow that may occur in the result of subtraction of the lower word executed in b. and the lower bytes of the upper word.

#### 7.2.6 Flowchart



# 7.2.7 Program List

\*\*\* H8/300 ASSEMBLER VER 1.0B \*\* 08/18/92 09:53:37 PROGRAM NAME = ;\*\*\*\*\* 1 2 ;\* 3 ;\* 00 - NAME :32 BIT BINARY SUBTRUCTION (SUB1) 4 ;\* 5 6 ;\* 7 ;\* ENTRY :R0,R1 (MINUEND) 8 ;\* R2,R3 (SUBTRAHEND) 9 ;\* ;\* RETURNS :R0,R1 (RESULT) 10 11 ;\* C flag OF CCR (C=0;TRUE,C=1;BORROW) 12 ;\* 13 14 ; .SECTION SUB1\_code,CODE,ALIGN=2 .EXPORT SUB1 15 SUB1\_cod C 0000 16 17 ; SUB1.EQU \$ ;Entry point SUB.W R3,R1 ;Subtruct lower word SUBX.B R2L,R0L ;Subtruct upper word 18 SUB1\_cod C 00000000 19 SUB1\_cod C 0000 1931 20 SUB1\_cod C 0002 1EA8 21 SUB1\_cod C 0004 1E20 SUBX.B R2H,ROH 22 ; 23 SUB1\_cod C 0006 5470 RTS 24 ; 25 .END \*\*\*\*\*TOTAL ERRORS 0 \*\*\*\*\*TOTAL WARNINGS 0

# 7.3 Multiplication of 16-Bit Binary Numbers

MCU: H8/300 Series H8/300L Series

Label name: MUL

### 7.3.1 Function

- 1. The software MUL multiplies a 16-bit binary number by another 16-bit binary number and places the result (a 32-bit binary number) in a general-purpose register.
- 2. The arguments used with the software MUL are unsigned integers.
- 3. All data is manipulated on general-purpose registers.

#### 7.3.2 Arguments

| Description |                          | Memory area | Data length (bytes) |
|-------------|--------------------------|-------------|---------------------|
| Input       | Multiplicand             | R1          | 2                   |
|             | Multiplier               | R0          | 2                   |
| Output      | Result of multiplication | R1, R2      | 4                   |

### 7.3.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| ×  | \$ | \$ | ×  | ×  | ×  | ×  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | ×  | ×  | ×  |  |

× : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |
|------------------------|
| 32                     |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 86                     |
| Reentrant              |
| Possible               |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |
|                        |

### 7.3.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software MUL:
    - R0: Contains a 16-bit binary multiplier as an input argument.
    - R1: Contains a 16-bit binary multiplicand as an input argument. The upper 2 bytes of the result are placed in this register after execution of the software MUL.
    - R2: Contains the lower 2 bytes of the result as an output argument.



# Figure 7.7 Input Argument Setting

b. Figure 7.8 shows an example of the software MUL being executed. When the input arguments are set as shown in (1), the result of multiplication is placed in R1 and R2 as shown in (2).



#### Figure 7.8 Example of Software MUL Execution

c. Table 7.1 lists the results of multiplication with 0's placed in the input arguments.

#### Table 7.1 Results of Multiplication with 0's Placed in Input Arguments

|                 | Output argument  |
|-----------------|------------------|
| Multiplier (R0) | Product (R1, R2) |
| H'0000          | H'0000000        |
| H'****          | H'0000000        |
| H'0000          | H'0000000        |
|                 | H'0000<br>H'**** |

Note: H'\*\*\*\* is a hexadecimal number.

#### 2. Notes on usage

a. When upper bits are not used (see figure 7.9), set 0's in them; otherwise, no correct result can be obtained because multiplication is made on the numbers including indeterminate data.



Figure 7.9 Example of Multiplication with Upper Bits Unused

b. After execution of the software MUL, the multiplicand is destroyed because the result is placed in R1. If the multiplicand is necessary after software MUL execution, save it on memory.

3. Data memory

The software MUL does not use the data memory.

4. Example of use

Г

Set a multiplicand and a multiplier in the input arguments and call the software MUL as a subroutine.

| WORK1 | .RES. W     | 1                            | Reserves a data memory area in which the user program places a 16-bit binary multiplicand.                        |
|-------|-------------|------------------------------|-------------------------------------------------------------------------------------------------------------------|
| WORK2 | .RES. W     | 1                            | Reserves a data memory area in which the user program places a 16-bit binary multiplier.                          |
| WORK3 | .RES. W     | 2                            | Reserves a data memory area for storage of the result of multiplication (a 32-bit binary number).                 |
|       | :<br>MOV. W | @WORK1, R1                   | Places in the input arguments (R1) the 16-<br>bit binary multiplicand set by the user<br>program.                 |
|       | MOV. W      | @WORK2, R0                   | Places in the input arguments (R0) the 16-<br>bit binary multiplier set by the user<br>program.                   |
|       | JSR         | @MUL                         | $\cdots \cdots \left( \begin{array}{c} Calls the software MUL as a subroutine. \end{array} \right)$               |
|       |             | R1, @WORK3<br>R2, @WORK3+2 } | Places the result (the 32-bit binary number, set in the output arguments) in the data memory of the user program. |

#### 5. Operation

a. Figure 7.10 shows an example of multiplying 16-bit binary numbers.





Multiplication of 16-bit binary numbers consists of two stages as shown in figure 7.10: (3) finding two partial products with the MULXU instruction and adding the two results (6).

- b. The program runs in the following steps:
  - (i) The MULXU instruction is used to obtain the result of the multiplicand (lower bytes) × the multiplier (lower bytes) ((1) in figure 7.10) and the result of the multiplicand (upper bytes) × the multiplier (lower bytes) ((2) in figure 7.10). Then these two results are added to obtain a partial product, that is, the multiplicand x the multiplier (lower bytes) ((3) in figure 7.10).
  - (ii) The MULXU instruction is used to obtain another partial product, that is, the multiplicand x the multiplier (upper bytes) ((6) in figure 7.10).

(iii) The two partial products (i) and (ii) are added to obtain the final product ((4) in figure 7.10).

### 7.3.6 Flowchart



# 7.3.7 Program List

| 1                                                  | ;***     | ******  | ******    | ******                               |
|----------------------------------------------------|----------|---------|-----------|--------------------------------------|
| 2                                                  | ;*       |         |           |                                      |
| 3                                                  |          | 00 - NA | ME        | :16 BIT MULTIPLICATION (MUL)         |
| 4                                                  | ;*       |         |           |                                      |
| 5                                                  |          | ******  | ********* | *******                              |
| 6<br>7                                             | ;*<br>;* | TANTON  |           | 0 (MULTIPLIER)                       |
| 8                                                  | ;*       | LNIKI   |           | (MULTIPLICAND)                       |
| 9                                                  | ;*       |         | r.        | (MOLITPLICAND)                       |
| 10                                                 |          | RETURNS | : :R      | (UPPER WORD OF RESULT)               |
| 11                                                 | ;*       |         |           | 2 (LOWER WORD OF RESULT)             |
| 12                                                 | ;*       |         |           |                                      |
| 13                                                 | ;***     | ******  | *****     | *****                                |
| 14                                                 | ;        |         |           |                                      |
| 15 MUL_code C 0000                                 |          | .SECTIO | N MU      | L_code,CODE,ALIGN=2                  |
| 16                                                 |          | .EXPORT | MU MU     | IL .                                 |
| 17                                                 | ;        |         |           |                                      |
| 18 MUL_code C 00000000                             | MUL      | .EQU    | \$        | ;Entry point                         |
| 19 MUL_code C 0000 0C9A                            |          | MOV.B   | R1L,R2L   | ;R1L -> R2L                          |
| 20 MUL_code C 0002 0C1C                            |          |         | R1H,R4L   | ;R1H -> R4L                          |
| 21 MUL_code C 0004 0C9B                            |          | MOV.B   | R1L,R3L   | ;RlL -> R3L                          |
| 22 MUL_code C 0006 0C19                            |          | MOV.B   | R1H,R1L   | /RIH -> RIL                          |
| 23                                                 | ;        |         |           |                                      |
| 24 MUL_code C 0008 5082                            |          |         | ROL,R2    | ;ROL * R2L -> R2                     |
| 25 MUL_code C 000A 5084                            |          | MULXU   |           | ;ROL * R4L -> R4                     |
| 26 MUL_code C 000C 5003<br>27 MUL_code C 000E 5001 |          | MULXU   | ROH,R3    | ;ROH * R3L -> R3<br>;ROH * R1L -> R1 |
| 28 28                                              | ;        | MULLAU  | ROH,R1    | /ROH " RIL -> RI                     |
| 29 MUL_code C 0010 08C2                            | ,        | ADD B   | R4L,R2H   | ;R2H + R4L -> R2H                    |
| 30 MUL_code C 0012 9400                            |          |         | #H'00,R4H |                                      |
| 31 MUL_code C 0014 0839                            |          |         | R3H,R1L   |                                      |
| 32 MUL_code C 0016 9100                            |          |         | #H'00,R1H |                                      |
| 33                                                 | ;        |         |           |                                      |
| 34 MUL_code C 0018 08B2                            |          | ADD.B   | R3L,R2H   | ;R3L + R2H -> R2H                    |
| 35 MUL_code C 001A 0E49                            |          | ADDX.B  | R4H,R1L   | ;R4H + R1L + C -> R1L                |
| 36 MUL_code C 001C 9100                            |          | ADDX.B  | #H'00,R1H | ;R1H + #H'00 + C -> R1H              |
| 37                                                 | ;        |         |           |                                      |
| 38 MUL_code C 001E 5470                            |          | RTS     |           |                                      |
| 39                                                 | ;        |         |           |                                      |
| 40<br>*****TOTAL ERRORS 0                          |          | .END    |           |                                      |

# 7.4 Division of 32-Bit Binary Numbers

MCU: H8/300 Series H8/300L Series

Label name: DIV

### 7.4.1 Function

- 1. The software DIV divides a 32-bit binary number by another 32-bit binary number and places the result (a 32-bit binary number) in a general-purpose register.
- 2. The arguments used with the software DIV are unsigned integers.
- 3. All data is manipulated on general-purpose registers.

#### 7.4.2 Arguments

| Description |                                | Memory area  | Data length (bytes) |
|-------------|--------------------------------|--------------|---------------------|
| Input       | Dividend                       | R0, R1       | 4                   |
|             | Divisor                        | R2, R3       | 4                   |
| Output      | Result of division (Quotient)  | R0, R1       | 4                   |
|             | Result of division (Remainder) | R4, R5       | 4                   |
|             | Errors                         | Z flag (CCR) |                     |

### 7.4.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| \$ | \$ | ×  | ×  | \$ | \$ | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | ×  | •  | ×  | ×  | \$ | ×  | ×  |  |

 $\times$  : Unchanged

Indeterminate

t : Result

| Г | Program memory (bytes) |  |
|---|------------------------|--|
|   | 58                     |  |
|   | Data memory (bytes)    |  |
|   | 0                      |  |
|   | Stack (bytes)          |  |
|   | 0                      |  |
|   | Clock cycle count      |  |
|   | 1374                   |  |
|   | Reentrant              |  |
|   | Possible               |  |
|   | Relocation             |  |
|   | Possible               |  |
| Γ | Interrupt              |  |
|   | Possible               |  |
|   |                        |  |

# 7.4.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software DIV:
    - R0: Contains the upper 2 bytes of a 32-bit binary dividend. The upper 2 bytes of the result of division (quotient) are placed in this register after execution of the software DIV.
    - R1: Contains the lower 2 bytes of the 32-bit binary dividend. The lower 2 bytes of the result of division (quotient) are placed in this register after execution of the software DIV.
    - R2: Contains the upper 2 bytes of a 32-bit binary divisor as an input argument.
    - R3: Contains the lower 2 bytes of the 32-bit binary divisor as an input argument.
    - R4: The upper 2 bytes of the result of division (remainder) are placed in this register as an output argument.
    - R5: The lower 2 bytes of the result of division (remainder) are placed in this register as an output argument.

- Z flag (CCR): Determines the presence or absence of an error (division by 0) with the software DIV as an output argument.
- Z flag = 1: The divisor was 0.

Z flag = 0: The divisor was not 0.



### Figure 7.11 Input Argument Setting

b. Figure 7.12 shows an example of the software DIV being executed. When the input arguments are set as shown in (1), the result of division is placed as shown in (2).



# Figure 7.12 Example of Software DIV Execution

c. Table 7.2 lists the results of division with 0's placed in the input arguments.

#### Table 7.2 Results of Division with 0's Placed in Input Arguments

| Input argument    |                  | Output argument   |                    |           |
|-------------------|------------------|-------------------|--------------------|-----------|
| Dividend (R0, R1) | Divisor (R2, R3) | Quotient (R0, R1) | Remainder (R4, R5) | Error (Z) |
| H'******          | H'00000000       | H'*****           | H'00000000         | 1         |
| H'00000000        | H'*****          | H'00000000        | H'00000000         | 0         |
| H'00000000        | H'00000000       | H'00000000        | H'00000000         | 1         |
| NI / 1114444 · 1  |                  |                   |                    |           |

Note: H'\*\*\*\* is a hexadecimal number.

2. Notes on usage

When upper bits are not used (see figure 7.13), set 0's in them; otherwise, no correct result can be obtained because division is done on the numbers including indeterminate data.





- b. After execution of the software DIV, the dividend is destroyed because the quotient is placed in R0 and R1. If the dividend is necessary after software DIV execution, save it on memory.
- 3. Data memory

The software DIV does not use the data memory.

4. Example of use

Set a dividend and a divisor in the input arguments and call the software DIV as a subroutine.



- 5. Operation
  - a. A binary division can be done by performing a series of subtractions. figure 7.14 shows an example of division (H'0 ÷ DH'03).



Figure 7.14 Example of Software DIV Execution (H'0D ÷ H'03)

This example indicates that the quotient and remainder are obtained by repeating a process of subtracting the dividend from the divisor. More specifically, the dividend is taken out bit by bit from the upper byte and the divisor is subtracted from the sum of the data and the previous result of subtraction.

- b. The program runs in the following steps:
  - (i) A shift count (D732) is set.
  - (ii) The dividend is 1 bit shifted to the left to place the most significant bit c. in the least significant bit of the remainder.
  - (iii) The divisor is subtracted from the remainder.

If the result is positive, "1" is placed in the least significant bit of the dividend  $((1) \rightarrow (2) \rightarrow (3)$  in figure 7.14). If the result is negative, "0" is placed in the least significant bit of the dividend and the divisor is added to the result to return to the state before the subtraction.  $((4) \rightarrow (5) \rightarrow (6)$  in figure 7.14).

- (iv) The shift count (set in step (i)) is decremented.
- (v) Steps (ii) to (iv) are repeated until the shift count reaches H'00.





# 7.4.7 Program List

| *** H8/300 ASSEMBLER        | VER 1.0B ** | 08/18/92 09:  | 58:57   |                                 |
|-----------------------------|-------------|---------------|---------|---------------------------------|
| PROGRAM NAME =              |             |               |         |                                 |
| 1                           | ;****       | *********     | ******  | ***************                 |
| 2                           | ;*          |               |         |                                 |
| 3                           | ;* (        | 00 - NAME     |         | :32 BIT DIVISION (DIV)          |
| 4                           | ;*          |               |         |                                 |
| 5                           | ;****       | *****         | ******  | *****                           |
| 6                           | ;*          |               |         |                                 |
| 7                           | :* 1        | ENTRY         | · Þ ()  | (UPPER WORD DIVIDEND)           |
| 8                           | ;*          |               |         | (LOWER WORD DIVIDEND)           |
|                             | ;*          |               |         |                                 |
| 9                           |             |               | R2      | (UPPER WORD DIVISOR)            |
| 10                          | ;*          |               | R3      | (LOWER WORD DIVISOR)            |
| 11                          | ;*          |               |         |                                 |
| 12                          | ;* I        | RETURNS       | :R0     | (UPPER WORD QUOTIENT)           |
| 13                          | ;*          |               | Rl      | (LOWER WORD QUOTIENT)           |
| 14                          | ;*          |               | R2      | (UPPER WORD RESIDUE)            |
| 15                          | ;*          |               | R3      | (LOWER WORD RESIDUE)            |
| 16                          | ;*          |               | Z flag  | OF CCR (Z=0;TRUE , Z=1;FALSE)   |
| 17                          | ;*          |               |         |                                 |
| 18                          |             | *****         | ******* | *****                           |
|                             |             |               |         |                                 |
| 19                          | ;           |               |         |                                 |
| 20 DIV_code C 0000          |             | SECTION       |         | le,CODE,ALIGN=2                 |
| 21                          |             | .EXPORT       | DIV     |                                 |
| 22                          | 7           |               |         |                                 |
| 23 DIV_code C 00000000      | DIV         | .EQU \$       |         | ;Entry point                    |
| 24 DIV_code C 0000 79040000 | P           | MOV.W #H'000  | 0,R4    | ;Clear R4                       |
| 25 DIV_code C 0004 0D45     | 1           | MOV.W R4,R5   |         | ;Clear R5                       |
| 26 DIV_code C 0006 1D42     |             | CMP.W R4,R2   |         |                                 |
| 27 DIV_code C 0008 4604     |             | BNE LBL1      |         | ;Branch if Z flag = $0$         |
|                             |             | CMP.W R4,R3   |         | /branch if 2 flag = 0           |
| 28 DIV_code C 000A 1D43     |             |               |         |                                 |
| 29 DIV_code C 000C 472A     |             | BEQ EXIT      |         | ;Branch if Z flag = 1 then exit |
| 30 DIV_code C 000E          | LBL1        |               |         |                                 |
| 31 DIV_code C 000E FE20     | 1           | MOV.B #D'32,  | R6L     | ;Set byte counter               |
| 32 DIV_code C 0010          | LBL2        |               |         |                                 |
| 33 DIV_code C 0010 1009     | 5           | SHLL R1L      |         | ;Shift dividend 1 bit left      |
| 34 DIV_code C 0012 1201     | I           | ROTXL R1H     |         |                                 |
| 35 DIV_code C 0014 1208     | I           | ROTXL ROL     |         |                                 |
| 36 DIV_code C 0016 1200     | I           | ROTXL ROH     |         |                                 |
| 37                          | ;           |               |         |                                 |
| 38 DIV_code C 0018 120D     |             | ROTXL R5L     |         |                                 |
|                             |             | ROTXL R5H     |         |                                 |
| 39 DIV_code C 001A 1205     |             |               |         |                                 |
| 40 DIV_code C 001C 120C     |             | ROTXL R4L     |         |                                 |
| 41 DIV_code C 001E 1204     |             | ROTXL R4H     |         |                                 |
| 42                          | ;           |               |         |                                 |
| 43 DIV_code C 0020 7009     | I           | BSET #0,R1L   |         | ;Bit set bit 0 of R1L           |
| 44                          | ;           |               |         |                                 |
| 45 DIV_code C 0022 1935     | 5           | SUB.W R3,R5   |         | /R5 - R3 -> R5                  |
| 46 DIV_code C 0024 1EAC     | 5           | SUBX.B R2L,R4 | L       | ;R4L - R2L - C -> R4L           |
| 47 DIV code C 0026 1E24     |             | SUBX.B R2H,R4 |         | ;R4H - R2H - C -> R4H           |
| 48                          | ;           | ,             |         |                                 |
| 49 DIV_code C 0028 4408     |             | BCC LBL3      |         | Branch if C=0                   |
|                             |             |               |         | /R3 + R5 -> R3                  |
| 50 DIV_code C 002A 0935     |             | ADD.W R3,R5   |         |                                 |
| 51 DIV_code C 002C 0EAC     |             | ADDX.B R2L,R4 |         | ;R2L + R4L + C -> R4L           |
| 52 DIV_code C 002E 0E24     |             | ADDX.B R2H,R4 | Н       | ;R2H + R4H + C -> R4H           |
| 53                          | ;           |               |         |                                 |
| 54 DIV_code C 0030 7209     | I           | BCLR #0,R1L   |         | ;Bit clear bit 0 of R1L         |
| 55 DIV_code C 0032          | LBL3        |               |         |                                 |
| 56 DIV_code C 0032 1A0E     | I           | DEC.B R6L     |         | ;Decrement R6L                  |
| 57 DIV_code C 0034 46DA     | I           | BNE LBL2      |         | ;Branch if Z=0                  |
| 58 DIV_code C 0036 06FB     |             |               |         | Clear Z flag                    |
| 59 DIV_code C 0038          | EXIT        |               | ,,      |                                 |
| 60 DIV_code C 0038 5470     |             | RTS           |         |                                 |
|                             |             |               |         |                                 |
| 61                          | ;           | -             |         |                                 |
| 62                          |             | .END          |         |                                 |
| *****TOTAL ERRORS 0         |             |               |         |                                 |

\*\*\*\*\*TOTAL WARNINGS 0

# 7.5 Addition of Multiple-Precision Binary Numbers

MCU: H8/300 Series H8/300L Series

Label name: ADD2

# 7.5.1 Function

- 1. The software ADD2 adds a multiple-precision binary number to another multiple-precision binary number and places the result in the data memory where the augend was placed.
- 2. The arguments used with the software ADD2 are unsigned integers, each being up to 255 bytes long.

### 7.5.2 Arguments

| Description |                                         | Memory area  | Data length (bytes) |  |
|-------------|-----------------------------------------|--------------|---------------------|--|
| Input       | Augend and addend byte length           | R0L          | 1                   |  |
|             | Start address of augend                 | R3           | 2                   |  |
|             | Start address of addend                 | R4           | 2                   |  |
| Output      | Start address of the result of addition | R3           | 2                   |  |
|             | Error                                   | Z flag (CCR) |                     |  |
| _           | Carry                                   | C flag (CCR) |                     |  |

# 7.5.3 Internal Register and Flag Changes

| R1 | R2 | R3         | R4                    | R5                 | R6                     | R7                                                                                                      |                                                                                                                             |
|----|----|------------|-----------------------|--------------------|------------------------|---------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| ×  | ×  | \$         | ×                     | ×                  | •                      | •                                                                                                       |                                                                                                                             |
|    | u  |            | N                     | 7                  | V                      | C                                                                                                       |                                                                                                                             |
| U  | п  | U          | IN                    | 2                  | v                      | C                                                                                                       |                                                                                                                             |
| •  | ×  | •          | ×                     | \$                 | ×                      | \$                                                                                                      |                                                                                                                             |
|    | ×  | × ×<br>U H | × × <b>‡</b><br>U H U | × × ¢ ×<br>U H U N | × × ‡ × ×<br>U H U N Z | ×         *         *         *         •           U         H         U         N         Z         V | ×         ×         *         ×         •         •           U         H         U         N         Z         V         C |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |  |
|------------------------|--|
| 42                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 7170                   |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |
|                        |  |

# 7.5.5 Notes

The clock cycle count (7170) in the specifications is for addition of 255 bytes to 255 bytes.

### 7.5.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software ADD2:
    - R0L: Contains, as an input argument, the byte count of an augend and an addend in 2digit hexadecimals.
    - R3: Contains the start address of the augend in the data memory area. The start address of the result of addition is placed in this register after execution of the software ADD2.
    - R4: Contains, as an input argument, the start address of the addend in the data memory area.
    - Z flag (CCR): Indicates an error in data length as an output argument.

- Z flag = 0: The data byte count (R0L) was not 0.
- Z flag = 1: The data byte count (R0L) was 0 (indicating an error).
- C flag (CCR): Determines the presence or absence of a carry, as an output argument, after execution of the software ADD2.
- C flag = 0: No carry occurred in the result of addition.
- C flag = 1: A carry occurred in the result of addition (see figure 17-2).
- b. Figure 7.15 shows an example of the software ADD2 being executed. When the input arguments are set as shown in (1), the result of addition is placed in the data memory area as shown in (2).



Figure 7.15 Example of Software ADD2 Execution

Figure 7.16 shows an example of addition with a carry that occurred in the result.



Figure 7.16 Example of Addition with a Carry

- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.17), set 0's in them. The software ADD2 performs byte-based addition; if 0's are not set in the upper bits unused, no correct result can be obtained because the addition is done on the numbers including indeterminate data.





- b. After execution of the software ADD2, the augend is destroyed because the result is placed in the data memory area where the augend was set. If the augend is necessary after software ADD2 execution, save it on memory.
- 3. Data memory

The software ADD2 does not use the data memory.

#### 4. Example of use

This is an example of adding 8 bytes of data. Set the start addresses of a byte count, an augend and an addend in the registers and call the software ADD2 as a subroutine.

| WORK1 | .RES.B      | 1                |   | Reserves a data memory area in which the user program places a byte count.                                                                                                   |
|-------|-------------|------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WORK2 | .RES. B     | 8                |   | Reserves a data memory area in which the<br>user program places an 8-byte binary<br>augend.                                                                                  |
| WORK3 | .RES. B     | 8<br>@WORK1, R0L |   | Reserves a data memory area in which the<br>user program places an 8-byte binary<br>addend.<br>Places in the input argument (R0L) the<br>byte count set by the user program. |
|       | MOV. W      | #WORK2, R3       |   | Places in the input argument (R3) the start<br>address of the augend set by the user<br>program.                                                                             |
|       | MOV. W      | #WORK3, R4       |   | Places in the input argument (R4) the start<br>address of the addend set by the user<br>program.                                                                             |
|       | JSR         | @ADD2            | ( | Calls the software ADD2 as a subroutine.                                                                                                                                     |
|       | BCS         | OVER             |   | Branches to the carry processing routine if<br>a carry has occurred in the result of<br>addition.                                                                            |
| OVER  | Carry proce | ssing routine.   |   |                                                                                                                                                                              |

### 5. Operation

- a. Addition of multiple-precision binary numbers can be done by performing a series of add instructions with a carry flag (ADDX.B) as the augend and addend data are placed in registers on a byte basis.
- b. The end address of the data memory area containing the augend is placed in R3, and the end address of the data memory area containing the addend is placed in R4.
- c. R1L is cleared for saving the C flag.
- d. The augend and addend are loaded in R2L and R2H respectively, byte by byte, starting at their end address and equation 1 is executed:

 $\begin{array}{c} Augend + addend + C \rightarrow R2L \\ R2L \rightarrow @R3 \end{array} \right\} \dots \dots equation 1$ 

where the C flag indicates a carry that may occur in the result of addition of the lower bytes.

- e. The result of d. is placed in the data memory area for the augend.
- f. R3, R4, and R0L are decremented each time the process d. to e. terminates. This processing is repeated until R0L reaches 0.

### 7.5.7 Flowchart





# 7.5.8 Program List

| OGRAM NAME =                             |          |      |                 |           |         |                                                                 |
|------------------------------------------|----------|------|-----------------|-----------|---------|-----------------------------------------------------------------|
|                                          |          |      |                 |           |         |                                                                 |
| 1                                        |          | ;*** | ******          | ******    | ******  | *********                                                       |
| 2                                        |          | ;*   |                 |           |         |                                                                 |
| 3                                        |          | ;*   | 00 - NA         | ME        |         | :MULTIPLE PRECISION BINARY ADDITION                             |
| 4                                        |          | ;*   |                 |           |         | (ADD2)                                                          |
| 5                                        |          | ;*   |                 |           |         |                                                                 |
| 6                                        |          | ;*** | ******          | ******    | ******  | *********                                                       |
| 7                                        |          | ;*   |                 |           |         |                                                                 |
| 8                                        |          | ;*   | ENTRY           |           | ROL     | (BYTE LENGTH OF ADDTION DATA)                                   |
| 9                                        |          | ;*   |                 |           | R3      | (START ADDRESS OF SUMMAND)                                      |
| 10                                       |          | ; *  |                 |           | R4      | (START ADDRESS OF ADDEND)                                       |
| 11                                       |          | ;*   |                 |           |         |                                                                 |
| 12                                       |          | ;*   | RETURNS         |           | :R3     | (START ADDRESS OF RESULT)                                       |
| 13                                       |          | ;*   |                 |           | Z flag  | OF CCR (Z=0;TRUE , Z=1;FALSE)                                   |
| 14                                       |          | ;*   |                 |           |         | OF CCR (C=0;TRUE , C=1;OVER FLOW)                               |
| 15                                       |          | ;*   |                 |           | -       |                                                                 |
| 16                                       |          | ;*** | ******          | ******    | ******* | *****                                                           |
| 17                                       |          | ;    |                 |           |         |                                                                 |
| 18 ADD2 cod C 0000                       |          |      | .SECTIO         | N         | ADD2 co | de, CODE, ALIGN=2                                               |
| 19                                       |          |      | .EXPORT         |           | ADD2    |                                                                 |
| 20                                       |          | ;    |                 |           |         |                                                                 |
| 21 ADD2 cod C                            | 00000000 |      | .EQU            | ŝ         |         | ;Entry point                                                    |
| 22 ADD2_cod C 0000                       |          |      | -               | #H'00,R   | Он      | Clear ROH                                                       |
| 23 ADD2_cod C 0002                       |          |      |                 | ROL,R1H   |         | Set byte counter(R1H)                                           |
| 24 ADD2 cod C 0004                       |          |      | BEQ             | EXIT      |         | Branch if ROL=0                                                 |
| 25 ADD2_cod C 0006                       |          |      | MOV.W           |           |         | /R3 -> R5                                                       |
| 26 ADD2_cod C 0008                       |          | MAIN |                 | 100 / 100 |         | ,,                                                              |
| 27 ADD2 cod C 0008                       |          |      | SUBS.W          | #1 R0     |         | ;Decrement R0                                                   |
| 28 ADD2_cod C 000A                       |          |      | ADD.W           | R0,R5     |         | Set start address of summand(R5)                                |
| 29 ADD2_cod C 000C                       |          |      | ADD.W           | R0,R5     |         | ;Set start address of addend(R4)                                |
| 30 ADD2 cod C 000E                       |          |      |                 | #H'00,R   | 11.     | Clear RL                                                        |
| 31 ADD2_cod C 0001                       |          | LOOP |                 | #11 00,1C |         | /ciear kiii                                                     |
| 32 ADD2_cod C 0010                       |          | LOOP |                 | @R5,R2L   |         | ;Load summand to R2L                                            |
| 33 ADD2_cod C 0010                       |          |      |                 | @R4,R2H   |         | Load addend to R2H                                              |
| 34 ADD2_cod C 0012                       |          |      | BLD             | #0,R1L    |         | ;Load bit 0 of R1L to C flag                                    |
| 34 ADD2_cod C 0014<br>35 ADD2_cod C 0016 |          |      |                 | R2H,R2L   |         | Addition                                                        |
| 36 ADD2_cod C 0018                       |          |      | BST             | #0,R1L    |         | Store C flag to bit 0 of R1L                                    |
| 37 ADD2_cod C 0018                       |          |      |                 | R2L,@R5   |         | Store result                                                    |
| 37 ADD2_cod C 001A<br>38 ADD2_cod C 001C |          |      | MOV.B<br>SUBS.W |           |         | ;Store result<br>;Decrement summand address(R5)                 |
| 39 ADD2_cod C 001C                       |          |      | SUBS.W          |           |         | ;Decrement summand address(R5)<br>;Decrement addend address(R4) |
| 40 ADD2_cod C 001E                       |          |      | DEC.B           |           |         |                                                                 |
| 40 ADD2_cod C 0020<br>41 ADD2_cod C 0022 |          |      |                 | LOOP      |         | ;Decrement byte counter(RlH)<br>;Branch if Z=0                  |
| 41 ADD2_Cod C 0022<br>42                 | 4010     |      | DNL             | TOOL      |         | /BLANCH IL Z=U                                                  |
|                                          | 7700     | ;    | DID             | #0 p1-    |         |                                                                 |
| 43 ADD2_cod C 0024                       |          |      |                 | #0,R1L    |         | ;Load bit 0 of R1L to c flag                                    |
| 44 ADD2_cod C 0026                       |          |      |                 | #H'FB,C0  | R       | ;Clear Z flag                                                   |
| 45 ADD2_cod C 0028                       |          | EXIT |                 |           |         |                                                                 |
| 46 ADD2_cod C 0028                       | 5470     |      | RTS             |           |         |                                                                 |
| 47                                       |          | ;    | -               |           |         |                                                                 |
| 48                                       |          |      | .END            |           |         |                                                                 |
| ****TOTAL ERRORS                         | 0        |      |                 |           |         |                                                                 |

# 7.6 Subtraction of Multiple-Precision Binary Numbers

MCU: H8/300 Series H8/300L Series

Label name: SUB2

### 7.6.1 Function

- 1. The software SUB2 subtracts a multiple-precision binary number from another multipleprecision binary number and places the result in the data memory where the minuend was set.
- 2. The arguments used with the software SUB2 are unsigned integers, each being up to 255 bytes long.

#### 7.6.2 Arguments

| Description |                                   | Memory area  | Data length (bytes) |
|-------------|-----------------------------------|--------------|---------------------|
| Input       | Minuend and subtrahend byte count | R0L          | 1                   |
|             | Start address of minuend          | R3           | 2                   |
|             | Start address of subtrahend       | R4           | 2                   |
| Output      | Start address of result           | R3           | 2                   |
|             | Error                             | Z flag (CCR) |                     |
| _           | Borrow                            | C flag (CCR) |                     |

#### 7.6.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| ×  | ×  | ×  | \$ | ×  | ×  | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | \$ | ×  | \$ |  |

 $\times$  : Unchanged

: Indeterminate

t : Result

| Program memory (bytes) |   |
|------------------------|---|
| 42                     |   |
| Data memory (bytes)    |   |
| 0                      |   |
| Stack (bytes)          |   |
| 0                      |   |
| Clock cycle count      |   |
| 7170                   |   |
| Reentrant              |   |
| Possible               |   |
| Relocation             |   |
| Possible               |   |
| Interrupt              |   |
| Possible               |   |
|                        | - |

# 7.6.5 Notes

The clock cycle count (7170) in the specifications for subtraction of 255 bytes from 255 bytes.

#### 7.6.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software SUB2:
    - R0L: Contains, as an input argument, the byte count of a minuend and the byte count of a subtrahend in 2-digit hexadecimals.
    - R3: Contains, as an input argument, the start address of the data memory area where the minuend is placed. After execution of the software SUB2, the start address of the result is placed in this register.
    - R4: Contains, as an input argument, the start address of the data memory area where the subtrahend is placed.
    - Z flag (CCR): Indicates an error in data length as an output argument.

- Z flag = 0: The data byte count (R0L) was not 0.
- Z flag = 1: The data byte count (R0L) was 0, indicating an error.
- C flag (CCR): Determines the presence or absence of a borrow after software SUB2 execution as an output argument.
- C flag = 0: No borrow occurred in the result.
- C flag = 1: A borrow occurred in the result. (See figure 7.19)
- b. Figure 7.18 shows an example of the software SUB2 being executed. When the input arguments are set as shown in (1), the result of subtraction is placed in the data memory area as shown in (2).

|                      | Subtraction data byte count    | R0L (H'04)         |          |           | 0 | 4      |
|----------------------|--------------------------------|--------------------|----------|-----------|---|--------|
|                      | Start address of minuend       | R3 (H'F000)        | [        | F   0     | 0 | 0      |
| (1) Input arguments  | Start address of subtrahend    | R4 (H'F100)        | [        | F   1     | 0 | 0      |
|                      |                                |                    | Data men | nory area |   |        |
|                      | Minuend                        | B 4                | 4 6      | 2 2       | 5 | 3      |
|                      |                                | (H'F000            | ~        | ~         | Н | 'F003) |
|                      | Subtrahend                     | A 3                | 6 7      | 5 C       | В | В      |
|                      | -)                             | (H'F100            | ~        | -         | Н | 'F103) |
|                      |                                | ↓<br>▼             |          |           |   |        |
|                      | Start address of result of sub | otraction R3 (H'F0 | 00)      | F 0       | 0 | 0      |
| (2) Output arguments |                                | 0                  |          |           |   |        |
| (z) Output arguments |                                | C flag             |          | 0         |   |        |
|                      |                                |                    | Data men | nory area |   |        |
|                      | Result of subtraction          | 1 0                | D E      | C   5     | 9 | 8      |
|                      |                                | (H'F000            | ~        | -         | Н | 'F003) |

Figure 7.18 Example of Software SUB2 Execution

Figure 7.19 shows an example of subtraction with a borrow that has occurred in the result.



Figure 7.19 Example of Subtraction with a Borrow

- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.20), set 0's in them. The software SUB2 performs byte-based subtraction; if 0's are not set in the upper bits unused, no correct result can be obtained because the subtraction is done on the numbers including indeterminate data.



Figure 7.20 Example of Subtraction with Upper Bits Unused

- b. After execution of the software SUB2, the minuend is destroyed because the result is placed in the data memory area where the minuend was set. If the minuend is necessary after software SUB2 execution, save it on memory.
- 3. Data memory

The software SUB2 does not use the data memory.

4. Example of use

This is an example of subtracting 8 bytes of data. Set the start addresses of a byte count, a minuend and a subtrahend in the registers and call the software SUB2 as a subroutine.



- 5. Operation
  - a. Subtraction of multiple-precision binary numbers can be done by repeating a subtract instruction with a carry flag (SUBX.B) as the minuend and subtrahend data are placed in registers on a byte basis.
  - b. The end address of the data memory area containing the minuend is placed in R3, and the end address of the data memory area containing the subtrahend is placed in R4.
  - c. R1L is cleared for saving the C flag.
  - d. The minuend and subtrahend are loaded in R2L and R2H respectively, byte by byte, starting at their end address and equation 1 is executed:

 $\begin{array}{c} \mbox{Minuend-subtrahend-C} \rightarrow \mbox{R2L} \\ \mbox{R2L} \rightarrow \mbox{@R3} \end{array} \right\} \ ..... \mbox{equation 1}$ 

where the C flag indicates a carry that may occur in the result of subtraction of the lower bytes.

- e. The result of d. is placed in the data memory area for the minuend.
- f. R3, R4, and R0L are decremented each time the process d. to e. terminates. This processing is repeated until R0L reaches 0.





# 7.6.8 Program List

| GRAM NAME =            |      |          |          |          |                                         |
|------------------------|------|----------|----------|----------|-----------------------------------------|
|                        |      |          |          |          |                                         |
| 1                      | ;*** | ******   | *******  | ******   | * * * * * * * * * * * * * * * * * * * * |
| 2                      | ; *  |          |          |          |                                         |
| 3                      | ; *  | 00 - NAI | ME       |          | :MULTIPLE-PRECISION BINARY SUBTRACTIO   |
| 4                      | ; *  |          |          |          | (SUB2)                                  |
| 5                      | ;*   |          |          |          |                                         |
| 6                      | ;*** | ******   | ******   | *****    | * * * * * * * * * * * * * * * * * * * * |
| 7                      | ;*   |          |          |          |                                         |
| 8                      | ; *  | ENTRY    |          | ROL      | (BYTE LENGTH OF DATA)                   |
| 9                      | ;*   |          |          | R3       | (START ADDRESS OF MINUEND)              |
| 10                     | ;*   |          |          | R4       | (START ADDRESS OF SUBTRAHEND)           |
| 11                     | ;*   |          |          |          |                                         |
| 12                     | ;*   | RETURNS  |          | :R3      | (START ADDRESS OF RESULT)               |
| 13                     | ;*   |          |          |          | OF CCR (Z=0;TRUE , Z=1;FALSE)           |
| 14                     | ;*   |          |          |          | OF CCR (C=0;TRUE , C=1;BORROW)          |
| 15                     | ;*   |          |          |          |                                         |
| 16                     | :*** | *******  | *******  | ******   | *****                                   |
| 17                     | ;    |          |          |          |                                         |
| 18 SUB2 cod C 0000     |      | .SECTIO  | N        | SUB2 CO  | de,CODE,ALIGN=2                         |
| 19                     |      | .EXPORT  |          | SUB2_COU |                                         |
| 20                     | ;    | .EAPORI  |          | 3082     |                                         |
| 21 SUB2_cod C 000      |      | .EQU     | ŝ        |          | Entry point                             |
|                        |      |          |          |          |                                         |
| 22 SUB2_cod C 0000 F00 |      | MOV.B    |          |          | ;Clear ROH<br>;Set byte counter(R1H)    |
| 23 SUB2_cod C 0002 0C8 |      |          |          |          |                                         |
| 24 SUB2_cod C 0004 472 |      | BEQ      | EXIT     |          | Branch if ROL=0                         |
| 25 SUB2_cod C 0006 0D3 |      |          | R3,R5    |          | ;R3 -> R5                               |
| 26 SUB2_cod C 0008     | MAIN |          |          |          |                                         |
| 27 SUB2_cod C 0008 1B0 |      | SUBS.W   |          |          | ;Decrement R0                           |
| 28 SUB2_cod C 000A 090 |      | ADD.W    | R0,R5    |          | ;Adjust minuend start address(R5)       |
| 29 SUB2_cod C 000C 090 |      | ADD.W    | R0,R4    |          | ;Adjust subtrahend start address(R4)    |
| 30 SUB2_cod C 000E F90 |      | MOV.B    | #H'00,R1 | L        | Clear RLL                               |
| 31 SUB2_cod C 0010     | LOOP |          |          |          |                                         |
| 32 SUB2_cod C 0010 685 |      |          | @R5,R2L  |          | ;Load minuend                           |
| 33 SUB2_cod C 0012 684 |      | MOV.B    | @R4,R2H  |          | ;Load subtrahend                        |
| 34 SUB2_cod C 0014 770 |      | BLD      | #0,R1L   |          | ;Load bit 0 of RlL to C flag            |
| 35 SUB2_cod C 0016 1E2 |      |          | R2H,R2L  |          | ;Subtruction                            |
| 36 SUB2_cod C 0018 670 |      | BST      | #0,R1L   |          | ;Store C flag to bit 0 of R1L           |
| 37 SUB2_cod C 001A 68D | A    | MOV.B    | R2L,@R5  |          | ;Store result                           |
| 38 SUB2_cod C 001C 1B0 | 5    | SUBS.W   | #1,R5    |          | ;Decrement minuend address              |
| 39 SUB2_cod C 001E 1B0 | 4    | SUBS.W   | #1,R4    |          | ;Decrement subtrahend address           |
| 40 SUB2_cod C 0020 1A0 | 1    | DEC.B    | R1H      |          | ;Decrement byte counter                 |
| 41 SUB2_cod C 0022 46E | C    | BNE      | LOOP     |          | Branch if not R0L=0                     |
| 42                     | ;    |          |          |          |                                         |
| 43 SUB2_cod C 0024 770 | 9    | BLD      | #0,R1L   |          | ;Load bit 0 of R1L to C flag            |
| 44 SUB2_cod C 0026 06F | в    | ANDC     | #H'FB,CC | R        | ;Clear Z flag                           |
| 45 SUB2_cod C 0028     | EXIT |          |          |          |                                         |
| 46 SUB2_cod C 0028 547 | 0    | RTS      |          |          |                                         |
| 47                     | ;    |          |          |          |                                         |
| 48                     |      | .END     |          |          |                                         |
| ****TOTAL ERRORS       | 0    |          |          |          |                                         |

\*\*\*\*\*TOTAL WARNINGS 0
# 7.7 Addition of 8-Digit BCD Numbers

MCU: H8/300 Series H8/300L Series

Label name: ADDD1

#### 7.7.1 Function

- 1. The software ADDD1 adds an 8-digit binary-coded decimal (BCD) number to another 8-digit BCD number and places the result (an 8-digit BCD number) in a general-purpose register.
- 2. The arguments used with the software ADDD1 are unsigned integers.
- 3. All data is manipulated in general-purpose registers.

#### 7.7.2 Arguments

| Description |                    | Memory area  | Data length (bytes) |  |
|-------------|--------------------|--------------|---------------------|--|
| Input       | Augend             | R0, R1       | 4                   |  |
|             | Addend             | R2, R3       | 4                   |  |
| Output      | Result of addition | R0, R1       | 4                   |  |
|             | Carry              | C flag (CCR) |                     |  |

#### 7.7.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| \$ | \$ | •  | •  | •  | •  | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | ×  | ×  | \$ |  |

 $\times$  : Unchanged

• : Indeterminate

\$ : Result

| Program memory (bytes) |  |
|------------------------|--|
| 18                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 24                     |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |
|                        |  |

#### 7.7.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software ADDD1:
    - R0, R1: Contain an 8-digit BCD augend (32 bits long). After execution of the software ADDD1, the result of addition (an 8-digit BCD number, 32 bits long) is placed in this register.
    - R2, R3: Contain an 8-digit BCD addend (32 bits long) as an input argument.
    - C flag (CCR): Determines the presence or absence of a carry, as an output argument, after execution of the software ADDD1.
    - C flag = 1: A carry occurred in the result of addition. (See figure 7.21.)
    - C flag = 0: No carry occurred in the result of addition.



Figure 7.21 Example of Addition with a Carry

b. Figure 7.22 shows an example of the software ADDD1 being executed. When the input arguments are set as shown in (1), the result of addition is placed in R0 and R1 as shown in (2).



Figure 7.22 Example of Software ADDD1 Execution

- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.23), set 0's in them; otherwise, no correct result can be obtained because addition is done on the numbers including indeterminate data.



Figure 7.23 Example of Addition with Upper Bits Unused

- b. After execution of the software ADDD1, the augend is destroyed because the result is placed in R1 and R2. If the augend is necessary after software ADDD1 execution, save it on memory.
- 3. Data memory

The software ADDD1 does not use the data memory.

#### 4. Example of use

Set an augend and an addend in the registers and call the software ADDD1 as a subroutine.



- 5. Operation
  - a. Addition of 2 bytes or more of BCD numbers can be done by performing a series of 1-byte additions with decimal correction.
  - b. A 1-byte add instruction (ADD.B), which does not involve the state of the C flag, is used to add the most significant byte given in equation 1. If a carry occurs after execution of equation 1, the C flag is set. Then a decimal correct instruction (DAA) is used to perform decimal correction.

 $R1L + R3L \rightarrow R1L \quad \text{equation } 1$ 

Decimal correction of  $R1L \rightarrow R1L$ 

c. A 1-byte add instruction (ADDX.B), which involves the state of the C flag, and a decimal-correct instruction are executed three times to add the upper bytes given in equation 2.

The C flag indicates a carry that may occur in the result of addition of the least significant byte, the upper bytes of the lower word, and the lower bytes of the upper word that was executed in step (b).



# 7.7.7 Program List

|                         | VER 1.0B ** 08/18         | /92 10:00:37                            |
|-------------------------|---------------------------|-----------------------------------------|
| PROGRAM NAME =          |                           |                                         |
| 1                       | ;********                 | *******                                 |
| 2                       | ;*                        |                                         |
| 3                       | ;* 00 - NAI               | ME :DECIMAL ADDITION (ADDD1)            |
| 4                       | ; *                       |                                         |
| 5                       | ; * * * * * * * * * * * * | *****                                   |
| 6                       | ; *                       |                                         |
| 7                       | ;* ENTRY                  | :R0 (UPPER WORD SUMMAND)                |
| 8                       | ;*                        | R1 (LOWER WORD SUMMAND)                 |
| 9                       | ;*                        | R2 (UPPER WORD ADDEND)                  |
| 10                      | ; *                       | R3 (LOWER WORD ADDEND)                  |
| 11                      | ; *                       |                                         |
| 12                      | ; * RETURNS               | :R0 (UPPER WORD RESULT)                 |
| 13                      | ; *                       | R1 (LOWER WORD RESULT)                  |
| 14                      | ;*                        | C flag OF CCR (C=0;TRUE , C=1;OVERFLOW) |
| 15                      | ;*                        |                                         |
| 16                      | ;********                 | * * * * * * * * * * * * * * * * * * * * |
| 17                      | ;                         |                                         |
| 18 ADDD1_co C 0000      |                           | N ADDD1_code, CODE, ALIGN=2             |
| 19                      | . EXPORT                  | ADDD1                                   |
| 20                      | ;                         |                                         |
| 21 ADDD1_co C 00000000  |                           |                                         |
| 22 ADDD1_co C 0000 08B9 |                           | R3L,R1L /R3L + R1L -> R1L               |
| 23 ADDD1_co C 0002 0F09 |                           | R1L ;Decimal adjust R1L                 |
| 24 ADDD1_co C 0004 0E31 |                           | R3H,R1H ;R3H + R1H + C -> R1H           |
| 25 ADDD1_co C 0006 0F01 |                           |                                         |
| 26 ADDD1_co C 0008 0EA8 |                           | R2L,R0L ;R2L + R0L + C -> R0L           |
| 27 ADDD1_co C 000A 0F08 | DAA                       | ROL ;Decimal adjust ROH                 |
| 28 ADDD1_co C 000C 0E20 |                           | R2H,R0H ;R2H + R0H + C -> R0H           |
| 29 ADDD1_co C 000E 0F00 | DAA                       | ROH ;Decimal adjust ROH                 |
| 30 ADDD1_co C 0010 5470 | RTS                       |                                         |
| 31                      | ;                         |                                         |
| 32                      | . END                     |                                         |
| *****TOTAL ERRORS 0     |                           |                                         |
| *****TOTAL WARNINGS 0   |                           |                                         |

# 7.8 Subtraction of 8-Digit BCD Numbers

MCU: H8/300 Series H8/300L Series

Label name: SUBD1

### 7.8.1 Function

- 1. The software SUBD1 subtracts an 8-digit binary-coded decimal (BCD) number from another 8-digit BCD number and places the result (an 8-digit BCD number) in a general-purpose register.
- 2. The arguments used with the software SUBD1 are unsigned integers.
- 3. All data is manipulated in general-purpose registers.

#### 7.8.2 Arguments

| Descript    | scription      |                   |                   | Memory are  | ea      | Data length (bytes) |              |
|-------------|----------------|-------------------|-------------------|-------------|---------|---------------------|--------------|
| Input       | Minuend        |                   |                   | R0, R1      |         | 4                   |              |
|             | Subtrahe       | end               |                   | R2, R3      |         | 4                   |              |
| Output      | Result of      | f subtraction     | 1                 | R0, R1      |         | 4                   |              |
|             | Borrow         |                   |                   | C flag (CCR | R)      |                     |              |
| 7.8.3       | Internal       | Register an       | d Flag Cha        | nges        |         |                     |              |
| 7.8.3<br>R0 | Internal<br>R1 | Register an<br>R2 | id Flag Cha<br>R3 | nges<br>R4  | R5      | R6                  | R7           |
|             |                | -                 |                   |             | R5<br>• | R6<br>•             | R7<br>•      |
|             |                | R2                |                   |             |         | R6<br>•<br>V        | R7<br>•<br>C |

× : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |                                                                                                     |
|------------------------|-----------------------------------------------------------------------------------------------------|
| 18                     |                                                                                                     |
| Data memory (bytes)    |                                                                                                     |
| 0                      |                                                                                                     |
| Stack (bytes)          |                                                                                                     |
| 0                      |                                                                                                     |
| Clock cycle count      |                                                                                                     |
| 24                     |                                                                                                     |
| Reentrant              |                                                                                                     |
| Possible               |                                                                                                     |
| Relocation             |                                                                                                     |
| Possible               |                                                                                                     |
| Interrupt              |                                                                                                     |
| Possible               |                                                                                                     |
|                        | 18Data memory (bytes)0Stack (bytes)0Clock cycle count24ReentrantPossibleRelocationPossibleInterrupt |

#### 7.8.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software SUBD1:
    - R0, R1: Contain an 8-digit BCD minuend (32 bits long). After execution of the software SUBD1, the result of subtraction (an 8-digit BCD number, 32 bits long) is placed in this register.
    - R2, R3: Contain an 8-digit BCD subtrahend (32 bits long) as an input argument.
    - C flag (CCR): Determines the presence or absence of a borrow, as an output argument, after execution of the software SUBD1.
    - C flag = 1: A borrow occurred in the result of subtraction. (See figure 7.24.)
    - C flag = 0: No borrow occurred in the result of subtraction.



Figure 7.24 Example of Subtraction with a Borrow

b. Figure 7.25 shows an example of the software SUBD1 being executed. When the input arguments are set as shown in (1), the result of subtraction is placed in R0 and R1 as shown in (2).



Figure 7.25 Example of Software SUBD1 Execution

- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.26), set 0's in them; otherwise, no correct result can be obtained because subtraction is done on the numbers including indeterminate data.



Figure 7.26 Example of Subtraction with Upper Bits Unused

- b. After execution of the software SUBD1, the minuend is destroyed because the result is placed in R1 and R2. If the minuend is necessary after software SUBD1 execution, save it on memory.
- 3. Data memory

The software SUBD1 does not use the data memory.

#### 4. Example of use

Set a minuend and a subtrahend in the registers and call the software SUBD1 as a subroutine.

| WORK1 | .RES. W               | 2                            |   | Reserves a data memory area in which the user program places an 8-digit BCD minuend.                            |
|-------|-----------------------|------------------------------|---|-----------------------------------------------------------------------------------------------------------------|
| WORK2 | .RES. W               | 2                            |   | Reserves a data memory area in which the user program places an 8-digit BCD subtrahend.                         |
| WORK3 | .RES. W               | 2                            |   | Reserves a data memory area in which the user program places the result of subtraction (an 8-digit BCD number). |
|       | i<br>MOV. W<br>MOV. W | @WORK1, R0<br>@WORK1+2, R1 ∫ |   | Places in the input argument (R0, R1) the<br>8-digit BCD minuend set by the user<br>program.                    |
|       | MOV. W<br>MOV. W      | @WORK2, R2<br>@WORK2+2, R3   |   | Places in the input argument (R2, R3) the<br>8-digit BCD subtrahend set by the user<br>program.                 |
|       | JSR                   | @SUBD1                       | ( | Calls the software SUBD1 as a subroutine.                                                                       |
|       | BCS                   | OVER                         |   | Branches to the borrow processing routine<br>if a borrow has occurred in the result of<br>subtraction.          |
|       |                       | R0, @WORK3                   |   | Places the result (set in the output argument) in the data memory of the user program.                          |
|       | :<br>Der              |                              | 7 |                                                                                                                 |
| OVER  | Borrow                | processing routine.          |   |                                                                                                                 |
|       |                       |                              |   |                                                                                                                 |

- 5. Operation
  - a. Subtraction of 2 bytes or more of BCD numbers can be done by performing a series of 1byte subtractions with decimal correction.
  - b. A 1-byte subtract instruction (SUB.B), which does not involve the state of the C flag, is used to add the most significant byte given in equation 1. If a borrow occurs after execution of equation 1, the C flag is set. Then a decimal correct instruction (DAS) is used to perform decimal correction.

 $R1L - R3L \rightarrow R1L$  .... equation 1 Decimal correction of  $R1L \rightarrow R1L$ 

c. A 1-byte subtract instruction (SUBX.B), which involves the state of the C flag, and a decimal-correct instruction (DAS) are executed three times to add the upper bytes given in equation 2.

 $\left. \begin{array}{l} R1H-R3H-C \rightarrow R1H \ \ Decimal \ correction \ of \ R1H \rightarrow R1H \\ R0H-R2L-C \rightarrow R0L \ \ Decimal \ correction \ of \ R0L \rightarrow R0L \\ R0H-R2H-C \rightarrow R0H \ \ Decimal \ correction \ of \ R0H \rightarrow R0H \end{array} \right\} \quad \cdots \cdots \quad equation \ 2$ 

The C flag indicates a borrow that may occur in the result of subtraction of the least significant byte, the upper bytes of the lower word, and the lower bytes of the upper word that was executed in step b..



## 7.8.7 Program List

| DROGRAM MANT                                       | VER 1.0B ** | 00/10   | / 22 10:0.     | 1.02   |         |           |                      |               |
|----------------------------------------------------|-------------|---------|----------------|--------|---------|-----------|----------------------|---------------|
| PROGRAM NAME =                                     |             |         |                |        |         |           |                      |               |
| 1                                                  | ;****       | ******  | ******         | ****** | ******  | * * * * * | ******               | *****         |
| 2                                                  | ;*          |         |                |        |         |           |                      |               |
| 3                                                  | ; *         | 00 - NA | ME             |        | :DECIM  | AL SU     | JETRUCTION (SU       | JBD1)         |
| 4                                                  | ;*          |         |                |        |         |           |                      |               |
| 5                                                  | ;****       | ******  | ******         | ****** | ******  | * * * * * | ******               | ******        |
| 6                                                  | ;*          |         |                |        |         |           |                      |               |
| 7                                                  | ;*          | ENTRY   |                | :R0    | (UPPER  | WORD      | MINUEND)             |               |
| 8                                                  | ;*          |         |                | Rl     | (LOWER  | WORD      | MINUEND)             |               |
| 9                                                  | ; *         |         |                | R2     | (UPPER  | WORD      | SUBTRAHEND)          |               |
| 10                                                 | ;*          |         |                | R3     | (LOWER  | WORE      | SUBTRAHEND)          |               |
| 11                                                 | ;*          |         |                |        |         |           |                      |               |
| 12                                                 | ;*          | RETURNS |                | :R0    | (UPPER  | WORD      | RESULT)              |               |
| 13                                                 | ;*          |         |                |        |         |           | RESULT)              |               |
| 14                                                 | ;*          |         |                | C flag | OF CCR  | ( C       | 2=0;TRUE,C=1;U       | JNDER FLOW)   |
| 15                                                 | ;*          |         |                |        |         |           |                      |               |
| 16                                                 | ,           | ******  | ******         | ****** | ******  | ****      | **********           | ************* |
| 17                                                 | ;           |         |                |        |         |           |                      |               |
| 18 SUBD1_co C 0000                                 |             |         | N              | -      | ode,COD | E,ALI     | GN=2                 |               |
| 19                                                 |             | .EXPORT |                | SUBD1  |         |           |                      |               |
| 20                                                 | ;           |         |                |        |         |           |                      |               |
| 21 SUBD1_co C 0000000                              |             |         | .EQU           |        |         |           | ntry point<br>-> R1L |               |
| 22 SUBD1_co C 0000 18B9<br>23 SUBD1 co C 0002 1F09 |             | DAS     | R3L,R1L<br>R1L |        |         |           | -> RIL<br>ljust R1L  |               |
| 24 SUBD1_co C 0002 1F09                            |             |         | R3H,R1H        |        |         |           | - C -> R1H           |               |
| 25 SUBD1 co C 0006 1F01                            |             | DAS     |                |        |         |           | ljust R1H            |               |
| 26 SUBD1 CO C 0008 1EA8                            |             |         | R2L,R0L        |        |         |           | - C -> ROL           |               |
| 27 SUBD1 CO C 000A 1F08                            |             | DAS     | ROL            |        |         |           | ljust ROL            |               |
| 28 SUBD1 co C 000C 1E20                            |             |         | R2H,R0H        |        |         |           | - C -> ROH           |               |
| 29 SUBD1 co C 000E 1F00                            |             | DAS     | R0H            |        |         |           | ljust ROH            |               |
| 30 SUBD1_co C 0010 5470                            |             | RTS     |                |        |         |           | -                    |               |
| 31                                                 | ;           |         |                |        |         |           |                      |               |
| 32                                                 |             | .END    |                |        |         |           |                      |               |
| ****TOTAL ERRORS 0                                 |             |         |                |        |         |           |                      |               |
|                                                    |             |         |                |        |         |           |                      |               |

# 7.9 Multiplication of 4-Digit BCD Numbers

MCU: H8/300 Series H8/300L Series

Label name: MULD

### 7.9.1 Function

- 1. The software MULD multiplies a 4-digit binary-coded decimal (BCD) number by another 4digit BCD number and places the result (an 8-digit BCD number) in a general-purpose register.
- 2. The arguments used with the software MULD are unsigned integers.
- 3. All data is manipulated in general-purpose registers.

#### 7.9.2 Arguments

| Description |                          | Memory area | Data length (bytes) |
|-------------|--------------------------|-------------|---------------------|
| Input       | Multiplicand             | R1          | 2                   |
|             | Multiplier               | R0          | 2                   |
| Output      | Result of multiplication | R2, R3      | 4                   |

#### 7.9.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5H R | 5L R6H | R6L R7 |  |
|----|----|----|----|----|-------|--------|--------|--|
| ×  | •  | \$ | \$ | •  | • ×   | ×      | × •    |  |
|    |    |    |    |    |       |        |        |  |
| I  | U  | н  | U  | Ν  | Z     | v      | С      |  |
| •  | •  | ×  | •  | ×  | ×     | ×      | ×      |  |

× : Unchanged

• : Indeterminate

t : Result

| Program memory (by | tes) |
|--------------------|------|
| 62                 |      |
| Data memory (byte  | s)   |
| 0                  |      |
| Stack (bytes)      |      |
| 0                  |      |
| Clock cycle count  |      |
| 1192               |      |
| Reentrant          |      |
| Possible           |      |
| Relocation         |      |
| Possible           |      |
| Interrupt          |      |
| Possible           |      |
|                    |      |

# 7.9.5 Notes

The clock cycle count (1192) in the specifications is for multiplication of 9999 by 9999.

#### 7.9.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software MULD:
    - R0: Contains a 4-digit BCD multiplier (16 bits long) as an input argument.
    - R1: Contains a 4-digit BCD multiplicand (16 bits long) as an input argument.
    - R2: Contains the upper 4 digits of the result (an 8-digit BCD, 32 bits long) as an output argument.
    - R3: Contains the lower 4 digits of the result (an 8-digit BCD, 32 bits long) as an output argument.

b. Figure 7.27 shows an example of the software MULD being executed. When the input arguments are set as shown in (1), the result of multiplication is places in R2 and R3 as shown in (2).



#### Figure 7.27 Example of Software MULD Execution

c. Table 7.3 lists the result of multiplication with 0's placed in input arguments.

#### Table 7.3 Result of Multiplication with 0's Placed in Input Arguments

|            | Output arguments |  |  |
|------------|------------------|--|--|
| Multiplier | Product          |  |  |
| H'0000     | H'0000           |  |  |
| H'****     | H'0000           |  |  |
| H'0000     | H'0000           |  |  |
|            | H'0000<br>H'**** |  |  |

Note: H'\*\*\*\* is a hexadecimal number.

- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.28), set 0's in them; otherwise, no correct result can be obtained because multiplication is done on the numbers including indeterminate data placed in the upper bytes.





- b. After execution of the software MULD, the multiplier is destroyed. If the multiplier is necessary after software MULD execution, save it on memory.
- 3. Data memory

The software MULD does not use the data memory.

# 4. Example of use

Set a multiplicand and a multiplier in the registers and call the software MULD as a subroutine.

| WORK1 | .RES. W     | 1                          | Reserves a data memory area in which the user program places a 4-digit BCD multiplicand.                           |
|-------|-------------|----------------------------|--------------------------------------------------------------------------------------------------------------------|
| WORK2 | .RES. W     | 1                          | Reserves a data memory area in which the user program places a 4-digit BCD multiplier.                             |
| WORK3 | .RES. W     | 2                          | Reserves a data memory area in which the user program places the result of multiplication (an 8-digit BCD number). |
|       | :<br>MOV. W | @WORK1, R1                 | Places in the input argument (R1) the 4-<br>digit BCD multiplicand set by the user<br>program.                     |
|       | MOV. W      | @WORK2, R0                 | Places in the input argument (R0) the 4-<br>digit BCD multiplier set by the user<br>program.                       |
|       | JSR         | @MULD                      | $\cdots \cdots \left( $ Calls the software MULD as a subroutine.                                                   |
|       |             | R2, @WORK3<br>R3, @WORK3+2 | Places the result (set in the output argument) in the data memory of the user program.                             |
|       |             |                            |                                                                                                                    |

- 5. Operation
  - a. Multiplication of decimal numbers can be can be done by performing a series of additions and shifts. Figure 7.29 shows an example of multiplication ( $568 \times 1234$ ).



Figure 7.29 Example of Multiplication (5678 × 1234)

Figure 7.29 indicates that a product is obtained by performing a series of shifting the result of multiplication and adding the multiplicand.

First, 4 bits (1 digit of the BCD) are taken out of the most significant byte of the multiplier and the multiplicand is added by that value. The result is shifted 4 bits (1 digit of the BCD). Next, 4 bits are taken out of the upper byte of the multiplier and the multiplicand is added by that value. The result is added to the previously obtained result. By performing this series of operations as many times as the number of digits of the BCD (that is, four times) the final result of multiplication can be obtained.

- b. The program runs in the following steps:
  - (i) H'04 is placed in the H6H counter that indicates the number of digits of data.
  - (ii) The result of multiplication (R2 and R3) is cleared.
  - (iii) R2 and R3 are shifted 4 bits (1 digit of the BCD) to the left.
  - (iv) The multiplier is loaded in units of 4 bits (1 digit of the BCD) to R5, starting at its upper bytes. Branches to step (vi) if R5L is 0.
  - (v) Decimal addition of the multiplicand to R2 and R3 is performed by the value of R5L.
  - (vi) R6H is decremented.
  - (vii) Steps (iii) to (vi) are repeated until R6H reaches 0.

# Renesas





### 7.9.8 Program List

\*\*\* H8/300 ASSEMBLER

```
PROGRAM NAME =
  1
                                  2
                                  ;*
   3
                                  ;*
                                      00 - NAME
                                                 :DECIMAL MULTIPLICATION
                                  ;*
   4
                                                   (MULD)
   5
                                  ;*
                                  6
   7
                                  ;*
   8
                                  ;* ENTRY :R1 (MULTIPLICAND)
   9
                                  ;*
                                           RO
                                                   (MULTIPLIER)
  10
                                  ;*
                                  ;* RETURNS :R2 (UPPER WORD OF RESULT)
  11
                                  ;*
                                      R3
                                                   (LOWER WORD OF RESULT)
  12
  13
                                  ;*
                                  14
  15
                                  ;
  16 MULD_cod C 0000
                                      .SECTION
                                                 MULD_code,CODE,ALIGN=2
                                      .EXPORT
  17
                                                 MULD
  18
                                  ;
  19 MULD_cod C 00000000
                                  MULD .EQU $
                                                         ;Entry point
  20 MULD_cod C 0000 F604
                                    MOV.B #H'04,R6H
                                                         ;Set bit counterl
  21 MULD_cod C 0002 79020000
                                     MOV.W #H'0000,R2
                                                         ;Clear R2
  22 MULD_cod C 0006 0D23
                                     MOV.W R2,R3
                                                         ;Clear R3
  23 MULD_cod C 0008
                                 LBL1
  24 MULD_cod C 0008 FE04
                                    MOV.B #H'04,R6L
                                                         ;Set bit counter2
  25 MULD_cod C 000A FD00
                                     MOV.B #H'00,R5L
                                                         ;Clear R5L
  26 MULD_cod C 000C
                                 LOOP1
  27 MULD_cod C 000C 1008
                                     SHLL.B ROL
                                                         ;Shift multiplier 1 bit left
  28 MULD cod C 000E 1200
                                     ROTXL.B ROH
  29 MULD_cod C 0010 120D
                                     ROTXL.B R5L
  30 MULD_cod C 0012 100B
                                      SHLL.B R3L
                                                         ;Shift result 1 bit left
  31 MULD cod C 0014 1203
                                      ROTXL.B R3H
  32 MULD_cod C 0016 120A
                                      ROTXL.B R2L
  33 MULD cod C 0018 1202
                                      ROTXL.B R2H
                                      DEC.B R6L
  34 MULD_cod C 001A 1A0E
                                                         ;Decrement bit counter 2
  35 MULD cod C 001C 46EE
                                     BNE LOOP1
                                                         ;Branch if Z=0
                                     CMP.B #H'00,R5L
  36 MULD cod C 001E AD00
  37 MULD cod C 0020 4714
                                      BEO
                                            LBL2
                                                         ;Branch if Z=1
  38 MULD cod C 0022
                                 LOOP2
  39 MULD_cod C 0022 089B
                                     ADD.B R1L,R3L
                                                         ;R1L + R3L
                                                                      -> R11.
  40 MULD_cod C 0024 0F0B
                                     DAA.B R3L
                                                         ;Decimal adjust R3L
                                                         ;R1H + R3H + C -> R1H
  41 MULD_cod C 0026 0E13
                                      ADDX.B R1H,R3H
  42 MULD cod C 0028 0F03
                                     DAA.B R3H
                                                         ;Decimal adjust R3H
  43 MULD_cod C 002A 9A00
                                      ADDX.B #H'00,R2L
                                                         ;R2L + #H'00 + C -> R2L
  44 MULD_cod C 002C 0F0A
                                      DAA.B R2L
                                                         ;Decimal adjust R2L
  45 MULD cod C 002E 9200
                                      ADDX.B #H'00,R2H
                                                         ;R2H + #H'00 + C -> R2H
  46 MULD cod C 0030 0F02
                                      DAA.B R2H
                                                         ;Decimal adjust R2H
  47 MULD_cod C 0032 1A0D
                                      DEC.B R5L
                                                         ;Clear bit 0 of R5L
  48 MULD cod C 0034 46EC
                                      BNE LOOP2
                                                         Branch if Z=0
  49 MULD cod C 0036
                                 LBL2
  50 MULD cod C 0036 1406
                                      DEC.B R6H
                                                         ;Decrement bit counter1
  51 MULD_cod C 0038 46CE
                                      BNE
                                            LBL1
                                                         Branch if Z=0
  52
                                  ;
  53 MULD_cod C 003A 5470
                                      RTS
                                      .END
  54
 ****TOTAL ERRORS
                   0
 *****TOTAL WARNINGS
                  0
```

VER 1.0B \*\* 08/18/92 10:01:29

# 7.10 Division of 8-Digit BCD Numbers

MCU: H8/300 Series H8/300L Series

Label name: DIVD

#### 7.10.1 Function

- 1. The software DIVD divides an 8-digit binary-coded decimal (BCD) number by another 8-digit BCD number and places the result (an 8-digit BCD number) in a general-purpose register.
- 2. The arguments used with the software DIVD are unsigned integers.
- 3. All data is manipulated in general-purpose registers.

#### 7.10.2 Arguments

| Descript | tion                           | Memory area  | Data length (bytes) |  |
|----------|--------------------------------|--------------|---------------------|--|
| Input    | Dividend                       | R0, R1       | 4                   |  |
|          | Divisor                        | R2, R3       | 4                   |  |
| Output   | Result of division (quotient)  | R0, R1       | 4                   |  |
|          | Result of division (remainder) | R4, R5       | 4                   |  |
|          | Error                          | Z flag (CCR) | 1                   |  |

#### 7.10.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| \$ | \$ | •  | •  | \$ | \$ | ×  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | \$ | ×  | ×  |  |

 $\times$  : Unchanged

Indeterminate

t : Result

| Program memory (bytes) |  |
|------------------------|--|
| 84                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 1162                   |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |

# 7.10.5 Notes

The clock cycle count (1162) in the specifications is for division of 999999999 by 9999.

#### 7.10.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software DIVD:
    - R0: Contains the upper 4 digits of an 8-digit BCD dividend (32 bits long). After execution of the software DIVD, the upper 4 digits of the result of division (quotient) are placed in this register.
    - R1: Contains the lower 4 bits of the 8-digit BCD dividend (32 bits long). After execution of the software DIVD, the lower 4 digits of the result of division (quotient) are placed in this register.
    - R2: Contains the upper 4 digits of an 8-digit BCD divisor as an input argument.
    - R3: Contains the lower 4 digits of the 8-digit BCD divisor as an input argument.
    - R4: The upper 4 digits of an 8-digit BCD remainder are placed in this register as an output argument.
    - R5: The lower 4 digits of the 8-digit BCD remainder are placed in this register as an output argument.
    - Z flag (CCR): Determines the presence or absence of an error (division by 0) with the software DIVD as an output argument.
    - Z flag = 1: The divisor was 0, indicating an error.
    - Z flag = 0: The divisor was not 0.
  - b. Figure 7.30 shows an example of the software DIVD being executed. When the input arguments are set as shown in (1), the result of division is placed in the registers as shown in (2).



Figure 7.30 Example of Software DIVD Execution

c. Table 7.4 lists the result of division with 0's placed in input arguments.

| Table 7.4 | <b>Result of Division</b> | with 0's Placed in | Input Arguments |
|-----------|---------------------------|--------------------|-----------------|
|-----------|---------------------------|--------------------|-----------------|

| Input arguments   |                  | Output arguments  |                    |           |  |  |
|-------------------|------------------|-------------------|--------------------|-----------|--|--|
| Dividend (R0, R1) | Divisor (R2, R3) | Quotient (R0, R1) | Remainder (R4, R5) | Error (Z) |  |  |
| H'*****           | H'00000000       | H'*****           | H'00000000         | 1         |  |  |
| H'00000000        | H'******         | H'00000000        | H'00000000         | 0         |  |  |
| H'00000000        | H'00000000       | H'00000000        | H'00000000         | 1         |  |  |

Note: H'\*\*\*\* is a hexadecimal number.

- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.31), set 0's in them; otherwise, no correct result can be obtained because division is done on the numbers including indeterminate data placed in the upper bits.



### Figure 7.31 Example of Division with Upper Bits Unused

- b. After execution of the software DIVD, the dividend is destroyed because the quotient is placed in R0 and R1. If the dividend is necessary after software DIVD execution, save it on memory.
- 3. Data memory

The software DIVD does not use the data memory.

# 4. Example of use

Set a dividend and a divisor in the registers and call the software DIVD as a subroutine.

| WORK1 | .RES. W 2                                                                            | Reserves a data memory area in which the user program places an 8-digit BCD dividend.                                            |
|-------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| WORK2 | .RES. W 2                                                                            | Reserves a data memory area in which the user program places an 8-digit BCD divisor.                                             |
| WORK3 | .RES. W 2                                                                            | Reserves a data memory area in which the user program places an 8-digit BCD quotient.                                            |
| WORK4 | .RES. W 2                                                                            | Reserves a data memory area in which the user program places an 8-digit BCD remainder.                                           |
|       | .i<br>MOV. W @WORK1, R0                                                              | Places in the input argument (R0 and R1)<br>the 8-digit BCD dividend set by the user<br>program.                                 |
|       | MOV. W @WORK2, R2<br>MOV. W @WORK2+2, R3 ∫                                           | Places in the input argument (R2 and R3) the 8-digit BCD divisor set by the user program.                                        |
|       | JSR @DIVD                                                                            |                                                                                                                                  |
|       | BEQ ERROR                                                                            | Branches to the error (division by 0)<br>processing routine if an error (division by<br>0) has occurred as a result of division. |
|       | MOV. W R0, @WORK3<br>MOV. W R1, @WORK3+2<br>MOV. W R4, @WORK4<br>MOV. W R5, @WORK4+2 | Places the result (set in the output argument) in the data memory of the user program.                                           |
|       |                                                                                      |                                                                                                                                  |
| ERROR | Division-by-0 processing routine                                                     |                                                                                                                                  |
|       |                                                                                      |                                                                                                                                  |

- 5. Operation
  - a. Division of decimal numbers can be done by performing a series of subtractions.
     Figure 7.32 shows an example of division (64733088 ÷ 5).



Figure 7.32 Example of Division (64733088 ÷ 5)

- b. The program runs in the following steps:
  - (i) The dividend is shifted 4 bits (1 digit of the BCD) to the left to place the upper 4 bits of the dividend in the lower 4 bits of the result of division (remainder).
  - (ii) The divisor is subtracted from the dividend. Subtractions are repeated until the result becomes negative. The number of subtractions thus done is placed in the lower 4 bits (the least significant digit) of the dividend. ((2)→(3)→(1) in figure 7.32) When the result has become negative, the divisor is added to the result (remainder) to return to the value before subtractions. ((4) in figure 7.32)
  - (iii) The steps (i) to (ii) are repeated as many times as 8 digits.







# 7.10.8 Program List

\*\*\* H8/300 ASSEMBLER

|                                              | ;*** | ******           | ******                | *****          | *******                                      |
|----------------------------------------------|------|------------------|-----------------------|----------------|----------------------------------------------|
|                                              | ;*   |                  |                       |                |                                              |
|                                              |      | 00 - NA          | ME ;I                 | MULTIPL        | E-PRECISION DECIMAL DIVISION (DIVD)          |
|                                              | ;*   | *******          | *********             | ******         | ******                                       |
|                                              | ;*** | ******           | * * * * * * * * * * * | ******         | ~ ~ ~ ~ ~ ~ * * * * * * * * * * * * * *      |
|                                              | ;*   | ENTRY            | :1                    | R2,R3          | (DIVISOR)                                    |
|                                              | ;*   |                  |                       | R0,R1          | (DIVIDEND)                                   |
|                                              | ; *  |                  |                       |                |                                              |
|                                              | ;*   | RETURNS          | :1                    | R0,R1          | (QUOTIENT)                                   |
|                                              | ;*   |                  | 1                     | R4,R5          | (RESIDUAL)                                   |
|                                              | ;*   |                  | :                     | Z flag         | OF CCR (Z=1;FALSE , Z=0;TRUE)                |
|                                              | ;*   |                  |                       |                |                                              |
|                                              |      | ******           | ********              | ******         | **************                               |
| DIVD and C 0000                              | ;    | .SECTIO          | N                     | TVD and        | CODE ALICN-2                                 |
| DIVD_cod C 0000                              |      | .SECTIO          |                       | IVD_cod<br>IVD | ≥,CODE,ALIGN=2                               |
|                                              | ;    | . BAFORI         | D.                    | 1 V D          |                                              |
| DIVD_cod C 000000                            |      | .EQU             | \$                    |                | Entry point                                  |
| DIVD_cod C 0000 7904000                      |      |                  | +H'0000,R             |                | Clear R4                                     |
| DIVD_cod C 0004 0D45                         |      |                  | R4,R5                 |                | Clear R5                                     |
| DIVD_cod C 0006 1D42                         |      | CMP.W            | R4,R2                 |                |                                              |
| DIVD_cod C 0008 4604                         |      |                  | LBL1                  |                | Branch if Z=0                                |
| DIVD_cod C 000A 1D53                         |      |                  | R5,R3                 |                |                                              |
| DIVD_cod C 000C 4744                         |      |                  | EXIT                  |                | Branch if Z=1 then exit                      |
| DIVD_cod C 000E                              | LBL1 |                  | #U100 DCT             |                | Set bit counterl                             |
| DIVD_cod C 000E FE08<br>DIVD_cod C 0010      | LBL2 |                  | #H'08,R6L             |                | Set bit counterl                             |
| DIVD_cod C 0010<br>DIVD_cod C 0010 F604      |      |                  | #H'04,R6H             |                | ;Set bit counter2                            |
| DIVD_cod C 0012                              | LBL3 |                  |                       |                |                                              |
| DIVD_cod C 0012 1009                         |      | SHLL.B           | R1L                   |                | Shift dividend                               |
| DIVD_cod C 0014 1201                         |      | ROTXL.B          |                       |                |                                              |
| DIVD_cod C 0016 1208                         |      | ROTXL.B          | ROL                   |                |                                              |
| DIVD_cod C 0018 1200                         |      | ROTXL.B          |                       |                |                                              |
| DIVD_cod C 001A 120D                         |      | ROTXL.B          |                       |                |                                              |
| DIVD_cod C 001C 1205                         |      | ROTXL.B          |                       |                |                                              |
| DIVD_cod C 001E 120C                         |      | ROTXL.B          |                       |                |                                              |
| DIVD_cod C 0020 1204<br>DIVD_cod C 0022 1A06 |      | ROTXL.B<br>DEC.B |                       |                | Decrement bit counter2                       |
| DIVD_cod C 0022 1A06                         |      |                  | LBL3                  |                | Branch if Z=0                                |
| DIVD_cod C 0024 40EC                         | LBL4 |                  |                       |                |                                              |
| DIVD_cod C 0026 0A09                         |      | INC.B            | R1L                   |                | Increment R1L                                |
| DIVD_cod C 0028 18BD                         |      | SUB.B            | R3L,R5L               |                | 785L - R3L -> R5L                            |
| DIVD_cod C 002A 1F0D                         |      | DAS.B            | R5L                   |                | Decimal adjust R5L                           |
| DIVD_cod C 002C 1E35                         |      |                  | R3H,R5H               |                | R5H - R3H - C -> R3H                         |
| DIVD_cod C 002E 1F05                         |      | DAS.B            |                       |                | Decimal adjust R5H                           |
| DIVD_cod C 0030 1EAC                         |      |                  | R2L,R4L               |                | 7R4L - R2L - C -> R4L                        |
| DIVD_cod C 0032 1F0C                         |      | DAS.B            |                       |                | Decimal adjust R4L                           |
| DIVD_cod C 0034 1E24<br>DIVD_cod C 0036 1F04 |      | SUBX.B<br>DAS.B  | R2H,R4H<br>R4H        |                | ;R4H - R2H - C -> R4H<br>;Decimal adjust R4H |
| DIVD_cod C 0038 44EC                         |      |                  | LBL4                  |                | Branch if C=0                                |
| 304 C 0030 7460                              | ;    |                  |                       |                |                                              |
| DIVD_cod C 003A 08BD                         |      | ADD.B            | R3L,R5L               |                | R3L + R5L -> R5L                             |
| DIVD_cod C 003C 0F0D                         |      | DAA.B            |                       |                | Decimal adjust R5L                           |
| DIVD_cod C 003E 0E35                         |      | ADDX.B           | R3H,R5H               |                | ;R3H + R5H + C -> R5H                        |
| DIVD_cod C 0040 0F05                         |      | DAA.B            | R5H                   |                | Decimal adjust R5H                           |
| DIVD_cod C 0042 0EAC                         |      |                  | R2L,R4L               |                | R2L + R4L + C -> R4L                         |
| DIVD_cod C 0044 0F0C                         |      | DAA.B            |                       |                | Decimal adjust R4L                           |
| DIVD_cod C 0046 0E24                         |      |                  | R2H,R4H               |                | ;R2H + R4H + C -> R4H                        |
| DIVD_cod C 0048 0F04                         |      |                  | R4H                   |                | Decimal adjust R4H                           |
| DIVD_cod C 004A 1A09<br>DIVD_cod C 004C 1A0E |      | DEC.B<br>DEC.B   | R1L<br>R6L            |                | ;Decrement RlL<br>;Decrement bit counterl    |
|                                              |      |                  |                       |                |                                              |

VER 1.0B \*\* 08/18/92 10:02:05



PAGE 1

| 64 DIVD_cod C 0050 06FB |     | ANDC.B | #B'11111011,CCR | ;Clear Z | flag of | CCR |
|-------------------------|-----|--------|-----------------|----------|---------|-----|
| 65 DIVD_cod C 0052      | EXI | IT     |                 |          |         |     |
| 66 DIVD_cod C 0052 5470 |     | RTS    |                 |          |         |     |
| 67                      | ;   |        |                 |          |         |     |
| 68                      |     | .END   |                 |          |         |     |
| *****TOTAL ERRORS (     | )   |        |                 |          |         |     |
| *****TOTAL WARNINGS     | )   |        |                 |          |         |     |
|                         |     |        |                 |          |         |     |
# 7.11 Addition of Multiple-Precision BCD Numbers

MCU: H8/300 Series H8/300L Series

Label name: ADDD2

## 7.11.1 Function

- 1. The software ADDD2 adds a multiple-precision binary-coded decimal (BCD) number to another multiple-precision BCD number and places the result in the data memory where the augend was placed.
- 2. The arguments used with the software ADDD2 are unsigned integers, each being up to 255 bytes long.

#### 7.11.2 Arguments

| Description |                                         | Memory area  | Data length (bytes) |
|-------------|-----------------------------------------|--------------|---------------------|
| Input       | Augend and addend byte count            | R0L          | 1                   |
|             | Start address of augend                 | R3           | 2                   |
|             | Start address of addend                 | R4           | 2                   |
| Output      | Start address of the result of addition | R3           | 2                   |
|             | Error                                   | Z flag (CCR) | 1                   |
|             | Carry                                   | C flag (CCR) | 1                   |

#### 7.11.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| ×  | ×  | ×  | \$ | ×  | ×  | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| 1  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | \$ | ×  | \$ |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result



## 7.11.5 Notes

The clock cycle count (7680) in the specifications is for addition of 255 bytes to 255 bytes.

## 7.11.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software ADDD2:
    - R0L: Contains, as an input argument, the byte count of an augend and an addend in 2digit hexadecimals.
    - R3: Contains the start address of the augend in the data memory area. The start address of the result of addition is placed in this register after execution of the software ADDD2.
    - R4: Contains, as an input argument, the start address of the addend in the data memory area.

- Z flag (CCR): Indicates an error in data length as an output argument.
- Z flag = 0: The data byte count (R0L) was not 0.
- Z flag = 1: The data byte count (R0L) was 0 (indicating an error).
- C flag (CCR): Determines the presence or absence of a carry, as an output argument, after execution of the software ADDD2.
- C flag = 0: No carry occurred in the result of addition.
- C flag = 1: A carry occurred in the result of addition (see figure 7.28).
- b. Figure 7.33 shows an example of the software ADDD2 being executed. When the input arguments are set as shown in 1., the result of addition is placed in the data memory area as shown in 2..

|                      | Addition data byte count         | R0L (H'04)      |                  | 0 4     |
|----------------------|----------------------------------|-----------------|------------------|---------|
|                      | Start address of augend          | R3 (H'F000)     | F 0              | 0 0     |
| (1) Input arguments  | Start address of addend          | R4 (H'F100)     | F 1              | 0 0     |
|                      |                                  | Γ               | Data memory area |         |
|                      | Augend                           | 2 9 8           | 3 7 8            | 0 4     |
|                      |                                  | (H'F000         | ~                | H'F003) |
|                      | Addend                           | 6 3 4           | 8 9 1            | 2 0     |
|                      | +)                               | (H'F100         | ~                | H'F103) |
|                      | ~                                | Ļ               |                  |         |
|                      | Start address of result of addit | ion R3 (H'F000) | F 0              | 0 0     |
| (2) Output arguments |                                  | Z flag          | 0                |         |
| (2) Output arguments |                                  | C flag          | 0                |         |
|                      |                                  | C               | Data memory area |         |
|                      | Result of addition               | 9 3 3           | 2 6 9            | 2 4     |
|                      |                                  | (H'F000         | ~                | H'F003) |

Figure 7.33 Example of Software ADDD2 Execution

Figure 7.34 shows an example of addition with a carry that occurred in the result.



Figure 7.34 Example of Addition with a Carry

- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.35), set 0's in them. The software ADDD2 performs byte-based addition; if 0's are not set in the upper bits unused, no correct result can be obtained because the addition is done on the numbers including indeterminate data.



Figure 7.35 Example of Addition with Upper Bits Unused

- b. After execution of the software ADDD2, the augend is destroyed because the result is placed in the data memory area where the augend was set. If the augend is necessary after software ADDD2 execution, save it on memory.
- 3. Data memory

The software ADDD2 does not use the data memory.

#### 4. Example of use

This is an example of adding 8 bytes of data. Set the start addresses of a byte count, an augend, and an addend in the registers and call the software ADDD2 as a subroutine.

| WORK1 | .RES. B                | 1                |   | Reserves a data memory area in which the user program places a byte count.                                                                                                           |
|-------|------------------------|------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WORK2 | .RES. B                | 8                |   | Reserves a data memory area in which the user program places an 8-byte (16-digit BCD) augend.                                                                                        |
| WORK3 | .RES. B<br>i<br>MOV. B | 8<br>@WORK1, R0L |   | Reserves a data memory area in which the<br>user program places an 8-byte (16-digit<br>BCD) addend.<br>Places in the input argument (R0L) the<br>byte count set by the user program. |
|       | MOV. W                 | #WORK2, R3       |   | Places in the input argument (R3) the start<br>address of the augend set by the user<br>program.                                                                                     |
|       | MOV. W                 | #WORK3, R4       |   | Places in the input argument (R4) the start<br>address of the addend set by the user<br>program.                                                                                     |
|       | JSR                    | @ADDD2           | ( | Call the software ADDD2 as a subroutine.                                                                                                                                             |
|       | BCS                    | OVER             |   | Branches to the carry processing routine if<br>a carry has occurred in the result of<br>addition.                                                                                    |
| OVER  | Carry proce            | ssing routine.   |   |                                                                                                                                                                                      |

## 5. Operation

- a. Addition of multiple-precision BCD numbers can be done by performing a series of 1-byte add instructions (ADDX.B) with decimal-correct instructions (DAA) as the augend and addend data are placed in registers, 2 digits in 1 byte.
- b. The address of the least significant byte of the data memory area for the augend is placed in R3, and the address of the least significant byte of the data memory area for the addend in R4.
- c. R1L that is used for saving the C flag is cleared. .

d. The augend and addend are loaded in R2L and R2H respectively, byte by byte, starting at their least significant byte and then equation 1 is executed:
where the C flag indicates a carry that may occur in the result of addition of the lower bytes.

 $\begin{array}{c} \text{R2L (augend)} + \text{R2H (addend)} + \text{C} \rightarrow \text{R2L} \\ \text{Decimal correction of } \text{R2L} \rightarrow \text{R2L} \\ \text{R2L} \rightarrow @\text{R3} \end{array} \right\} \quad \cdots \cdots \text{equation 1}$ 

- e. The result of (d) is placed in the data memory area for the augend.
- f. R3, R4, and R0L are decremented each time the process d. to e. terminates. This processing is repeated until R0L reaches 0.





## 7.11.8 Program List

\*\*\* H8/300 ASSEMBLER VER 1.0B \*\* 08/18/92 10:02:42 PROGRAM NAME = 1 2 ;\* ;\* :MULTIPLE-PRECISION DECIMAL ADDITION 3 00 - NAME ;\* 4 (ADDD2) 5 ;\* 6 7 ;\* 8 ;\* ENTRY :R0L (BYTE COUNTER OF ADDTION DATA) 9 ;\* R3 (START ADDRESS OF AUGEND) 10 ; \* R4 (START ADDRESS OF ADDEND) 11 ;\* 12 ;\* RETURNS :R3 (START ADDRESS OF RESULT) ;\* Z flag OF CCR (Z=0;TRUE,Z=1;FALSE) 13 14 ;\* C flag OF CCR (C=0;TRUE,C=1;OVERFLOW) 15 ;\* 16 17 ; 18 ADDD2\_co C 0000 .SECTION ADDD2\_code,CODE,ALIGN=2 19 .EXPORT ADDD2 20 ; 21 ADDD2\_co C 00000000 ADDD2 .EQU \$ ;Entry point 22 ADDD2\_co C 0000 F000 MOV.B #H'00,R0H ;Clear R0H 23 ADDD2\_co C 0002 0C81 MOV.B ROL,R1H ;Clear R1H 24 ADDD2\_co C 0004 4724 BEQ EXIT ;Branch if Z=1 then exit 25 ADDD2\_co C 0006 0D35 MOV.W R3,R5 26 ADDD2\_co C 0008 MAIN 27 ADDD2\_co C 0008 1B00 SUBS.W #1,R0 ;Decrement R0 28 ADDD2\_co C 000A 0905 ADD.W R0,R5 ;Set end address to summand pointer 29 ADDD2\_co C 000C 0904 ADD.W R0,R4 ;Set end address to addend pointer 30 ADDD2 co C 000E F900 MOV.B #H'00,R1L ;Clear R1L 31 ADDD2 co C 0010 LOOP 32 ADDD2\_co C 0010 685A MOV.B @R5,R2L ;Load summand data 33 ADDD2\_co C 0012 6842 MOV.B @R4,R2H ;Load addend data #0,R1L 34 ADDD2 co C 0014 7709 BLD ;Bit load bit 0 of R1L 35 ADDD2\_co C 0016 0E2A ADDX.B R2H,R2L ;R2H + R2L + C -> R2L 36 ADDD2 co C 0018 0F0A DAA R2L ;Decimal adjust R1L 37 ADDD2\_co C 001A 6709 BST #0,R1L ;Store C falg to bit 0 of R1L 38 ADDD2\_co C 001C 68DA MOV.B R2L,@R5 ;Store struct 39 ADDD2\_co C 001E 1B05 SUBS.W #1,R5 ;Decrement summand pointer SUBS.W #1,R4 40 ADDD2\_co C 0020 1B04 ;Decrement addend pointer DEC.B R1H 41 ADDD2 co C 0022 1A01 Decrement R1H 42 ADDD2\_co C 0024 46EA BNE LOOP :Branch if Z=0 43 ; 44 ADDD2 co C 0026 7709 BLD #0,R1L ;Load bit 0 of R1L to C flag ANDC.B #H'FB.CCR 45 ADDD2 co C 0028 06FB ;Clear Z flag of CCR 46 ADDD2 CO C 002A EXIT 47 ADDD2 co C 002A 5470 RTS 48 ; END 49 \*\*\*\*\*TOTAL ERRORS 0 \*\*\*\*\*TOTAL WARNINGS 0

# 7.12 Subtraction of Multiple-Precision BCD Numbers

MCU: H8/300 Series H8/300L Series

Label name: SUBD2

## 7.12.1 Function

- 1. The software SUBD2 subtracts a multiple-precision binary-coded decimal (BCD) number from another multiple-precision BCD number and places the result in the data memory where the minuend was set.
- 2. The arguments used with the software SUBD2 are unsigned integers, each being up to 255 bytes long.

#### 7.12.2 Arguments

| Description |                                   | Memory area  | Data length (bytes) |
|-------------|-----------------------------------|--------------|---------------------|
| Input       | Minuend and subtrahend byte count | R0L          | 1                   |
|             | Start address of minuend          | R3           | 2                   |
|             | Start address of subtrahend       | R4           | 2                   |
| Output      | Start address of result           | R3           | 2                   |
|             | Error                             | Z flag (CCR) | 1                   |
|             | Borrow                            | C flag (CCR) | 1                   |

#### 7.12.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| ×  | ×  | ×  | \$ | ×  | ×  | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | \$ | ×  | \$ |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |
|------------------------|
| 44                     |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 7680                   |
| Reentrant              |
| Possible               |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |
|                        |

## 7.12.5 Notes

The clock cycle count (7680) in the specifications is for subtraction of 255 bytes from 255 bytes.

#### 7.12.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software SUBD2:
    - R0L: Contains, as an input argument, the byte count of a minuend and the byte count of a subtrahend in 2-digit hexadecimals.
    - R3: Contains, as an input argument, the start address of the data memory area where the minuend is placed. After execution of the software SUBD2, the start address of the result is placed in this register.
    - R4: Contains, as an input argument, the start address of the data memory area where the subtrahend is placed.
    - Z flag (CCR): Indicates an error in data length as an output argument.

- Z flag = 0: The data byte count (R0L) was not 0.
- Z flag = 1: The data byte count (R0L) was 0, indicating an error.
- C flag (CCR): Determines the presence or absence of a borrow after software SUBD2 execution as an output argument.
- C flag = 0: No borrow occurred in the result.
- C flag = 1: A borrow occurred in the result. (See figure 7.36)
- b. Figure 7.36 shows an example of the software SUBD2 being executed. When the input arguments are set as shown in (1), the result of subtraction is placed in the data memory area as shown in (2).

|                      | Subtraction data byte count    | R0L (H'04)           |                 | 0 4     |
|----------------------|--------------------------------|----------------------|-----------------|---------|
|                      | Start address of minuend       | R3 (H'F000)          | F 0             | 0 0     |
| (1) Input arguments  | Start address of subtrahend    | R4 (H'F100)          | F   1           | 0 0     |
|                      |                                | D                    | ata memory area |         |
|                      | Minuend                        | 8 9 8                | 3 7 8           | 0 4     |
|                      |                                | (H'F000              | ~               | H'F003) |
|                      | Subtrahend                     | 6 3 4                | 8 9 1           | 2 0     |
|                      | —)                             | (H'F100              | ~               | H'F103) |
|                      |                                | ļ                    |                 |         |
|                      | Start address of result of sub | traction R3 (H'F000) | F 0             | 0 0     |
| (2) Output arguments |                                | Z flag               | 0               |         |
| (2) Output arguments |                                | C flag               | 0               |         |
|                      |                                | D                    | ata memory area |         |
|                      | Result of subtraction          | 2 6 3                | 4 8 6           | 8 4     |
| (                    |                                | (H'F000              | ~               | H'F003) |

## Figure 7.36 Example of Software SUBD2 Execution

Figure 7.37 shows an example of subtraction with a borrow that has occurred in the result.



Figure 7.37 Example of Subtraction with a Borrow

- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.38), set 0's in them. The software SUBD2 performs byte-based subtraction; if 0's are not set in the upper bits unused, no correct result can be obtained because the subtraction is done on the numbers including indeterminate data.



Figure 7.38 Example of Subtraction with Upper Bits Unused

- b. After execution of the software SUBD2, the minuend is destroyed because the result is placed in the data memory area where the minuend was set. If the minuend is necessary after software SUBD2 execution, save it on memory.
- 3. Data memory

The software SUBD2 does not use the data memory.

4. Example of use

This is an example of subtracting 8 bytes of data. Set the start addresses of a byte count, a minuend and a subtrahend in the registers and call the software SUBD2 as a subroutine.



- 5. Operation
  - a. Subtraction of multiple-precision binary numbers can be done by repeating a 1-byte subtract instruction (SUBX.B) and a decimal-correct instruction (DAA) as the minuend and subtrahend data are placed in registers, 2 digits in 1 byte.
  - b. The least significant byte of the data memory area for the minuend is placed in R3, and the least significant byte of the data memory area for the subtrahend in R4.
  - c. R1L that is used for saving the C flag is cleared.
  - d. The minuend and subtrahend are loaded in R2L and R2H respectively, byte by byte, starting at their least significant byte and equation 1 is executed:

 $\begin{array}{c} \text{R2L (minuend)} - \text{R2H (subtrahend)} - \text{C} \rightarrow \text{R2L} \\ \text{Decimal correction of } \text{R2L} \rightarrow \text{R2L} \\ \text{R2L} \rightarrow @\text{R3} \end{array} \right\} \quad \dots \dots \text{ equation 1}$ 

where the C flag indicates a borrow that may occur in the result of subtraction of the lower bytes.

- e. The result of d. is placed in the data memory area for the minuend.
- f. R3, R4, and R0L are decremented each time the process d. to e. terminates. This processing is repeated until R0L reaches 0.





## 7.12.8 Program List

\*\*\* H8/300 ASSEMBLER VER 1.0B \*\* 08/18/92 10:03:31 PROGRAM NAME = 1 2 ;\* ;\* :MULTIPLE-PRECISION DECIMAL SUBSTRUCTION 3 00 - NAME ;\* 4 (SUBD2) 5 ;\* 6 7 ;\* 8 ;\* ENTRY :ROL (BYTE LENGTH OF DATA) 9 ;\* R3 (START ADDRESS OF MINUEND) 10 ; \* R4 (START ADDRESS OF SUBSTRAHEND) ;\* 11 12 ; \* RETURNS :R3 (START ADDRESS OF RESULT) ;\* Z BIT OF CCR (Z=0;TRUE , Z=1;FALSE) 13 14 ;\* C BIT OF CCR (C=0;TRUE , C=1;OVERFLOW) 15 ;\* 16 17 ; 18 SUBD2\_co C 0000 .SECTION SUBD2\_code,CODE,ALIGN=2 19 .EXPORT SUBD2 20 ; 21 SUBD2\_co C 00000000 SUBD2 .EQU \$ ;Entry point 22 SUBD2\_co C 0000 F000 MOV.B #H'00,R0H ;Clear R0H 23 SUBD2\_co C 0002 0C81 MOV.B ROL,R1H ;Set byte counter 24 SUBD2\_co C 0004 4724 BEQ EXIT ;Branch if Z=1 then exit 25 SUBD2\_co C 0006 0D35 MOV.W R3,R5 26 SUBD2\_co C 0008 MAIN 27 SUBD2\_co C 0008 1B00 SUBS.W #1,R0 ;Decrement byte length 28 SUBD2\_co C 000A 0905 ADD.W R0,R5 ;Set end address of minuend 29 SUBD2\_co C 000C 0904 ADD.W R0,R4 ;Set end address of substrahend 30 SUBD2 co C 000E F900 MOV.B #H'00,R1L ;Clear R1L 31 SUBD2 co C 0010 LOOP 32 SUBD2\_co C 0010 685A MOV.B @R5,R2L ;Load minuend data 33 SUBD2\_co C 0012 6842 MOV.B @R4,R2H ;Load substrahend data #0,R1L 34 SUBD2 co C 0014 7709 BLD. ;Bit load bit 0 of R1L 35 SUBD2\_co C 0016 1E2A SUBX.B R2H,R2L ;R2L - R2H - C -> R2L DAS R2L 36 SUBD2 co C 0018 1F0A ;Decimal adjust R2L 37 SUBD2\_co C 001A 6709 BST #0,R1L ;Bit store bit 0 of R1L 38 SUBD2\_co C 001C 68DA MOV.B R2L,@R5 ;Store result 39 SUBD2\_co C 001E 1B05 SUBS.W #1,R5 ;Decrement minuend pointer SUBS.W #1,R4 40 SUBD2\_co C 0020 1B04 ;Decrement substrahend pointer DEC.B R1H 41 SUBD2 co C 0022 1A01 ;Decrement byte counter 42 SUBD2\_co C 0024 46EA BNE LOOP :Branch if Z=0 43 ; 44 SUBD2 co C 0026 7709 BLD #0,R1L ;Bit load bit 0 of R1L ANDC.B #H'FB,CCR 45 SUBD2 CO C 0028 06FB ;Clear Z bit 46 SUBD2 CO C 002A EXIT 47 SUBD2 co C 002A 5470 RTS 48 ; END 49 \*\*\*\*\*TOTAL ERRORS 0 \*\*\*\*\*TOTAL WARNINGS 0

# 7.13 Addition of Signed 32-Bit Binary Numbers

MCU: H8/300 Series H8/300L Series

Label name: SADD

## 7.13.1 Function

- 1. The software SADD adds a signed 32-bit binary number to another signed 32-bit binary number and places the result in a general-purpose register.
- 2. The arguments used with the software SADD are signed integers.
- 3. All data is manipulated on general-purpose registers.

#### 7.13.2 Arguments

| Descript | ion                | Memory area  | Data length (bytes) |
|----------|--------------------|--------------|---------------------|
| Input    | Augend             | R0, R1       | 4                   |
|          | Addend             | R2, R3       | 4                   |
| Output   | Result of addition | R0, R1       | 4                   |
|          | Carry              | V flag (CCR) | 1                   |

## 7.13.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| \$ | \$ | •  | •  | •  | •  | ×  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | ×  | ×  | ×  | ×  | ×  | \$ | ×  |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program | memory (bytes) |  |
|---------|----------------|--|
|         | 20             |  |
| Data n  | nemory (bytes) |  |
|         | 0              |  |
| Sta     | ack (bytes)    |  |
|         | 0              |  |
| Cloc    | k cycle count  |  |
|         | 44             |  |
| F       | Reentrant      |  |
|         | Possible       |  |
| R       | elocation      |  |
|         | Possible       |  |
|         | Interrupt      |  |
|         | Possible       |  |
|         | Possible       |  |

## 7.13.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software SADD:
    - (i) Input arguments:

R0, R1: Contain a signed 32-bit binary augend.

R2, R3: Contain a signed 32-bit binary addend.

- (ii) Output arguments
  - R0, R1: Contain the result of addition (a signed 32-bit binary number)

V flag (CCR): Determines the presence or absence of a carry as a result of addition.

- V flag = 1: A carry occurred in the result.
- V flag = 0: No carry occurred in the result.

b. Figure 7.39 shows an example of the software SADD being executed. When the input arguments are set as shown in 1., the result of addition is placed in R0 and R1 as shown in 2..



Figure 7.39 Example of Software SADD Execution

- 2. Notes on usage
  - a. After execution of the software SADD, the augend is destroyed because the result is placed in R0 and R1. If the augend is necessary after software SADD execution, save it on memory.
- 3. Data memory

The software SADD does not use the data memory.

#### 4. Example of use

Set an augend and an addend in the input arguments and call the software SADD as a subroutine.



- 5. Operation
  - a. Addition of signed 32-bit binary numbers is done by using add instructions (ADD.W and ADDX.B).
  - b. The addition steps are as follows:
    - (i) An augend is placed in R0 and R1 and an addend in R2 and R3.
    - (ii) The user bits (bits 6 and 4) and the overflow flag (bit 2) are cleared.
    - (iii) If the augend is negative, sign bit "1" is placed in the user bit (bit 6) of the CCR. If the addend is negative, sign bit "1" is placed in the user bit (bit 4) of the CCR.
    - (iv) The augend is added to the addend as follows:

(v) Whether to continue processing or clear the V flag is determined depending on the state of the sign bit (CCR user bit):

| <sign bit=""></sign>  |                 |                                     |
|-----------------------|-----------------|-------------------------------------|
| Bit 6 of CCR (Augend) | Bit 4 of CCR (A | ddend)                              |
| 0                     | 0               | $\rightarrow$ Continues processing. |
| 0                     | 1 ]             | $\rightarrow$ Clears the V flag.    |
| 1                     | 0 )             | $\rightarrow$ Clears the v flag.    |
| 1                     | 1               | $\rightarrow$ Continues processing. |





# 7.13.7 Program List

| *** H8/300 ASSEMBLER                               | VER 1.0B ** | 08/18/92  | 10:15:08                      |                                                  |
|----------------------------------------------------|-------------|-----------|-------------------------------|--------------------------------------------------|
| PROGRAM NAME =                                     |             |           |                               |                                                  |
| 1                                                  | ;****       | *****     | * * * * * * * * * * * * * * * | ************                                     |
| 2                                                  | ;*          |           |                               |                                                  |
| 3                                                  | ;* 0        | 0 - NAME  | SIGNED                        | 32 BIT BINARY ADDITION (SADD)                    |
| 4                                                  | ;*          |           |                               |                                                  |
| 5                                                  | ;****       | *****     | * * * * * * * * * * * * * * * | ************                                     |
| б                                                  | ;*          |           |                               |                                                  |
| 7                                                  | ;* E        | INTRY     | :R0                           | (UPPER WORD OF SUMMAND)                          |
| 8                                                  | ;*          |           | Rl                            | (LOWER WORD OF SUMMAND)                          |
| 9                                                  | ;*          |           | R2                            | (UPPER WORD OF ADDEND)                           |
| 10                                                 | ;*          |           | R3                            | (LOWER WORD OF ADDEND)                           |
| 11                                                 | ; *         |           |                               |                                                  |
| 12                                                 | ;* R        | ETURNS    | :R0                           | (UPPER WORD OF RESULT)                           |
| 13                                                 | ;*          |           | Rl                            | (LOWER WORD OF RESULT)                           |
| 14                                                 | ;*          |           | V FLAG                        | OF CCR                                           |
| 15                                                 | ;*          |           |                               | (V=0;TRUE,V=1:OVERFLOW OR UNDERFLOW)             |
| 16                                                 | ;*          |           |                               |                                                  |
| 17                                                 | ;****       | ******    | * * * * * * * * * * * * * *   | **********                                       |
| 18                                                 | ,           |           |                               |                                                  |
| 19 SADD cod C 0000                                 |             | SECTION   | SADD cod                      | de,CODE,ALIGN=2                                  |
| 20                                                 |             | EXPORT    | SADD                          |                                                  |
| 21                                                 | ,           |           |                               |                                                  |
| 22 SADD_cod C 00000000                             | SADD .      | EQU \$    |                               | Entry point                                      |
| 23 SADD cod C 0000 06AD                            |             | NDC #H    |                               | Clear user bits and V flag of CCR                |
| 24 SADD_cod C 0002 7770                            |             |           |                               | Load sign bit of summand                         |
| 25 SADD_cod C 0004 4402                            |             | SCC LBI   |                               | Branch if C=0                                    |
| 26 SADD_cod C 0006 0440                            |             |           |                               | Bit set user bit (bit 6 of CCR)                  |
| 27 SADD_cod C 0008                                 | LBL1        |           | ,                             | int inter pie (pie o or con)                     |
| 28 SADD_cod C 0008 7772                            |             | 3LD #7    | ,R2H                          | ;Load sign bit of addend                         |
| 29 SADD_cod C 000A 4402                            |             | CC LB     |                               | Branch if C=0                                    |
| 30 SADD_cod C 000C 0410                            |             |           |                               | Bit set user bit (bit 4 of CCR)                  |
| 31 SADD_cod C 000E                                 | LBL2        |           | ,con                          | int int int (int i of con)                       |
| 32 SADD_cod C 000E 0931                            |             | DD.W R3   | R1                            | ;R3 + R1 -> R1                                   |
| 33 SADD_cod C 0001 0551                            |             | DDX.B R21 |                               | <pre>/RS + RI<br/>/R2L + R0L + C -&gt; R0L</pre> |
| 34 SADD_cod C 0012 0E20                            |             | DDX.B R21 |                               | $R_{2H} + R_{0H} + C \rightarrow R_{0H}$         |
| 35 SADD_cod C 0014 020E                            |             |           |                               | /CCR -> R6L                                      |
| 36 SADD_cod C 0016 776E                            |             |           |                               | Bit load bit 4 of R6L                            |
| 37 SADD_cod C 0018 754E                            |             | XOR #4    |                               | Bit exclusive OR sign bits                       |
| 38 SADD_cod C 001A 4402                            |             |           |                               | Barnch if C=0                                    |
| 38 SADD_cod C 001A 4402<br>39 SADD_cod C 001C 06FD |             |           |                               | Clear V flag                                     |
| 40 SADD_cod C 001E                                 | LBL3        | 412C.D #R | 10,000                        | , cicar , riag                                   |
| 40 SADD_cod C 001E 5470                            |             | TS        |                               |                                                  |
| 41 SADD_COM C 001E 5470<br>42                      | ;           | .1.0      |                               |                                                  |
| 42                                                 |             | END       |                               |                                                  |
|                                                    |             | LIND      |                               |                                                  |
| ****TOTAL ERRORS 0                                 |             |           |                               |                                                  |
| *****TOTAL WARNINGS 0                              |             |           |                               |                                                  |

# 7.14 Multiplication of Signed 16-Bit Binary Numbers

MCU: H8/300 Series H8/300L Series

Label name: SMUL

## 7.14.1 Function

- 1. The software SMUL multiplies a signed 16-bit binary number to another signed 162-bit binary number and places the result in a general-purpose register.
- 2. The arguments used with the software SMUL are signed integers.
- 3. All data is manipulated on general-purpose registers.

#### 7.14.2 Arguments

| Descript | ion                      | Memory area | Data length (bytes) |
|----------|--------------------------|-------------|---------------------|
| Input    | Multiplicand             | R1          | 2                   |
|          | Multiplier               | R0          | 2                   |
| Output   | Result of multiplication | R1, R2      | 4                   |

## 7.14.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6H | R6L R7 |  |
|----|----|----|----|----|----|-----|--------|--|
| ×  | \$ | \$ | ×  | ×  | •  | •   | × •    |  |
|    |    |    |    |    |    |     |        |  |
| I  | U  | Н  | U  | Ν  | Z  | V   | С      |  |
| •  | ×  | ×  | ×  | ×  | ×  | ×   | ×      |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |
|------------------------|
| 52                     |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 132                    |
| Reentrant              |
| Possible               |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |
|                        |

# 7.14.5 Notes

The clock cycle count (132) in the specifications is a maximum cycle count.

## 7.14.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software SMUL:
    - (i) Input arguments:

R0: Contains a signed 16-bit binary multiplier.

R1: Contains a signed 162-bit binary multiplicand.

(ii) Output arguments

R1, R2: Contain the result of multiplication (a signed 16-bit binary number)

b. Figure 7.40 shows an example of the software SMUL being executed. When the input arguments are set as shown in (1), the result of multiplication is placed in R1 and R2 as shown in (2).



Figure 7.40 Example of Software SMUL Execution

- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.41), set 0's in them; otherwise, no correct result can be obtained because multiplication is done on the numbers including indeterminate data placed in the upper bits. (The upper bits referred to here do not include sign bits.)



Figure 7.41 Example of Multiplication with Upper Bits Unused

- b. After execution of the software SMUL, the multiplicand is destroyed because the upper 2 bytes of the result are placed in R1. If the multiplicand is necessary after software SMUL execution, save it on memory.
- 3. Data memory

The software SMUL does not use the data memory.

4. Example of use

Set a multiplicand and a multiplier in the input arguments and call the software SMUL as a subroutine.

| r     |                  |                            |   |                                                                                                   |
|-------|------------------|----------------------------|---|---------------------------------------------------------------------------------------------------|
| WORK1 | . RES. W         | 2                          |   | Reserves a data memory area in which the user program places a signed 16-bit binary multiplicand. |
| WORK2 | . RES. W         | 2                          |   | Reserves a data memory area in which the user program places a 16-bit binary multiplier.          |
| WORK3 | . RES. W         | 2                          |   | Reserves a data memory area for storage of the result of multiplication.                          |
|       | :<br>MOV. W      | @WORK1, R1                 |   | Places in R1 the 16-bit binary multiplicand set by the user program.                              |
|       | MOV. W           |                            |   | Places in R0 the 16-bit binary multiplier set by the user program.                                |
|       | JSR              | @SMUL                      |   | Calls the software SMUL as a subroutine.                                                          |
|       | MOV. W<br>MOV. W | R1, @WORK3<br>R2, @WORK3+2 | } | Places the result (set in the output argument) in the data memory area of the user program.       |

- 5. Operation
  - a. Subtraction of signed 16-bit binary numbers is done in one of the following manners depending on the signs of the multiplicand and multiplier:

| (Multiplicand) | (Multiplier) |               | (Process)                                                    |
|----------------|--------------|---------------|--------------------------------------------------------------|
| (+)            | (+)          | $\rightarrow$ | Multiplied directly.                                         |
| (+)            | ( – )        | $\rightarrow$ | Multiplied with the sign of the multiplier inverted.         |
| ( – )          | (+)          | $\rightarrow$ | Multiplied with the sign of the multiplicand inverted.       |
| ( – )          | ( – )        | $\rightarrow$ | Multiplied with the signs of both multiplicand and multiplie |

- b. The multiplication steps are as follows:
  - (i) A multiplicand is placed in R1 and a multiplier in R0.
  - (ii) The user bit (CCR) is cleared.
  - (iii) If the multiplicand is negative, its sign is inverted. If the multiplier is negative, its sign bit is inverted. Bits 6 and 4 of the CCR (user bits) are used as the sign bits of the multiplicand and multiplier, respectively. If the multiplicand or multiplier is negative, "1" is set in the corresponding user bit.
  - (iv) Multiplication is done with the software MUL.
  - (v) The CCR is transferred to R6L.
  - (vi) The result is modified or unmodified depending on the signs of the multiplicand and multiplier, as follows:

(Multiplicand) (Multiplier)

| (+)<br>(+) | (+)<br>(-) | $\Big\} \rightarrow$ | The result is unmodified.         |
|------------|------------|----------------------|-----------------------------------|
| (-)<br>(-) | (+)<br>(-) | $\Big\} \rightarrow$ | The result has its sign inverted. |





## 7.14.8 Program List

VER 1.0B \*\* 08/18/92 10:16:51

\*\*\* H8/300 ASSEMBLER PROGRAM NAME =

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 SMUL\_cod C 0000 16 17 18 SMUL cod C 00000000 19 SMUL cod C 0000 06AD 20 SMIII, cod C 0002 7771 21 SMUL\_cod C 0004 4408 22 SMUL\_cod C 0006 0440 23 SMUL\_cod C 0008 1701 24 SMUL\_cod C 000A 1709 25 SMUL\_cod C 000C 0B01 26 SMUL cod C 000E 27 SMUL\_cod C 000E 7770 28 SMUL cod C 0010 4408 29 SMUL\_cod C 0012 0410 30 SMUL\_cod C 0014 1700 31 SMUL\_cod C 0016 1708 32 SMUL\_cod C 0018 0B00 33 SMUL cod C 001A 34 SMUL cod C 001A 0C9A 35 SMUL cod C 001C 0C1C 36 SMUL\_cod C 001E 0C9B 37 SMUL\_cod C 0020 0C19 38 SMUL\_cod C 0022 5082 39 SMUL cod C 0024 5084 40 SMUL\_cod C 0026 5003 41 SMUL\_cod C 0028 5001 42 SMUL cod C 002A 08C2 43 SMUL\_cod C 002C 9400 44 SMUL\_cod C 002E 0839 45 SMUL cod C 0030 9100 46 SMUL\_cod C 0032 08B2 47 SMUL cod C 0034 0E49 48 SMUL\_cod C 0036 9100 49 50 SMUL\_cod C 0038 020E 51 SMUL cod C 003A 776E 52 SMUL cod C 003C 754E 53 SMUL cod C 003E 4410 54 SMUL\_cod C 0040 1701 55 SMUL cod C 0042 1709 56 SMUL\_cod C 0044 1702 57 SMUL\_cod C 0046 170A 58 SMUL cod C 0048 8A01 59 SMUL cod C 004A 9200 60 SMUL\_cod C 004C 9900 61 SMUL\_cod C 004E 9100 62 SMUL\_cod C 0050 63 SMUL cod C 0050 5470 64 65 \*\*\*\*\*TOTAL ERRORS 0 \*\*\*\*\*TOTAL WARNINGS 0

;\* SIGNED 16 BIT BINARY MULTIPLICATION (SMUL) ;\* 00 - NAME ;\* :\* ;\* ENRTRY :R1 (MULTIPLICAND) ;\* RO (MULTIPLIER) ;\* \* RETURNS :R1 (UPPER WORD OF RESULT) R2 (LOWER WORD OF RESULT) ;\* ;\* : .SECTION SMUL\_code,CODE,ALIGN=2 .EXPORT SMUL : SMUL .EQU \$ ;Entry point ANDC.B #H'AD,CCR ;Clear user bits BLD #7 B1H :Load sign bit of multiplicand BCC LBL1 ;Branch if C=0 ORC.B #H'40,CCR Bit set user bit (bit 6 of CCR) NOT RlH ;2's complement multiplicand NOT R1L ADDS.W #1,R1 LBL1 BLD. #7,R0H ;Load sign bit of multiplier BCC LBL2 ;Branch if C=0 ORC.B #H'10,CCR ;Bit set user bit (bit 4 of CCR) NOT ROH ;2's complement multiplier NOT ROL ADDS.W #1,R0 LBL2 MOV.B R1L,R2L ; MOV.B R1H.R4L ; MOV.B R1L,R3L ; MOV.B R1H,R1L ; MULXU ROL,R2 ;ROL \* R2L -> R2 MULXU ROL.R4 ;ROL \* R4L -> R4 ;ROH \* R3L -> R3 MULXU ROH,R3 MULXU ROH,R1 ;ROH \* R1L -> R1 ADD.B R4L,R2H ;R2H + R4L -> R2H ;R4H + #H'00 + C -> R4H ADDX.B #H'00,R4H -> R1L ADD.B R3H,R1L ;R1L + R3L :R1H + #H'00 + C -> R1H ADDX.B #H'00,R1H ADD.B R3L,R2H (R2H + R3L -> R2H ;R1L + R4H + C -> R1L ADDX B R4H R1L ADDX.B #H'00,R1H ;R1H + #H'00 + C -> R1H ; CCR,R6L STC ;CCR -> R6L BLD #6,R6L ;Load sign bit of multiplicand BXOR #4,R6L Bit exclusive OR sign bits LBL3 BCC Branch if C=0 NOT R1H ;2's complement sign bits NOT R1L NOT R2H NOT R21. ADD.B #1,R2L ; ADDX.B #H'00,R2H ADDX.B #H'00,R1L ADDX.B #H'00.R1H LBL3 RTS ; . END

#### **About Short Floating-Point Numbers**

#### Formats of Short Floating-Point Numbers

1. Internal representation of short floating-point numbers

For purposes of this Application Note, the following formats of representation apply to short floating-point numbers (R = real number):

a. Internal representation for  $\mathbf{R} = \mathbf{0}$ 



All of the 32 bits are 0's.

b. Normalized format

| 31 | 30 23 | 22 0 |
|----|-------|------|
| S  | α     | β    |

 $\alpha$  is an exponent whose field is 8 bits long.  $\beta$  is a mantissa whose field is 32 bits long. The value of R can be represented by the following equation (on conditions that  $1 \le \alpha \le 254$ :

$$\mathbf{R} = 2^{S} \times 2^{\alpha - 127} \times (1 + 2^{-1} \times \beta_{22} + 2^{-2} \times \beta_{21} + \dots + 2^{-23} \times \beta_{0})$$

where  $\beta i$  is the value of the i-th bit ( $0 \le i \le 22$ ) and S is a sign bit.

c. Denormalized format

| 31 | 30 |   |   |   |   |   |   | 23 | 22 0 | ) |
|----|----|---|---|---|---|---|---|----|------|---|
| S  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0  | β    |   |

where  $\alpha$  is a mantissa whose field is 23 bits long. This format is used to represent a real number too small to be represented in the normal format. In this format, R can be represented by the following equation:

$$\mathbf{R} = 2^{S} \times 2^{\alpha - 126} \times (2^{-1} \times \beta_{22} + 2^{-2} \times \beta_{21} + \dots + 2^{-23} \times \beta_{0})$$

d. Infinity

| 31 | 30 |   |   |   |   |   |   | 23 | 22 0 |
|----|----|---|---|---|---|---|---|----|------|
| S  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1  | β    |

where  $\beta$  is a mantissa whose field is 32 bits long. In this Application Note, however, the following rules apply if all exponents are 1's;

Positive infinity when S = 0

 $R = +\infty$ Negative infinity when S = 1 $R = -\infty$ 

- 2. Example of internal representation
  - If S = B'0 (binary)

 $\alpha = B'10000011$  (binary)

 $\beta = B'1011100\cdots 0$  (binary)

Then the corresponding real number is as follow:

a. Maximum and minimum values

Up to the following absolute maximum value (Rmax) and minimum value (Rmin) can be represented;

$$\begin{split} R_{MAX} &= 2^{254 - 127} \times (1 + 2^{-1} + 2^{-3} + 2^{-4} \cdots + 2^{-5}) \\ &= 3.37 \times 1038 \\ R_{MIN} &= 2^{-128} \times 2^{-23} = 2^{-140} \doteq 1.40 \times 10^{-45} \end{split}$$

# 7.15 Change of a Short Floating-Point Number to a Signed 32-Bit Binary Number

MCU: H8/300 Series H8/300L Series

Label name: FKTR

## 7.15.1 Function

- 1. The software FKTR changes a short floating-point number (placed in a general-purpose register) to a signed 32-bit binary number.
- 2. "0" is output when the short floating-point number is "0".
- 3. When the short floating-point number is not less than  $|2^{31}|$ , a maximum value  $(2^{31} 1 \text{ or } -2^{31})$  with the same sign as that number is output. When the short floating-point number is not more than |1|, "0" is output.

## 7.15.2 Arguments

| Descrip | tion                                   |                |        | Memory are | ea | Data leng | jth (bytes) |  |  |  |  |
|---------|----------------------------------------|----------------|--------|------------|----|-----------|-------------|--|--|--|--|
| Input   | Short flo                              | pating-point r | number | R0, R1     |    | 4         |             |  |  |  |  |
| Output  | Signed                                 | 32-bit binary  | number | R2, R3     |    | 4         |             |  |  |  |  |
|         |                                        |                |        |            |    |           |             |  |  |  |  |
| 7.15.3  | 5.3 Internal Register and Flag Changes |                |        |            |    |           |             |  |  |  |  |
| R0      | R1                                     | R2             | R3     | R4         | R5 | R6        | R7          |  |  |  |  |
| ×       | ×                                      | \$             | \$     | •          | ×  | •         | •           |  |  |  |  |
|         |                                        |                |        |            |    |           |             |  |  |  |  |
| I       | U                                      | Н              | U      | Ν          | Z  | V         | С           |  |  |  |  |
| •       | •                                      | ×              | •      | ×          | ×  | ×         | ×           |  |  |  |  |

 $\times$  : Unchanged

Indeterminate

t : Result
| Program memory (bytes) |
|------------------------|
| 100                    |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Clock cycle count      |
| 108                    |
| Reentrant              |
| Possible               |
| Relocation             |
| Possible               |
| Interrupt              |
| Possible               |
|                        |

### 7.15.5 Notes

The clock cycle count (108) in the specifications is for the example shown in figure 7.42

For the format of floating-point numbers, see "About Short Floating-point Numbers <Reference>."

### 7.15.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software FKTR:
    - (i) Input arguments:

R0: Contains the upper 2 bytes of a short floating-point number.

R1: Contains the lower 2 bytes of the short floating-point number.

(ii) Output arguments

R2: Contains the upper 2 bytes of a signed 32-bit binary number.

R3: Contains the lower 2 bytes of the signed 32-bit binary number.

b. Figure 7.42 shows an example of the software FKTR being executed. When the input arguments are set as shown in (1), the result of change is placed in R2 and R3 as shown in (2).



Figure 7.42 Example of Software FKTR Execution

- 2. Notes on usage
  - a. When the short floating-point number is "0" or not more than |1|, "0" is output.
  - b. When the short floating-point number is not less than  $|2^{31}|$ , a maximum value with the same sign (H'7FFFFFFF or H'8000000) is output.
  - c. After execution of the software FKTR, the input arguments placed in R0 and R1 are destroyed. If the input arguments are necessary after software FKTR execution, save them on memory.
- 3. Data memory

The software FKTR does not use the data memory.

#### 4. Example of use

Set a short floating-point number in the general-purpose register and call the software FKTR as a subroutine.

| WORK1 | . DATA. W             | 2, 0                       | <br>Reserves a data memory area in which the user program places a short floating-point number. |
|-------|-----------------------|----------------------------|-------------------------------------------------------------------------------------------------|
| WORK2 | . DATA. W             | 2, 0                       | <br>Reserves a data memory area in which the user program places a signed 32-bit binary number. |
|       | MOV. B<br>MOV. W      | @WORK1, R0<br>@WORK1+2, R1 | <br>Places in R0 and R1 the short floating-<br>point number set by the user program.            |
|       | JSR                   | @FKTR                      | <br>Calls the software FKTR as a subroutine.                                                    |
|       | MOV. W<br>MOV. W<br>E | R2, @WORK2<br>R3, @WORK2+2 | <br>Places in R2 and R3 the signed 32-bit binary number set in the output argument.             |
|       | •                     |                            |                                                                                                 |

- 5. Operation
  - a. The software FKTR takes the following steps to change the short floating-point number to a signed 32-bit binary number:
  - b. First, the input argument is checked.
    - (i) If the input argument is "0", then "0" is output.
    - (ii) If the exponent part is smaller than "H'7F", then "0" is output.
    - (iii) If the exponent part is not less than "H'9E", a maximum value with the same sign is output.
  - c. Next, if the input argument is not "0" and its absolute value is not less than "1" (the exponent part=H'7F) and smaller than 2<sup>31</sup> (the exponent part = H'9E), the following operations are performed;
    - (i) The implicit MSB is set.
    - (ii) The mantissa part (24 bits long) in which the implicit MSB is contained is shifted 1 bit to the left.
    - (iii) R3 and R2 are rotated 1 bit to the left.
    - (iv) Steps (ii) and (iii) are repeated as many times as "R0H+1".
    - (v) A negative number is obtained by two's complement when the sign bit is negative.







# 7.15.8 Program List

|                      | AM NAME = |   |      |          |      |         |                       |         |                                                                                 |
|----------------------|-----------|---|------|----------|------|---------|-----------------------|---------|---------------------------------------------------------------------------------|
|                      |           |   |      |          |      |         |                       |         |                                                                                 |
| 1                    |           |   |      |          |      | ******  | *******               | ******  | *******                                                                         |
| 2                    |           |   |      |          | ;*   |         |                       |         |                                                                                 |
| 3                    |           |   |      |          | ;*   | 00 - NA | ME                    |         | FLOATING POINT TO 32 BIT BINARY                                                 |
| 4                    |           |   |      |          |      |         |                       | (FKTR)  |                                                                                 |
| 5                    |           |   |      |          | ;*   |         |                       |         |                                                                                 |
| 6                    |           |   |      |          |      | ******  | *******               | ******* | *********                                                                       |
| 7                    |           |   |      |          | ;*   |         |                       |         |                                                                                 |
| 8                    |           |   |      |          | ;*   | ENTRY   |                       |         | PER WORD OF FLOATING POINT)                                                     |
| 9                    |           |   |      |          | ;*   |         |                       | RI (LOV | NER WORD OF FLOATING POINT)                                                     |
| 10                   |           |   |      |          | ;*   |         |                       |         | ·                                                                               |
| 11                   |           |   |      |          | ;*   | RETURNS |                       |         | (UPPER WORD OF 32 BIT BINARY)                                                   |
| 12                   |           |   |      |          | ;*   |         |                       | R3      | (LOWER WORD OF 32 BIT BINARY)                                                   |
| 13                   |           |   |      |          | ;*   |         |                       |         | *****                                                                           |
| 14                   |           |   |      |          |      | ******* | *******               | ******* | *********                                                                       |
| 15                   | -         | ~ |      |          | ;    | 0.0.000 |                       | -       |                                                                                 |
|                      | FKTR_cod  | C | 0000 |          |      | .SECTIO |                       |         | de,CODE,ALIGN=2                                                                 |
| 17                   |           |   |      |          |      | .EXPORT |                       | FKTR    |                                                                                 |
| 18                   |           | ~ |      | 00000000 | ;    |         | ~                     |         | Patra aniat                                                                     |
|                      | FKTR_cod  |   |      |          |      | .EQU    | \$                    |         | Entry point                                                                     |
|                      | FKTR_cod  |   |      |          |      | MOV.W   |                       |         | Clear R2                                                                        |
|                      | FKTR_cod  | C | 0004 | 0223     |      | MOV.W   | K2,R3                 |         | /Clear R3                                                                       |
| 22                   | -         | ~ |      | 0700     | ;    |         | B0 55                 |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      | MOV.W   | ., .                  |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      |         | LBL1                  |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      | MOV.W   |                       |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      | BEQ     | LBL5                  |         | ;Branch if R0=R1=0                                                              |
|                      | FKTR_cod  |   |      |          | LBL1 |         |                       |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      |         | #7,R0H                |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      |         | #0,R5L                |         | ;Set sign bit to bit 0 of R5L                                                   |
|                      | FKTR_cod  |   |      |          |      |         | #7,R0L                |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      | ROTXL.B |                       |         | /Set expornent                                                                  |
| 32                   | FKTR_cod  | С | 0016 | F57F     |      | MOV.B   | #H'7F,R5              | 5H      |                                                                                 |
| 33                   | FKTR_cod  | С | 0018 | 1850     |      | SUB.B   | R5H,R0H               |         |                                                                                 |
| 34                   | FKTR_cod  | С | 001A | 4546     |      | BCS     | LBL5                  |         | ;Branch if ROH<"H'7F"                                                           |
| 35                   | FKTR_cod  | С | 001C | A01F     |      |         | #H'1F,R0              | ЭH      |                                                                                 |
| 36                   | FKTR_cod  | С | 001E | 4518     |      | BCS     | LBL3                  |         | ;Branch if ROH<"H'1F"                                                           |
|                      | FKTR_cod  |   |      |          |      |         | #0,R5L                |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      | BCS     | LBL2                  |         | ;Branch if sign bit = 1                                                         |
| 39                   | FKTR_cod  | С | 0024 | 79027FFF |      | MOV.W   | #H'7FFF               | ,R2     |                                                                                 |
| 40                   | FKTR_cod  | С | 0028 | 7903FFFF |      | MOV.W   | #H'FFFF               | ,R3     | ;Set "H'7FFFFFFF"                                                               |
| 41                   | FKTR_cod  | С | 002C | 4034     |      | BRA     | LBL5                  |         | ;Branch always                                                                  |
| 42                   | FKTR_cod  | С | 002E |          | LBL2 | 2       |                       |         |                                                                                 |
| 43                   | FKTR_cod  | С | 002E | 79028000 |      | MOV.W   | #H'8000               | ,R2     |                                                                                 |
| 44                   | FKTR_cod  | С | 0032 | 79030000 |      | MOV.W   | #H'0000               | ,R3     | ;Set "H'80000000"                                                               |
| 45                   | FKTR_cod  | С | 0036 | 402A     |      | BRA     | LBL5                  |         |                                                                                 |
| 46                   |           |   |      |          | ;    |         |                       |         |                                                                                 |
| 47                   | FKTR_cod  | С | 0038 |          | LBL3 | 3       |                       |         |                                                                                 |
| 48                   | FKTR_cod  | С | 0038 | 7078     |      | BSET    | #7,R0L                |         | ;Set implicit MSB                                                               |
| 49                   | FKTR_cod  | С | A600 | 8001     |      | ADD.B   | #1,R0H                |         | ;ROH + #1 -> ROH                                                                |
|                      |           |   |      |          | LBL4 | 1       |                       |         |                                                                                 |
|                      |           |   |      |          |      | SHLL.B  | R1L                   |         | ;Shift mantissa 1 bit left                                                      |
|                      | FKTR_cod  |   |      |          |      | ROTXL.B |                       |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      | ROTXL.B |                       |         |                                                                                 |
| 54                   |           |   |      |          | ;    |         |                       |         |                                                                                 |
|                      | FKTR_cod  | с | 0042 | 120B     |      | ROTXL.B | R3L                   |         | Rotate 32 bit binary 1 bit left                                                 |
|                      | FKTR_cod  |   |      |          |      | ROTXL.B |                       |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      | ROTXL.B |                       |         |                                                                                 |
|                      | FKTR_cod  |   |      |          |      | ROTXL.B |                       |         |                                                                                 |
| 20                   | FKIR_cod  |   |      |          |      | DEC.B   |                       |         | ;Decrement ROH                                                                  |
| 50                   | FKIR_COU  |   |      |          |      |         |                       |         |                                                                                 |
|                      |           | - | 004C | 1055     |      | DINE    | LBL4                  |         | ;Branch if Z=0                                                                  |
| 60                   | rnin_cou  |   |      |          |      |         |                       |         |                                                                                 |
| 60<br>61             | _         | ~ | 0045 | 7705     | ;    | DID     | #0 PFT                |         | The local size bit ( C C)                                                       |
| 60<br>61<br>62       | FKTR_cod  |   |      |          | ;    |         | #0,R5L                |         | Bit load sign bit to C flag                                                     |
| 60<br>61<br>62<br>63 | _         | С | 0050 | 4410     | ;    |         | #0,R5L<br>LBL5<br>R2H |         | ;Bit load sign bit to C flag<br>;Branch if C=0<br>;2's complement 32 bit binary |



| 65  | FKTR_cod   | C 0054 | 170A |      | NOT    | R2L       |
|-----|------------|--------|------|------|--------|-----------|
| 66  | FKTR_cod   | C 0056 | 1703 |      | NOT    | R3H       |
| 67  | FKTR_cod   | C 0058 | 170B |      | NOT    | R3L       |
| 68  | FKTR_cod   | C 005A | 8B01 |      | ADD.B  | #H'01,R3L |
| 69  | FKTR_cod   | C 005C | 9300 |      | ADDX.B | #H'00,R3H |
| 70  | FKTR_cod   | C 005E | 9A00 |      | ADDX.B | #H'00,R2L |
| 71  | FKTR_cod   | C 0060 | 9200 |      | ADDX.B | #H'00,R2H |
| 72  | FKTR_cod   | C 0062 |      | LBL5 |        |           |
| 73  | FKTR_cod   | C 0062 | 5470 |      | RTS    |           |
| 74  |            |        |      | ;    |        |           |
| 75  |            |        |      |      | .END   |           |
| *** | **TOTAL ER | RORS   | 0    |      |        |           |
| *** | **TOTAL WA | RNINGS | 0    |      |        |           |
|     |            |        |      |      |        |           |

# 7.16 Change of a Signed 32-Bit Binary Number to a Short Floating-Point Number

MCU: H8/300 Series H8/300L Series

Label name: KFTR

## 7.16.1 Function

1. The software KFTR changes a signed 32-bit binary number (placed in a general-purpose register) to a short floating-point number.

#### 7.16.2 Arguments

| Descript | ion                           | Memory area | Data length (bytes) |
|----------|-------------------------------|-------------|---------------------|
| Input    | Signed 32-bit binary number   | R0, R1      | 4                   |
| Output   | Short floating-point y number | R0, R1      | 4                   |

# 7.16.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| \$ | \$ | •  | •  | ×  | ×  | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I. | U  | н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | ×  | ×  | ×  |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |  |
|------------------------|--|
| 98                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 346                    |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |
|                        |  |

### 7.16.5 Notes

The clock cycle count (346) in the specifications is for the example shown in figure 7.43.

For the format of floating-point numbers, see "About Short Floating-point Numbers <Reference>."

## 7.16.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software KFTR:
    - (i) Input arguments:

R0: Contains the upper 2 bytes of a signed 32-bit binary number.

R1: Contains the lower 2 bytes of the signed 32-bit binary number.

- (ii) Output arguments
  - R2: Contains the upper 2 bytes of a short floating-point number.
  - R3: Contains the lower 2 bytes of the short floating-point number.
- b. Figure 7.43 shows an example of the software KFTR being executed. When the input arguments are set as shown in (1), the result of change is placed in R0 and R1 as shown in (2).



Figure 7.43 Example of Software KFTR Execution

- 2. Notes on usage
  - a. After execution of the software KFTR, the signed 32-bit binary number is destroyed because the result of change is placed in R0 and R1. If the signed 32-bit binary number is necessary after software KFTR execution, save it on memory.
- 3. Data memory

The software KFTR does not use the data memory.

4. Example of use

Set a signed 32-bit binary number in the general-purpose register and call the software KFTR as a subroutine.

| WORK1 | . DATA. W             | 2, 0                       | <br>Reserves a data memory area in which the user program places a signed 32-bit binary number. |
|-------|-----------------------|----------------------------|-------------------------------------------------------------------------------------------------|
| WORK2 | . DATA. W             | 2, 0                       | <br>Reserves a data memory area in which the user program places a short floating-point number. |
|       | MOV. W<br>MOV. W      | @WORK1, R0<br>@WORK1+2, R1 | <br>Places in R0 and R1 the signed 32-bit binary number set by the user program.                |
|       | JSR                   | @KFTR                      | <br>Calls the software KFTR as a subroutine.                                                    |
|       | MOV. W<br>MOV. W<br>: | R0, @WORK2<br>R1, @WORK2+2 | <br>Places in R0 and R1 the short floating-<br>point number set in the output argument.         |
|       | •                     |                            |                                                                                                 |

- 5. Operation
  - a. The software KFTR first checks whether the signed 32-bit binary number is positive or negative; if it is negative, the software takes two's complement of the number. Next, the software performs either of the following operations depending on whether the upper 8 bits are "H'00" or not;
    - (i) When the upper 8 bits are not "H'00", the exponent part is calculated and shifted to the right to obtain a 24-bit binary number.
    - (ii) When the upper 8 bits are "H'00', the exponent part is calculated and shifted to the left to place "1" inn the MSB of the lower 24 bits.

Finally, "H'7F" is added to the exponent part to obtain floating-point form.







# 7.16.8 Program List

| 1                                                                                                   | ; * * * * * * * * * * * * * * *    | ******                                 |
|-----------------------------------------------------------------------------------------------------|------------------------------------|----------------------------------------|
| 2                                                                                                   | ;*                                 |                                        |
| 3                                                                                                   | ;* 00 - NAME                       | CHANGE 32 BIT BINARY TO FLOATING POINT |
| 4                                                                                                   | ;*                                 | (KFTR)                                 |
| 5                                                                                                   | ;*                                 |                                        |
| 6                                                                                                   | ;**********                        | *****                                  |
| 7                                                                                                   | ;*                                 |                                        |
| 8                                                                                                   | ;* ENTRY                           | :R0 (UPPER WORD OF 32 BIT BINARY)      |
| 9                                                                                                   | ;*                                 | R1 (LOWER WORD OF 32 BIT BINARY)       |
| LO                                                                                                  | ;*                                 |                                        |
| .1                                                                                                  | ;* RETURNS                         | :R0 (UPPER WORD OF FLOATING POINT)     |
| 2                                                                                                   | ;*                                 | R1 (LOWER WORD OF FLOATING POINT)      |
| .3                                                                                                  | ;*                                 |                                        |
| 4                                                                                                   | ;**********                        | *****                                  |
| .5                                                                                                  | ;                                  |                                        |
| .6 KFTR_cod C 0000                                                                                  | .SECTION                           | KFTR_code, CODE, ALIGN=2               |
| .7                                                                                                  | .EXPORT                            |                                        |
| .8                                                                                                  | ;                                  |                                        |
| 9 KFTR_cod C 0000000                                                                                | KFTR .EQU \$                       | Entry point                            |
| 0 KFTR_cod C 0000 0D00                                                                              | MOV.W F                            |                                        |
| 1 KFTR_cod C 0002 4604                                                                              | BNE I                              | .BL1                                   |
| 2 KFTR_cod C 0004 0D11                                                                              | MOV.W F                            | R1,R1                                  |
| 3 KFTR_cod C 0006 4758                                                                              | BEQ I                              | .BL7 /Branch if R0=R1=0                |
| 4 KFTR_cod C 0008                                                                                   | LBL1                               |                                        |
| 5 KFTR_cod C 0008 79050000                                                                          | MOV.W #                            | H'0000,R5 ;Clear R5                    |
| 6 KFTR_cod C 000C 0CD4                                                                              | MOV.B F                            | Clear R4H ;Clear R4H                   |
| 7 KFTR_cod C 000E 7770                                                                              | BLD #                              | 7,R0H                                  |
| 8 KFTR_cod C 0010 670D                                                                              | BST ‡                              | 0,R5L ;Set sign bit to bit 0 of R5L    |
| 9 KFTR_cod C 0012 4410                                                                              | BCC I                              | .BL2 ;Branch if 32 bit binary is minus |
| 0 KFTR_cod C 0014 1700                                                                              | NOT F                              | COH ;2's complement 32 bit binary      |
| 1 KFTR_cod C 0016 1708                                                                              | NOT F                              | OL                                     |
| 2 KFTR_cod C 0018 1701                                                                              | NOT F                              | 21H                                    |
| 3 KFTR_cod C 001A 1709                                                                              | NOT F                              | RIL                                    |
| 4 KFTR_cod C 001C 8901                                                                              | ADD.B ‡                            | H'01,R1L                               |
| 5 KFTR_cod C 001E 9100                                                                              | ADDX.B #                           | H'00,R1H                               |
| 6 KFTR_cod C 0020 9800                                                                              | ADDX.B #                           | H'00,R0L                               |
| 7 KFTR_cod C 0022 9000                                                                              | ADDX.B #                           | H'00,R0H                               |
| 8 KFTR_cod C 0024                                                                                   | LBL2                               |                                        |
| 9 KFTR_cod C 0024 0C00                                                                              | MOV.B F                            | ROH, ROH                               |
| 0 KFTR_cod C 0026 471A                                                                              | BEQ I                              | JBL5 /Branch if ROH=0                  |
| 1 KFTR_cod C 0028 0C05                                                                              | MOV.B F                            | 10H,R5H                                |
| 2 KFTR_cod C 002A FC20                                                                              | MOV.B #                            | D'32,R4L ;Set bit counter1             |
| 3 KFTR_cod C 002C                                                                                   | LBL3                               |                                        |
| 4 KFTR_cod C 002C 1005                                                                              | SHLL.B F                           |                                        |
| 5 KFTR_cod C 002E 1A0C                                                                              | DEC.B F                            |                                        |
| 6 KFTR_cod C 0030 44FA                                                                              | BCC I                              |                                        |
| 7 KFTR_cod C 0032 0CC4                                                                              | MOV.B F                            | 24L,R4H ;Push R4L to R4H               |
| 8 KFTR_cod C 0034                                                                                   | LBL4                               |                                        |
| 9 KFTR_cod C 0034 1100                                                                              | SHLR.B F                           |                                        |
| 0 KFTR_cod C 0036 1308                                                                              | ROTXR.B F                          |                                        |
| 1 KFTR_cod C 0038 1301                                                                              | ROTXR.B F                          | 21H                                    |
| 2 KFTR_cod C 003A 1309                                                                              | ROTXR.B F                          |                                        |
| 3 KFTR_cod C 003C 1A0C                                                                              | DEC.B F                            |                                        |
| 4 KFTR_cod C 003E 46F4                                                                              |                                    | JBL4 ;Branch if Z=0                    |
| 5 KFTR_cod C 0040 4012                                                                              | BRA I                              | .BL6 ;Branch always                    |
| 6                                                                                                   | ;                                  |                                        |
| 7 KFTR_cod C 0042                                                                                   | LBL5                               |                                        |
| 8 KFTR_cod C 0042 F418                                                                              | MOV.B #                            | D'24,R4H ;Set bit counter2             |
| 0 KDMD 0 0044                                                                                       | LBL5_1                             |                                        |
|                                                                                                     |                                    |                                        |
| 50 KFTR_cod C 0044 1009                                                                             | SHLL.B F                           | Change 32 bit binary to mantissa       |
| 59 KFTR_cod C 0044<br>50 KFTR_cod C 0044 1009<br>51 KFTR_cod C 0046 1201<br>52 KFTR cod C 0048 1208 | SHLL.B F<br>ROTXL.B F<br>ROTXL.B F | ан                                     |



| 64      | KFTR_cod C | 004C  | 44F6 | 5 |      | BCC     | LBL5_1    |         |          |       |        |  |
|---------|------------|-------|------|---|------|---------|-----------|---------|----------|-------|--------|--|
| 65      | KFTR_cod C | 004E  | 1308 | 3 |      | ROTXR.B | ROL       | ;Rotate | mantissa | 1 bit | right  |  |
| 66      | KFTR_cod C | 0050  | 1301 | L |      | ROTXR.B | R1H       |         |          |       |        |  |
| 67      | KFTR_cod C | 0052  | 1309 | ) |      | ROTXR.B | R1L       |         |          |       |        |  |
| 68      | KFTR_cod C | 0054  |      |   | LBL6 |         |           |         |          |       |        |  |
| 69      | KFTR_cod C | 0054  | 847F | , |      | ADD.B   | #H'7F,R4H | ;Biased | exponent |       |        |  |
| 70      | KFTR_cod C | 0056  | 1104 | l |      | SHLR.B  | R4H       | ;Change | floating | point | format |  |
| 71      | KFTR_cod C | 0058  | 6778 | 3 |      | BST     | #7,R0L    |         |          |       |        |  |
| 72      | KFTR_cod C | 005A  | 0C40 | ) |      | MOV.B   | R4H,R0H   |         |          |       |        |  |
| 73      | KFTR_cod C | 005C  | 7701 | ) |      | BLD     | #0,R5L    |         |          |       |        |  |
| 74      | KFTR_cod C | 005E  | 6770 | ) |      | BST     | #7,R0H    |         |          |       |        |  |
| 75      | KFTR_cod C | 0060  |      |   | LBL7 |         |           |         |          |       |        |  |
| 76      | KFTR_cod C | 0060  | 5470 | ) |      | RTS     |           |         |          |       |        |  |
| 77      |            |       |      |   | ;    |         |           |         |          |       |        |  |
| 78      |            |       |      |   |      | .END    |           |         |          |       |        |  |
| * * * * | *TOTAL ERF | ORS   |      | 0 |      |         |           |         |          |       |        |  |
| * * * * | *TOTAL WAF | NINGS |      | 0 |      |         |           |         |          |       |        |  |
|         |            |       |      |   |      |         |           |         |          |       |        |  |

# 7.17 Addition of Short Floating-Point Numbers

MCU: H8/300 Series H8/300L Series

Label name: FADD

## 7.17.1 Function

- 1. The software FADD adds short floating-point numbers placed in four general-purpose registers and places the result of addition in two of the four general-purpose registers.
- 2. All arguments used with the software FADD are represented in short floating-point form.

#### 7.17.2 Arguments

| Descript | lion               | Memory area | Data length (bytes) |
|----------|--------------------|-------------|---------------------|
| Input    | Augend             | R0, R1      | 4                   |
|          | Addend             | R2, R3      | 4                   |
| Output   | Result of addition | R0, R1      | 4                   |

### 7.17.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| \$ | \$ | ×  | ×  | ×  | ×  | ×  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | ×  | ×  | ×  |  |
|    |    |    |    |    |    |    |    |  |

 $\times$  : Unchanged

: Indeterminate

t : Result

| Program memory (bytes) |   |
|------------------------|---|
| 280                    |   |
| Data memory (bytes)    |   |
| 0                      |   |
| Stack (bytes)          |   |
| 0                      |   |
| Clock cycle count      |   |
| 268                    |   |
| Reentrant              |   |
| Possible               |   |
| Relocation             |   |
| Possible               |   |
| Interrupt              |   |
| Possible               |   |
|                        | I |

# 7.17.5 Notes

The clock cycle count (268) in the specifications is for the example shown in figure 7.44.

For the format of floating-point numbers, see "About Short Floating-point Numbers <Reference>."

### 7.17.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software FADD:
    - (i) Input arguments:

R0: Contains the upper 2 bytes of a short floating-point augend.

R1: Contains the lower 2 bytes of the short floating-point augend.

R2: Contains the upper 2 bytes of a short floating-point addend.

R3: Contains the lower 2 bytes of the short floating-point addend.

(ii) Output arguments

R0: Contains the upper 2 bytes of the result.

R1: Contains the lower 2 bytes of the result.

b. Figure 7.44 shows an example of the software FADD being executed. When the input arguments are set as shown in (1), the result of addition is placed in R0 and R1 as shown in (2).



Figure 7.44 Example of Software FADD Execution

- 2. Notes on usage
  - a. The maximum and minimum values that can be handled by the software FADD are as follows:
    - { Positive maximum H'7F800000 Positive minimum H'00000001 Negative maximumH'80000001 Negative minimum H'FF800000
  - b. All positive short floating-point numbers H'7F800000 to H'7FFFFFFF are treated as a maximum value (H'7F800000). All negative short floating-point numbers H'FF800000 to H'FFFFFFFF are treated as a minimum value (H'FF800000).

c. As a maximum value is treated as infinity (∞), the result of ∞ + 100 or ∞ - 100 becomes infinite. (See table 7.5.)

| Augend               | Addend               | Result   |
|----------------------|----------------------|----------|
| 7F800000 to 7FFFFFFF | *****                | 7F800000 |
| 7F800000 to FFFFFFFF | 7F800000 to 7FFFFFFF | 7F800000 |
| FF800000 to FFFFFFFF | *****                | FF800000 |
| 7F800000 to 7FFFFFF  | FF800000 to FFFFFFFF | FF800000 |

#### Table 7.5 Examples of Operation with Maximum Values Used as Arguments

Note: \* represents a hexadecimal number.

- d. H'80000000 is treated as H'00000000 (zero).
- e. After execution of the software FADD, the augend and addend data are destroyed. If the input arguments are necessary after software FADD execution, save them on memory.
- 3. Data memory

The software FADD does not use the data memory.

4. Example of use

Set an augend and an addend in the general-purpose register and call the software FADD as a subroutine.

| WORK1<br>WORK2<br>WORK3 | . R | ES. W<br>ES. W<br>ES. W<br>I    | 2<br>2<br>2                |    | Reserves a data memory area<br>in which the user program<br>places { an augend.<br>an addend.<br>the result of addition. |
|-------------------------|-----|---------------------------------|----------------------------|----|--------------------------------------------------------------------------------------------------------------------------|
|                         | М   | :<br>Iov. W<br>Iov. W<br>Iov. W | @WORK2,R2                  | }[ | Places in R0 and R1 the augend set by the<br>user program.<br>Places in R2 and R3 the addend set by the                  |
|                         | []  | IOV. W<br>SR                    | @WORK2+2,R3<br>@FADD       |    | user program.<br>Calls the software FADD as a subroutine.                                                                |
|                         | M   | IOV. W<br>IOV. W                | R0, @WORK3<br>R1, @WORK3+2 | }  | Places in R0 and R1 the result of addition set in the output argument.                                                   |

5. Operation

Addition of short floating-point numbers is done in the following steps:

- a. The software checks whether the augend and addend are  $+ {\rm \AA} {\rm \acute{a}}$  or  ${\rm \AA} {\rm \acute{a}}$  .
  - (i) When the exponent part of the augend is H'FFF, either of the following values is output depending on the state of the sign bit:

| Sign bit     | Output value    |
|--------------|-----------------|
| 0 (positive) | H'7F800000 (+∞) |
| 1 (negative) | H'FF800000 (–∞) |

- (ii) The table shown in (a)-(i) also applies when the augend is neither  $+\infty$  nor  $-\infty$  and the exponent part of the addend is H'FF.
- b. The software checks whether the augend and addend are "0".
  - (i) If either the augend or addend is "0", the other number is output. (If both are "0", "H'00000000" is output.)
- c. The software attempts to match the exponent part of the augend with that of the addend.
  - (i) The smaller number of the exponent part is incremented and, at the same time, the mantissa part (including the implicit MSB) is shifted digit by digit to the right until the exponent part of the augend matches that of the addend. (In the case of the denormalized format, 1 is added to the exponent part aso that the implicit MSB of the mantissa part is treated as "0".
- d. The mantissa part of the augend is added to that of the addend.
- e. The result of addition is represented in floating-point format.

(Example)

Augend

```
Sign bit=0, exponent part=H'F1, mantissa part=H'1ABCDE
```

(excluding the implicit MSB)

Addend

Sign bit=0, exponent part=H'F4, mantissa part=H'1B3DD2

(excluding the implicit MSB)



















# 7.17.8 Program List

| 1  |              |      |          | ;*** | ******  | ******  | * * * * * * * | *****                                  |
|----|--------------|------|----------|------|---------|---------|---------------|----------------------------------------|
| 2  |              |      |          | ; *  |         |         |               |                                        |
| 3  |              |      |          | ;*   | 00 - N2 | AME     | FLOAT         | FING POINT ADDITION (FADD)             |
| 4  |              |      |          | ;*   |         |         |               |                                        |
| 5  |              |      |          | ;*** | ******  | ******  | * * * * * * * | *****                                  |
| 6  |              |      |          | ;*   |         |         |               |                                        |
| 7  |              |      |          | ;*   | ENTRY   |         | :R0           | (UPPER WORD OF SUMMAND)                |
| 8  |              |      |          | ;*   |         |         | Rl            | (LOWER WORD OF SUMMAND)                |
| 9  |              |      |          | ;*   |         |         | R2            | (UPPER WORD OF ADDEND)                 |
| 10 |              |      |          | ;*   |         |         | R3            | (LOWER WORD OF ADDEND)                 |
| 11 |              |      |          | ;*   |         |         |               |                                        |
| 12 |              |      |          | ;*   | RETURNS | S       | :R0           | (UPPER WORD OF RESULT)                 |
| 13 |              |      |          | ;*   |         |         | Rl            | (LOWER WORD OF RESULT)                 |
| 14 |              |      |          | ;*   |         |         |               |                                        |
| 15 |              |      |          | ;*** | ******  | ******  | * * * * * * * | *******                                |
| 16 |              |      |          | ;    |         |         |               |                                        |
| 17 | FADD_cod C 0 | 0000 |          |      | .SECTIO | ON      | FADD_c        | code, CODE, ALIGN=2                    |
| 18 |              |      |          |      | .EXPOR  | г       | FADD          |                                        |
| 19 |              |      |          | ;    |         |         |               |                                        |
| 20 | FADD_cod C   |      | 0000000  | FADD | .EQU    | \$      |               | ;Entry point                           |
| 21 | FADD_cod C 0 | 0000 | FE00     |      |         | #H'00,R |               | Clear R6L                              |
| 22 | FADD_cod C 0 | 0002 | 79057F80 |      | MOV.W   | #H'7F80 | ,R5           | ;Set "H'7F80"                          |
| 23 |              |      |          | ;    |         |         |               |                                        |
| 24 | FADD_cod C 0 | 0006 | 7770     |      | BLD     | #7,R0H  |               |                                        |
| 25 | FADD_cod C 0 | 8000 | 670E     |      | BST     | #0,R6L  |               | ;Set sign bit to bit 0 of R6L          |
| 26 | FADD_cod C 0 | A000 | 7270     |      | BCLR    | #7,R0H  |               | ;Bit clear bit 7 of ROH                |
| 27 |              |      |          | ;    |         |         |               |                                        |
| 28 | FADD_cod C 0 | 000C | 7772     |      | BLD     | #7,R2H  |               |                                        |
| 29 | FADD_cod C 0 | 000E | 671E     |      | BST     | #1,R6L  |               | ;Set sign bit to bit 1 of R6L          |
| 30 | FADD_cod C 0 | 010  | 7272     |      | BCLR    | #7,R2H  |               | ;Bit clear bit 7 of R2H                |
| 31 |              |      |          | ;    |         |         |               |                                        |
| 32 | FADD_cod C 0 | 012  | 1D05     |      | CMP.W   | R0,R5   |               |                                        |
| 33 | FADD_cod C 0 | 0014 | 4306     |      | BLS     | LBL1    |               | Branch if "exponent of summand"="H'FF" |
| 34 | FADD_cod C 0 | 016  | 1D25     |      | CMP.W   | R2,R5   |               |                                        |
| 35 | FADD_cod C 0 | 018  | 421A     |      | BHI     | LBL4    |               | Branch if not "exponent of summand"="H |
| 36 | FADD_cod C 0 | 001A | 110E     |      | SHLR    | R6L     |               | ;Shift R6L 1 bit right                 |
| 37 | FADD_cod C 0 | 001C |          | LBL1 |         |         |               |                                        |
| 38 | FADD_cod C 0 | 01C  | 770E     |      | BLD     | #0,R6L  |               | ;Bit load sign bit                     |
| 39 | FADD_cod C 0 | 001E | 450A     |      | BCS     | LBL3    |               | ;Branch if sign bit=1                  |
| 40 | FADD_cod C 0 | 020  |          | LBL2 |         |         |               |                                        |
| 41 | FADD_cod C 0 | 020  | 79007F80 |      | MOV.W   | #H'7F80 | ,R0           | ;Set plus maximum number               |
| 42 | FADD_cod C 0 | 024  | 79010000 |      | MOV.W   | #H'0000 | ,Rl           |                                        |
| 43 | FADD_cod C 0 | 028  | 5470     |      | RTS     |         |               |                                        |
| 44 | FADD_cod C 0 | 02A  |          | LBL3 |         |         |               |                                        |
| 45 | FADD_cod C 0 | 02A  | 7900FF80 |      | MOV.W   | #H'FF80 | ,R0           | /Set minus minimum number              |
| 46 | FADD_cod C 0 | 02E  | 79010000 |      | MOV.W   | #H'0000 | ,R1           |                                        |
| 47 | FADD_cod C 0 | 032  | 5470     |      | RTS     |         |               |                                        |
| 48 |              |      |          | ;    |         |         |               |                                        |
| 49 | FADD_cod C 0 | 034  |          | LBL4 |         |         |               |                                        |
| 50 | FADD_cod C 0 | 034  | 0D11     |      | MOV.W   | R1,R1   |               | ;                                      |
| 51 | FADD_cod C 0 | 036  | 4608     |      | BNE     | LBL5    |               | ;Branch if Z=0                         |
| 52 | FADD_cod C 0 | 038  | 0000     |      | MOV.W   | R0,R0   |               |                                        |
| 53 | FADD_cod C 0 | 03A  | 4604     |      | BNE     | LBL5    |               | ;Branch if Z=0                         |
| 54 | FADD_cod C 0 | 003C | 707E     |      | BSET    | #7,R6L  |               | ;Bit set bit 7 of R6L                  |
| 55 | FADD_cod C 0 | 003E | 720E     |      | BCLR    | #0,R6L  |               | ;Bit clear bit 0 of R6L                |
|    | FADD_cod C 0 |      |          | LBL5 |         |         |               |                                        |
|    | FADD_cod C 0 |      | 0D33     |      | MOV.W   | R3,R3   |               |                                        |
|    | FADD_cod C 0 |      |          |      | BNE     | LBL6    |               | ;Branch if Z=0                         |
|    | FADD_cod C 0 |      |          |      |         | R2,R2   |               |                                        |
|    | FADD_cod C 0 |      |          |      | BNE     | LBL6    |               | ;Branch if Z=0                         |
|    | FADD_cod C 0 |      |          |      | BSET    | #6,R6L  |               | Bit set bit 6 of R6L                   |
|    |              |      |          |      |         |         |               |                                        |
| 62 | FADD_cod C 0 | 004A | 721E     |      | BCLR    | #1,R6L  |               | ;Bit clear bit 1 of R6L                |



| 64  | FADD_cod C 00 | 04C | 777E |       | BLD   | #7,R6L    |                                         |
|-----|---------------|-----|------|-------|-------|-----------|-----------------------------------------|
| 65  | FADD_cod C 00 | )4E | 746E |       | BOR   | #6,R6L    |                                         |
|     | FADD_cod C 00 |     |      |       | BCC   | LBL8      | Branch if not summand=addend=0          |
|     |               |     |      |       |       |           | Set summand and addend to result        |
|     | FADD_cod C 00 |     |      |       | ADD.W |           | set summand and addend to result        |
|     | FADD_cod C 00 |     |      |       | ADD.W | R2,R0     |                                         |
| 69  | FADD_cod C 00 | )56 | 770E |       | BLD   | #0,R6L    |                                         |
| 70  | FADD_cod C 00 | 58  | 741E |       | BOR   | #1,R6L    |                                         |
| 71  | FADD_cod C 00 | )5A | 6770 |       | BST   | #7,R0H    | ;Set sign bit                           |
|     | FADD cod C 00 |     |      |       | RTS   |           |                                         |
|     | FADD_COU C 00 | 150 | 5470 |       | R15   |           |                                         |
| 73  |               |     |      | ;     |       |           |                                         |
| 74  | FADD_cod C 00 | )5E |      | LBL8  |       |           |                                         |
| 75  | FADD_cod C 00 | )5E | 7778 |       | BLD   | #7,R0L    |                                         |
| 76  | FADD_cod C 00 | 060 | 1200 |       | ROTXL | ROH       | ;Set exponent of summand to ROH         |
| 77  |               |     |      | ;     |       |           |                                         |
| 70  | FADD_cod C 00 |     | 7773 |       | BLD   | #7,R2L    |                                         |
|     |               |     |      |       |       |           |                                         |
|     | FADD_cod C 00 | 164 | 1202 |       | ROTXL | R2H       | ;Set exponent of addend to ROL          |
| 80  |               |     |      | ;     |       |           |                                         |
| 81  | FADD_cod C 00 | 066 | 7278 |       | BCLR  | #7,R0L    |                                         |
| 82  | FADD_cod C 00 | 068 | 0C00 |       | MOV.B | ROH, ROH  |                                         |
|     | FADD_cod C 00 |     |      |       | BEQ   | LBL9      | Branch if summand is normalized         |
|     |               |     |      |       | BSET  |           |                                         |
|     | FADD_cod C 00 |     |      |       |       |           | ;Set implicit MSB to summand            |
| 85  | FADD_cod C 00 | )6E | 4002 |       | BRA   | LBL10     | Branch always                           |
| 86  | FADD_cod C 00 | 070 |      | LBL9  |       |           |                                         |
| 87  | FADD_cod C 00 | 070 | 8001 |       | ADD.B | #H'01,R0H |                                         |
| 88  | FADD_cod C 00 | 072 |      | LBL1( | )     |           |                                         |
|     | FADD cod C 00 |     | 7271 |       | BCLR  | #7,R2L    |                                         |
|     | -             |     |      |       |       |           |                                         |
|     | FADD_cod C 00 |     |      |       |       | R2H,R2H   |                                         |
| 91  | FADD_cod C 00 | )76 | 4704 |       | BEQ   | LBL11     | ;Branch if addend is normalized         |
| 92  | FADD_cod C 00 | 078 | 707A |       | BSET  | #7,R2L    | ;Set implicit MSB to addend             |
| 93  | FADD cod C 00 | )7A | 4002 |       | BRA   | LBL12     | Branch always                           |
| 94  | FADD_cod C 00 | 170 |      | LBL11 |       |           | -                                       |
|     |               |     |      |       |       |           |                                         |
|     | FADD_cod C 00 | 170 | 8201 |       | ADD.B | #H'01,R2H |                                         |
| 96  |               |     |      | ;     |       |           |                                         |
| 97  | FADD_cod C 00 | )7E |      | LBL12 | 2     |           |                                         |
| 98  | FADD_cod C 00 | )7E | 0C05 |       | MOV.B | ROH,R5H   |                                         |
| 99  | FADD_cod C 00 | 080 | 0C2D |       | MOV.B | R2H,R5L   |                                         |
|     | FADD_cod C 00 |     |      |       |       | R5L,R5H   |                                         |
|     |               |     |      |       |       |           |                                         |
|     | FADD_cod C 00 |     |      |       | BEQ   |           | Branch if R5H=R5L                       |
| 102 | FADD_cod C 00 | 086 | 451A |       | BCS   | LBL14     | ;Branch if R5H <r5l< td=""></r5l<>      |
| 103 |               |     |      | ;     |       |           |                                         |
| 104 | FADD_cod C 00 | 880 | 18D5 |       | SUB.B | R5L,R5H   |                                         |
| 105 | FADD_cod C 00 | A80 | A518 |       | CMP.B | #D'24,R5H | ;Set bit counter                        |
|     | FADD_cod C 00 |     |      |       | BCS   |           | ;Branch if R5H <d'24< td=""></d'24<>    |
|     |               |     |      |       |       |           |                                         |
|     | FADD_cod C 00 |     |      |       | MOV.W |           | ;Clear addend                           |
| 108 | FADD_cod C 00 | 92  | 0D23 |       | MOV.W | R2,R3     |                                         |
| 109 | FADD_cod C 00 | 94  | 4028 |       | BRA   | LBL16     | ;Branch always                          |
| 110 | FADD_cod C 00 | 096 |      | LBL13 | 3     |           |                                         |
|     | FADD_cod C 00 |     | 1103 |       | SHLR  | R2L       | ;Shift mantissa of addend 1 bit left    |
|     | FADD_cod C 00 |     |      |       | ROTXR | R3H       | , onite wantibba of addena i bit itre   |
|     |               |     |      |       |       |           |                                         |
|     | FADD_cod C 00 |     |      |       | ROTXR | R3L       |                                         |
| 114 | FADD_cod C 00 | )9C | 1A05 |       | DEC.B | R5H       | ;Decrement bit counter                  |
| 115 | FADD_cod C 00 | )9E | 46F6 |       | BNE   | LBL13     | ;Branch Z=0                             |
| 116 | FADD cod C 00 | 0A0 | 401C |       | BRA   | LBL16     | Branch always                           |
| 117 |               |     |      | ;     |       |           |                                         |
|     |               |     |      |       |       |           |                                         |
|     | FADD_cod C 00 |     |      | LBL14 | 1     |           |                                         |
| 119 | FADD_cod C 00 | )A2 | 185D |       | SUB.B | R5H,R5L   |                                         |
| 120 | FADD_cod C 00 | DA4 | AD18 |       | CMP.B | #D'24,R5L |                                         |
| 121 | FADD_cod C 00 | DA6 | 450A |       | BCS   | LBL15     | Branch if R5L <d'24< td=""></d'24<>     |
|     | FADD_cod C 00 |     |      |       |       | R2H,R0H   |                                         |
|     |               |     |      |       |       |           | 101                                     |
|     | FADD_cod C 00 |     |      |       |       |           | ;Clear summand                          |
|     | FADD_cod C 00 |     |      |       | MOV.B | R1L,R0L   |                                         |
| 125 | FADD_cod C 00 | )B0 | 400C |       | BRA   | LBL16     | Branch always                           |
| 126 | FADD_cod C 00 | )B2 |      | LBL15 | 5     |           |                                         |
|     | FADD_cod C 00 |     |      |       | SHLR  | POI.      | ;Shift mantissa of summand 1 bit right  |
|     |               |     |      |       |       |           | . Shire manerada or summanu i bit fight |
|     | FADD_cod C 00 |     |      |       | ROTXR |           |                                         |
|     | FADD_cod C 00 |     |      |       | ROTXR | R1L       |                                         |
| 130 | FADD_cod C 00 | )B8 | 1A0D |       | DEC.B | R5L       | ;Decrement bit counter                  |
| 131 | FADD_cod C 00 | )BA | 46F6 |       | BNE   | LBL15     | ;Branch if Z=0                          |
| 132 | FADD_cod C 00 | )BC | 0C20 |       |       | R2H,R0H   |                                         |
| 133 |               | -   |      | ;     |       | , .       |                                         |
| 100 |               |     |      | '     |       |           |                                         |
|     |               |     |      |       |       |           |                                         |

134 FADD\_cod C 00BE 135 FADD\_cod C 00BE 770E 136 FADD cod C 00C0 751E 137 FADD\_cod C 00C2 4516 138 139 FADD cod C 00C4 0931 140 FADD cod C 00C6 0EA8 141 FADD\_cod C 00C8 442A 142 FADD\_cod C 00CA 1308 143 FADD cod C 00CC 1301 144 FADD cod C 00CE 1309 145 FADD\_cod C 00D0 8001 146 FADD\_cod C 00D2 A0FF 147 FADD cod C 00D4 4638 148 FADD\_cod C 00D6 5A000000 149 150 FADD\_cod C 00DA 151 FADD cod C 00DA 1931 152 FADD\_cod C 00DC 1EA8 153 FADD\_cod C 00DE 4604 154 FADD cod C 00E0 F000 155 FADD\_cod C 00E2 5470 156 FADD\_cod C 00E4 157 FADD cod C 00E4 440E 158 FADD\_cod C 00E6 710E 159 FADD\_cod C 00E8 1708 160 FADD\_cod C 00EA 1701 161 FADD\_cod C 00EC 1709 162 FADD\_cod C 00EE 8901 163 FADD\_cod C 00F0 9100 164 FADD\_cod C 00F2 9800 165 166 FADD\_cod C 00F4 167 FADD cod C 00F4 1009 168 FADD\_cod C 00F6 1201 169 FADD\_cod C 00F8 1208 170 FADD cod C 00FA 1A00 171 FADD cod C 00FC 470C 172 FADD\_cod C 00FE 44F4 173 FADD cod C 0100 174 FADD cod C 0100 0A00 175 FADD cod C 0102 176 FADD cod C 0102 1308 177 FADD cod C 0104 1301 178 FADD\_cod C 0106 1309 179 FADD cod C 0108 4004 180 FADD cod C 010A 181 FADD cod C 010A 45F4 182 FADD\_cod C 010C 40F4 183 184 FADD cod C 010E 185 FADD cod C 010E 1100 186 FADD cod C 0110 6778 187 FADD cod C 0112 770F 188 FADD cod C 0114 6770 189 FADD cod C 0116 5470 190 191 \*\*\*\*\*TOTAL ERRORS 0 \*\*\*\*\*TOTAL WARNINGS 0

LBL16 BLD #0,R6L BXOR #1,R6L BCS LBL17 Branch if different sign bit ; ADD.W R3,R1 ;Addition mantissa ADDX.B R2L,R0L BCC LBL19 ;Branch if C=0 ROTXR ROL ;Rotate mantissa l bit right ROTXR R1H ROTXR R1L ADD.B #H'01,R0H ;Increment exponent CMP.B #H'FF,ROH BNE LBL23 Branch if not exponent=H'FF JMP @LBL1 ;Jump ; LBL17 SUB.W R3,R1 ;Substruct mantissa SUBX.B R2L,R0L BNE LBL18 ;Branch if Z=0 MOV.B #H'00,R0H ;Clear ROH RTS LBL18 BCC LBL19 ;Branch if C=0 BNOT #0,R6L Bit not sign bit NOT ROL ;2's complement mantissa NOT R1H NOT R1L ADD.B #H'01,R1L ADDX.B #H'00,R1H ADDX.B #H'00,R0L ; LBL19 SHLL R1L ;Shift mantissa 1 bit left ROTXL R1H ROTXL ROL DEC.B ROH ;Decrement exponent BEQ LBL22 Branch if exponent=0 BCC LBL19 ;Branch if exponent>0 LBL20 INC.B ROH ;Increment exponent LBL21 ROTXR ROL Rotate mantissa 1 bit right; ROTXR R1H ROTXR R1L Branch always BRA LBL23 LBL22 BCS LBL20 ;Branch if C=1 BRA LBL21 ;Branch alwavs ; LBL23 ;Chage floating point format SHLR ROH BST #7,R0L BLD #0.R6L BST #7,R0H RTS ; .END

# 7.18 Multiplication of Short Floating-Point Numbers

MCU: H8/300 Series H8/300L Series

Label name: FMUL

# 7.18 Function

- 1. The software FMUL performs multiplication of short floating-point numbers placed in four general-purpose registers and places the result of multiplication in two of the four general-purpose registers.
- 2. All arguments used with the software FMUL are represented in short floating-point form.

#### 7.18.1 Arguments

| Descript | ion                      | Memory area | Data length (bytes) |
|----------|--------------------------|-------------|---------------------|
| Input    | Multiplicand             | R0, R1      | 4                   |
|          | Multiplier               | R2, R3      | 4                   |
|          |                          | R0, R1      | 4                   |
| Output   | Result of multiplication | "           |                     |

## 7.18.2 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| \$ | \$ | ×  | ×  | ×  | ×  | ×  | ٠  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | ×  | ×  | ×  |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |  |
|------------------------|--|
| 348                    |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 16                     |  |
| Clock cycle count      |  |
| 1078                   |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |
|                        |  |

### 7.18.4 Notes

The clock cycle count (16) in the specifications is for the example shown in figure 7.45.

For the format of floating-point numbers, see "About Short Floating-point Numbers <Reference>."

### 7.18.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software FMUL:
    - (i) Input arguments:
      - R0: Contains the upper 2 bytes of a short floating-point multiplicand.
      - R1: Contains the lower 2 bytes of the short floating-point multiplicand.
      - R2: Contains the upper 2 bytes of a short floating-point multiplier.
      - R3: Contains the lower 2 bytes of the short floating-point multiplier.

#### 236
- (ii) Output arguments
  - R0: Contains the upper 2 bytes of the result.
  - R1: Contains the lower 2 bytes of the result.
- b. Figure 7.45 shows an example of the software FMUL being executed. When the input arguments are set as shown in (a), the result of multiplication is placed in R0 and R1 as shown in (b).



Figure 7.45 Example of Software FMUL Execution

- 2. Notes on usage
  - a. The maximum and minimum values that can be handled by the software FADD are as follows:
    - { Positive maximum H'7F800000 Positive minimum H'00000001 Negative maximumH'80000001 Negative minimum H'FF800000
  - b. All positive short floating-point numbers H'7F800000 to H'7FFFFFFF are treated as a maximum value (H'7F800000). All negative short floating-point numbers H'FF800000 to H'FFFFFFFF are treated as a minimum value (H'FfF800000).
  - c. As a maximum value is treated as infinity (∞),∞ x 100 = ∞ or ∞ x (-100) = -∞. (See table 7.6)

# Renesas

| Positive number<br>Negative number<br>Positive number            | H'7F800000 (+∞)<br>H'FF800000 (−∞)                      |  |
|------------------------------------------------------------------|---------------------------------------------------------|--|
| 5                                                                |                                                         |  |
| Positive number                                                  |                                                         |  |
| i ositive number                                                 | H'FF800000 (–∞)                                         |  |
| Negative number                                                  | H'7F800000 (+∞)                                         |  |
| >H'7F800000 (+∞)                                                 | H'7F800000 (+∞)                                         |  |
| <h'ff800000 (–∞)<="" td=""><td>H'FF800000 (–∞)</td></h'ff800000> | H'FF800000 (–∞)                                         |  |
| >H'7F800000 (+∞)                                                 | H'FF800000 (–∞)                                         |  |
| <h'ff800000 (–∞)<="" td=""><td>H'7F800000 (+∞)</td></h'ff800000> | H'7F800000 (+∞)                                         |  |
|                                                                  | <h'ff800000 (-∞)<br="">&gt;H'7F800000 (+∞)</h'ff800000> |  |

 Table 7.6
 Examples of Operation with Maximum Values Used as Arguments

- d. H'80000000 is treated as H'00000000 (zero).
- e. After execution of the software FMUL, the multiplicand and multiplier data are destroyed. If the input arguments are necessary after software FMUL execution, save them on memory.
- 3. Data memory

The software FMUL does not use the data memory.

4. Example of use

Set a multiplicand and a multiplier in the general-purpose registers and call the software FMUL as a subroutine.



5. Operation

Multiplication of short floating-point numbers is done in the following steps:

a. The software checks whether the multiplicand and multiplier are "0".

(i) If either the multiplicand or multiplier is "0", H'00000000 is output.

- b. The software checks whether the multiplicand and multiplier are infinite. If they are infinite, the values listed in table 7.6 are output.
- c. Assume that the multiplicand is  $R_1$  (sign bit= $S_1$ , exponent part= $\alpha_1$ , mantissa part= $\beta_1$ ) and the multiplier is  $R_2$  (sign bit= $S_2$ , exponent part= $\alpha_2$ , mantissa part= $\beta_2$ ). Then R1 and R2 are given by

R1= (-1)  $^{S1} \times 2^{\alpha 1 - 127} \times \beta_1$ 

R2= (-1) 
$$^{S2} \times 2^{\alpha 2 - 127} \times \beta_2$$

Multiplication of these two numbers is given by

 $R1 \times R2 = (-1)^{S1+S2} \times 2^{\alpha_{1+\alpha_{2-1}-127}} \times \beta_{1} \times \beta_{2}$ 

In the case of the floating-point format, the multiplication equation changes as follows, because H'7F (D'127) is added to the result of multiplication of the exponent parts:

 $\mathbf{R}_1 \times \mathbf{R}_2 = (-1)^{S1+S2} \times 2^{\alpha 1+\alpha 2-127} \times \beta_1 \times \beta_2$ 

Thus, the multiplication is performed in the steps below:

- (i) The software checks the sign bits of  $R1 \times R2$ .
- (ii) Addition is done on the exponent parts.

Both  $\alpha_1$  and  $\alpha_2$  involve addition of H'7F (D'127) according to the floating-point format. As H'7F (D'127) is also added to the result of multiplication, the operation goes as follows:

 $(\alpha_1 - H'7F) + (\alpha_2 - H'7F) + H'7F = \alpha_1 + \alpha_2 - H'7F$ 

(In the case of the denormalized format, 1 is added to the exponent part before multiplication is done.)

(iii) Multiplication is done on the mantissa parts.

This operation includes the value of the implicit MSB.

(In the case of the denormalized format, the implicit MSB of the mantissa part is treated as "0".)

(iv) The result of multiplication is represented in floating-point format.





















# 7.18.7 Program List

\*\*\* H8/300 ASSEMBLER VER 1.0B \*\* 08/18/92 10:22:23 PROGRAM NAME = 1 2 ;\* :FLOATING POINT MULTIPLICATION (FMUL) 3 ;\* 00 - NAME 4 ;\* 5 6 ;\* :R0 (UPPER WORD OF MULTI PLICAND) 7 ;\* ENTRY 8 ;\* R1 (LOWER WORD OF MULTI PLICAND) 9 ;\* R2 (UPPER WORD OF MULTIPLIER) 10 ;\* R3 (LOWER WORD OF MULTIPLIER) 11 ;\* 12 ;\* RETURNS :R0 (UPPER WORD OF RESULT) ;\* 13 R1 (LOWER WORD OF RESULT) 14 ;\* 15 16 ; 17 FMUL cod C 0000 .SECTION FMUL\_code,CODE,ALIGN=2 18 .EXPORT FMUL 19 ; 20 FMUL\_cod C 00000000 FMUL .EQU \$ ;Entry point 21 FMUL\_cod C 0000 FE00 MOV.B #H'00,R6L ;Clear R6L 22 FMUL\_cod C 0002 79057F80 MOV.W #H'7F80,R5 ;Set "H'7F80" 23 ; 24 FMUL\_cod C 0006 7770 BLD #7,R0H ;Set sign bit of multiplicand 25 FMUL\_cod C 0008 670E BST #0,R6L ; to bit 0 of R6L 26 FMUL\_cod C 000A 7270 BCLR #7,R0H ;Bit clear bit 7 of ROH 27 ; 28 FMUL\_cod C 000C 7772 BLD #7,R2H : 29 FMUL\_cod C 000E 750E BXOR #0,R6L ;Set sign bit of result 30 FMUL cod C 0010 670E BST #0,R6L ; to bit 0 of R6L 31 FMUL cod C 0012 7272 BCLR #7,R2H ;Bit clear bit 7 of R2H 32 ; 33 FMUL cod C 0014 0D11 MOV.W R1.R1 34 FMUL cod C 0016 4604 BNE LBL1 MOV.W R0,R0 35 FMUL cod C 0018 0D00 ;Branch if R1=R0=0 36 FMUL\_cod C 001A 4708 BEO LBL2 37 FMUL\_cod C 001C LBL1 38 FMUL\_cod C 001C 0D33 MOV.W R3,R3 39 FMUL\_cod C 001E 460C LBL3 BNE Branch if not R3=0 40 FMUL\_cod C 0020 0D22 MOV.W R2,R2 BNE LBL3 41 FMUL\_cod C 0022 4608 Branch if not R2=0 42 . 43 FMUL cod C 0024 LBL2 44 FMUL cod C 0024 79000000 MOV.W #H'0000,R0 ;Set 0 to result 45 FMUL cod C 0028 0D01 MOV.W R0,R1 46 FMUL cod C 002A 5470 RTS 47 ; 48 FMUL cod C 002C LBL3 49 EMUL cod C 002C 1D05 CMP.W R0,R5 50 FMUL\_cod C 002E 4304 BLS LBL4 ;Branch if R0>=R5 51 FMUL cod C 0030 1D25 CMP.W R2,R5 52 FMUL\_cod C 0032 4218 BHI LBL7 /Branch if R2>=R5 53 FMUL\_cod C 0034 LBL4 #0,R6L 54 FMUL cod C 0034 770E BLD ;Load sign bit 55 FMUL cod C 0036 450A BCS LBL6 ;Branch if C=1 56 FMUL cod C 0038 LBL5 57 FMUL\_cod C 0038 79007F80 MOV.W #H'7F80,R0 ;Set #H'7F800000 to result 58 FMUL cod C 003C 79010000 MOV.W #H'0000,R1 59 FMUL\_cod C 0040 5470 RTS 60 FMUL cod C 0042 LBL6 61 FMUL\_cod C 0042 7900FF80 MOV.W #H'FF80,R0 ;Set #H'FF800000 to result 62 FMUL cod C 0046 79010000 MOV.W #H'0000,R1 63 FMUL cod C 004A 5470 RTS

| 64                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                          |                                                                                                                                      |                                                                                                                                                                                             |            |                                                                                                                                            |                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                               | THUI and C                                                                                                                                                                                                                                               | 0040                                                                                                                                 |                                                                                                                                                                                             | ;<br>LBL7  |                                                                                                                                            |                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             | гвг /      |                                                                                                                                            |                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | BLD                                                                                                                                        | #7,ROL                                                                                                                                                                               | ;                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | ROTXL                                                                                                                                      | ROH                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | MOV.B                                                                                                                                      |                                                                                                                                                                                      | ;Set exponent of multiplicand to R4                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               | 0052                                                                                                                                 | F400                                                                                                                                                                                        |            | MOV.B                                                                                                                                      | #H'00,R4H                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                              |
| 70                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                          | 0054                                                                                                                                 |                                                                                                                                                                                             | ;          |                                                                                                                                            |                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | BLD                                                                                                                                        | #7,R2L                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | ROTXL                                                                                                                                      | R2H                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | MOV.B                                                                                                                                      | R2H,R5L                                                                                                                                                                              | ;Set exponent of multiplier to R5                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               | 005A                                                                                                                                 | F500                                                                                                                                                                                        |            | MOV.B                                                                                                                                      | #H'00,R5H                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                              |
| 75                                                                                                                                                                                                                                                                                                            | FMUL cod C                                                                                                                                                                                                                                               | 0050                                                                                                                                 | 2020                                                                                                                                                                                        | ;          | BCLR                                                                                                                                       | #7,R0L                                                                                                                                                                               | Clear bit 7 of R0L                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                               | _                                                                                                                                                                                                                                                        |                                                                                                                                      |                                                                                                                                                                                             |            |                                                                                                                                            |                                                                                                                                                                                      | Clear bit / of Rol                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C<br>FMUL cod C                                                                                                                                                                                                                                 |                                                                                                                                      |                                                                                                                                                                                             |            | MOV.B                                                                                                                                      | LBL8                                                                                                                                                                                 | much is multipliced in demonstrated                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | BEQ<br>BSET                                                                                                                                | H7,R0L                                                                                                                                                                               | ;Branch if multiplicand is denormalized<br>;Set implicit MSB                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | BRA                                                                                                                                        |                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                          |                                                                                                                                      | 4002                                                                                                                                                                                        | LBL8       | BRA                                                                                                                                        | LBL9                                                                                                                                                                                 | ;Branch always                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                                 |                                                                                                                                      | 0.004                                                                                                                                                                                       | LBL0       | ADDS.W                                                                                                                                     | #1 104                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                              |
| 83                                                                                                                                                                                                                                                                                                            | FMUL_COA C                                                                                                                                                                                                                                               | 0066                                                                                                                                 | 0804                                                                                                                                                                                        | ;          | ADDS.W                                                                                                                                     | #1,R4                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               | 0060                                                                                                                                 |                                                                                                                                                                                             | ,<br>LBL9  |                                                                                                                                            |                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      | 2023                                                                                                                                                                                        | гвга       | BCLR                                                                                                                                       | #7,R2L                                                                                                                                                                               | Clear bit 7 of R2L                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                          |                                                                                                                                      |                                                                                                                                                                                             |            |                                                                                                                                            |                                                                                                                                                                                      | Clear bit / of R2L                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | MOV.B                                                                                                                                      |                                                                                                                                                                                      | (Durant if multipling is descentling)                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                                 |                                                                                                                                      |                                                                                                                                                                                             |            | BEQ<br>BSET                                                                                                                                | LBL10<br>#7,R2L                                                                                                                                                                      | ;Branch if multiplier is denormalized<br>;Set implicit MSB                                                                                                                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                          |                                                                                                                                      |                                                                                                                                                                                             |            |                                                                                                                                            |                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      | 4002                                                                                                                                                                                        | LBL1       | BRA                                                                                                                                        | LBL11                                                                                                                                                                                | Branch always                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                                 |                                                                                                                                      | 0.005                                                                                                                                                                                       | TRTI       | ADDS.W                                                                                                                                     | #1 DF                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_COA C                                                                                                                                                                                                                                               | 0072                                                                                                                                 | 0805                                                                                                                                                                                        |            | ADDS.W                                                                                                                                     | #1,K5                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                              |
| 92                                                                                                                                                                                                                                                                                                            | THUI and C                                                                                                                                                                                                                                               | 0074                                                                                                                                 |                                                                                                                                                                                             | ;<br>LBL1: |                                                                                                                                            |                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                                 |                                                                                                                                      | 0054                                                                                                                                                                                        |            |                                                                                                                                            | R5,R4                                                                                                                                                                                | addition exponents                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                               | FMUL cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            |                                                                                                                                            | #H'FE,CCR                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | ANDC                                                                                                                                       | #H'FE,CCR<br>#H'7F,R4L                                                                                                                                                               | ;Clear C flag of CCR<br>;R4L - #H'7F - C -> R4L                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            |                                                                                                                                            | #H'00,R4H                                                                                                                                                                            | /R4L - #R /F - C -> R4L                                                                                                                                                                                                                                                                                                                      |
| 98                                                                                                                                                                                                                                                                                                            | -                                                                                                                                                                                                                                                        | 007A                                                                                                                                 | B400                                                                                                                                                                                        | ;          | JUBA.B                                                                                                                                     | #H 00,K4H                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL cod C                                                                                                                                                                                                                                               | 0070                                                                                                                                 | 6DE4                                                                                                                                                                                        | '          | PUSH                                                                                                                                       | R4                                                                                                                                                                                   | Push R4                                                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | PUSH                                                                                                                                       | R6                                                                                                                                                                                   | Push R6                                                                                                                                                                                                                                                                                                                                      |
| 100                                                                                                                                                                                                                                                                                                           | FMOD_COU C                                                                                                                                                                                                                                               | 0075                                                                                                                                 | 0DF 0                                                                                                                                                                                       | ;          | FODI                                                                                                                                       | 10                                                                                                                                                                                   | /Fush Ro                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               | 0080                                                                                                                                 | 0004                                                                                                                                                                                        | '          | MOV.W                                                                                                                                      | R0,R4                                                                                                                                                                                | i                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      |                                                                                                                                                                                             |            | MOV.W                                                                                                                                      | R1,R5                                                                                                                                                                                | ,                                                                                                                                                                                                                                                                                                                                            |
| 104                                                                                                                                                                                                                                                                                                           | 11102_000 0                                                                                                                                                                                                                                              | 0002                                                                                                                                 | 0010                                                                                                                                                                                        | ;          |                                                                                                                                            | 112 / 113                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                                      | 0022                                                                                                                                                                                        | ,          | MOV.B                                                                                                                                      | R2L,R2H                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                          |                                                                                                                                      |                                                                                                                                                                                             |            |                                                                                                                                            | icald / icali                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                          |                                                                                                                                      |                                                                                                                                                                                             |            | TSR                                                                                                                                        | @MIII.Z                                                                                                                                                                              | :R2T. * (R0T.:R1) -> (R4:R5)                                                                                                                                                                                                                                                                                                                 |
| 106                                                                                                                                                                                                                                                                                                           | FMUL_cod C                                                                                                                                                                                                                                               | 0086                                                                                                                                 | 5E000000                                                                                                                                                                                    |            | JSR                                                                                                                                        | @MULA<br>R4                                                                                                                                                                          | ;R2L * (R0L:R1) -> (R4:R5)                                                                                                                                                                                                                                                                                                                   |
| 106<br>107                                                                                                                                                                                                                                                                                                    | FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                                 | 0086<br>008A                                                                                                                         | 5E000000<br>6DF4                                                                                                                                                                            |            | PUSH                                                                                                                                       | R4                                                                                                                                                                                   | ;Push R4                                                                                                                                                                                                                                                                                                                                     |
| 106<br>107<br>108                                                                                                                                                                                                                                                                                             | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                   | 0086<br>008A                                                                                                                         | 5E000000<br>6DF4                                                                                                                                                                            | ;          |                                                                                                                                            |                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                              |
| 106<br>107<br>108<br>109                                                                                                                                                                                                                                                                                      | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                   | 0086<br>008A<br>008C                                                                                                                 | 5E000000<br>6DF4<br>6DF5                                                                                                                                                                    | ;          | PUSH<br>PUSH                                                                                                                               | R4<br>R5                                                                                                                                                                             | ;Push R4                                                                                                                                                                                                                                                                                                                                     |
| 106<br>107<br>108<br>109<br>110                                                                                                                                                                                                                                                                               | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                   | 0086<br>008A<br>008C<br>008E                                                                                                         | 5E000000<br>6DF4<br>6DF5<br>0C32                                                                                                                                                            | ;          | PUSH<br>PUSH<br>MOV.B                                                                                                                      | R4<br>R5<br>R3H,R2H                                                                                                                                                                  | ;Push R4<br>;Push R5                                                                                                                                                                                                                                                                                                                         |
| 106<br>107<br>108<br>109<br>110<br>111                                                                                                                                                                                                                                                                        | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                       | 0086<br>008A<br>008C<br>008E<br>0090                                                                                                 | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000                                                                                                                                                | ;          | PUSH<br>PUSH<br>MOV.B<br>JSR                                                                                                               | R4<br>R5<br>R3H,R2H                                                                                                                                                                  | ;Push R4                                                                                                                                                                                                                                                                                                                                     |
| 106<br>107<br>108<br>109<br>110<br>111<br>112                                                                                                                                                                                                                                                                 | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                         | 0086<br>008A<br>008C<br>008E<br>0090<br>0094                                                                                         | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4                                                                                                                                        | ;          | PUSH<br>PUSH<br>MOV.B<br>JSR<br>PUSH                                                                                                       | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4                                                                                                                                                   | ;Push R4<br>;Push R5<br>;R3L * (R0L:R1) -> (R4:R5)<br>;Push R4                                                                                                                                                                                                                                                                               |
| 106<br>107<br>108<br>109<br>110<br>111<br>112                                                                                                                                                                                                                                                                 | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                       | 0086<br>008A<br>008C<br>008E<br>0090<br>0094                                                                                         | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4                                                                                                                                        | ;          | PUSH<br>PUSH<br>MOV.B<br>JSR                                                                                                               | R4<br>R5<br>R3H,R2H<br>@MULA                                                                                                                                                         | ;Push R4<br>;Push R5<br>;R3L * (R0L:R1) -> (R4:R5)                                                                                                                                                                                                                                                                                           |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114                                                                                                                                                                                                                                                   | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                         | 0086<br>008A<br>008C<br>008E<br>0090<br>0094<br>0096                                                                                 | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5                                                                                                                                |            | PUSH<br>PUSH<br>MOV.B<br>JSR<br>PUSH                                                                                                       | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5                                                                                                                                             | ;Push R4<br>;Push R5<br>;R3L * (R0L:R1) -> (R4:R5)<br>;Push R4                                                                                                                                                                                                                                                                               |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115                                                                                                                                                                                                                                            | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                           | 0086<br>008A<br>008C<br>008E<br>0090<br>0094<br>0096                                                                                 | 52000000<br>6DF4<br>6DF5<br>0C32<br>52000000<br>6DF4<br>6DF5<br>0CB2                                                                                                                        |            | PUSH<br>PUSH<br>MOV.B<br>JSR<br>PUSH<br>PUSH<br>MOV.B                                                                                      | R4<br>R5<br>@MULA<br>R4<br>R5<br>R3L,R2H                                                                                                                                             | <pre>;Push R4 ;Push R5 ;R3L * (R0L:R1) -&gt; (R4:R5) ;Push R4 ;Push R5 ;</pre>                                                                                                                                                                                                                                                               |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116                                                                                                                                                                                                                                     | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                             | 0086<br>008A<br>008C<br>0090<br>0094<br>0096<br>0098<br>0098                                                                         | 5E000000<br>6DP4<br>6DP5<br>0C32<br>5E000000<br>6DP4<br>6DP5<br>0CB2<br>5E000000                                                                                                            |            | PUSH<br>PUSH<br>MOV.B<br>JSR<br>PUSH<br>PUSH<br>MOV.B<br>JSR                                                                               | R4<br>R5<br>«MULA<br>R4<br>R5<br>R3L,R2H<br>«MULA                                                                                                                                    | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)</pre>                                                                                                                                                                                                         |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117                                                                                                                                                                                                                              | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                               | 0086<br>008A<br>008C<br>0090<br>0094<br>0096<br>0098<br>0098<br>009A                                                                 | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5<br>0CE2<br>5E000000<br>0D42                                                                                                    |            | PUSH<br>PUSH<br>MOV.B<br>JSR<br>PUSH<br>PUSH<br>MOV.B                                                                                      | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5<br>R3L,R2H<br>@MULA<br>R4,R2                                                                                                                | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)</pre>                                                                                                                                                                                                         |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118                                                                                                                                                                                                                       | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                 | 0086<br>008A<br>008C<br>0090<br>0094<br>0096<br>0098<br>0098<br>009A                                                                 | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5<br>0CE2<br>5E000000<br>0D42                                                                                                    |            | PUSH<br>PUSH<br>MOV.B<br>JSR<br>PUSH<br>PUSH<br>MOV.B<br>JSR<br>MOV.W                                                                      | R4<br>R5<br>«MULA<br>R4<br>R5<br>R3L,R2H<br>«MULA                                                                                                                                    | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4</pre>                                                                                                                                                                                            |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119                                                                                                                                                                                                                | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                 | 0086<br>008A<br>008C<br>0090<br>0094<br>0096<br>0098<br>0098<br>009A<br>009E<br>00A0                                                 | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53                                                                                            |            | PUSH<br>PUSH<br>MOV.B<br>JSR<br>PUSH<br>PUSH<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W                                                      | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5<br>R3L,R2H<br>@MULA<br>R4,R2                                                                                                                | <pre>;Push R4<br/>;Push R5<br/>;R3L * (R0L:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (R0L:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5</pre>                                                                                                                                                                               |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120                                                                                                                                                                                                         | FMUL_cod C<br>FMUL_cod C                                                                                                   | 0086<br>008A<br>008C<br>0098<br>0090<br>0094<br>0098<br>0098<br>0098<br>0098<br>0098                                                 | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000                                                                                |            | PUSH<br>PUSH<br>MOV.B<br>JSR<br>PUSH<br>PUSH<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W                                                      | R4<br>R5<br>@MULA<br>R4<br>R5<br>@MULA<br>R4,R2<br>R4,R2<br>R5,R3<br>#H'0000,R1                                                                                                      | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1</pre>                                                                                                                                                                 |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121                                                                                                                                                                                                  | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                 | 0086<br>008A<br>008C<br>008E<br>0090<br>0094<br>0094<br>0098<br>0098<br>0098<br>009A<br>009A<br>00A2                                 | 5E000000<br>6DF4<br>6DF5<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75                                                                                |            | PUSH<br>PUSH<br>JSR<br>PUSH<br>PUSH<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W<br>MOV.W<br>POP                                               | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5<br>R3L,R2H<br>@MULA<br>R4,R2<br>R5,R3<br>#H`0000,R1<br>R5                                                                                   | <pre>;Push R4<br/>;Push R5<br/>;R3L * (R0L:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (R0L:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1<br/>;Pop R5</pre>                                                                                                                                                     |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121                                                                                                                                                                                                  | FMUL_cod C<br>FMUL_cod C                                                                                     | 0086<br>008A<br>008C<br>008E<br>0090<br>0094<br>0094<br>0098<br>0098<br>0098<br>009A<br>009A<br>00A2                                 | 5E000000<br>6DF4<br>6DF5<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75                                                                                |            | PUSH<br>PUSH<br>MOV.B<br>JSR<br>PUSH<br>PUSH<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W                                                      | R4<br>R5<br>@MULA<br>R4<br>R5<br>@MULA<br>R4,R2<br>R4,R2<br>R5,R3<br>#H'0000,R1                                                                                                      | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1</pre>                                                                                                                                                                 |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123                                                                                                                                                                             | FMUL_cod C<br>FMUL_cod C                                                                                     | 0086<br>008A<br>008C<br>008E<br>0090<br>0094<br>0096<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098                         | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75<br>6D74                                                                | ;          | PUSH<br>PUSH<br>JSR<br>PUSH<br>PUSH<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W<br>POP<br>POP                                                        | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5<br>R3L,R2H<br>@MULA<br>R4,R2<br>R5,R3<br>#H'0000,R1<br>R5<br>R4                                                                             | <pre>;Push R4<br/>;Push R5<br/>;R3L * (R0L:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (R0L:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1<br/>;Pop R5</pre>                                                                                                                                                     |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124                                                                                                                                                                             | FMUL_cod C<br>FMUL_cod C                                                                       | 0086<br>008A<br>008C<br>008E<br>0090<br>0094<br>0096<br>0098<br>0098<br>0098<br>0098<br>0098<br>00040<br>00042<br>000A2              | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75<br>6D74<br>0BD3                                                        | ;          | PUSH<br>PUSH<br>JSR<br>PUSH<br>PUSH<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W<br>MOV.W<br>POP<br>POP                                               | R4<br>R5<br>R3H,R2H<br>eMULA<br>R4<br>R5<br>R3L,R2H<br>eMULA<br>R4,R2<br>R5,R3<br>#H'0000,R1<br>R5<br>R4<br>R5L,R3H                                                                  | :Push R4<br>;Push R5<br>;R3L * (ROL:R1) -> (R4:R5)<br>;Push R4<br>;Push R5<br>;<br>;R3L * (ROL:R1) -> (R4:R5)<br>;Push R4<br>;Push R5<br>;Clear R1<br>;Pop R5<br>;Pop R4                                                                                                                                                                     |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125                                                                                                                                                                      | FMUL_cod C<br>FMUL_cod C                                                                       | 0086<br>008A<br>008C<br>0090<br>0094<br>0096<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098                                 | 5E000000<br>6DP4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75<br>6D74                                                                | ;          | PUSH<br>PUSH<br>JSR<br>PUSH<br>PUSH<br>PUSH<br>JSR<br>MOV.W<br>MOV.W<br>MOV.W<br>POP<br>POP<br>POP                                         | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5<br>R3L,R2H<br>@MULA<br>R4,R2<br>R5,R3<br>#H '0000,R1<br>R5<br>R4<br>R5L,R3H<br>R5L,R3H                                                      | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1<br/>;Pop R5<br/>;Pop R4<br/>;R3H + R5L -&gt; R3H</pre>                                                                                                                |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126                                                                                                                                                               | FMUL_cod C<br>FMUL_cod C                                                                       | 0086<br>0082<br>0082<br>0090<br>0094<br>0096<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098                                 | 5E000000<br>6DF4<br>6DF5<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75<br>6D74<br>08D3<br>0E5A<br>0E22                                                | ;          | PUSH<br>PUSH<br>JSR<br>PUSH<br>PUSH<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W<br>POP<br>POP<br>POP<br>ADD.B<br>ADD.B<br>ADDX.B              | R4<br>R5<br>R3H, R2H<br>@MULA<br>R4<br>R5<br>R3L, R2H<br>@MULA<br>R4, R2<br>R5, R3<br>#H'0000, R1<br>R5<br>R4<br>R5L, R3H<br>R5L, R3H<br>R5L, R2L<br>R4L, R2L                        | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1<br/>;Pop R5<br/>;Pop R4<br/>;R3H + R5L -&gt; R3H<br/>;R2L + R5H + C -&gt; R2H</pre>                                                                                   |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126                                                                                                                                                               | FMUL_cod C<br>FMUL_cod C                             | 0086<br>0082<br>0082<br>0090<br>0094<br>0096<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098                                 | 5E000000<br>6DF4<br>6DF5<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75<br>6D74<br>08D3<br>0E5A<br>0E22                                                | ;          | PUSH<br>PUSH<br>JSR<br>PUSH<br>PUSH<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W<br>POP<br>POP<br>POP<br>ADD.B<br>ADD.B<br>ADDX.B              | R4<br>R5<br>R3H, R2H<br>@MULA<br>R4<br>R5<br>R3L, R2H<br>@MULA<br>R4, R2<br>R5, R3<br>#H'0000, R1<br>R5<br>R4<br>R5L, R3H<br>R5L, R3H<br>R5L, R2L<br>R4L, R2L                        | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1<br/>;Pop R5<br/>;Pop R4<br/>;R3H + R5L -&gt; R3H<br/>;R2L + R5H + C -&gt; R2L</pre>                                                                                   |
| 106<br>107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128                                                                                                                                                 | FMUL_cod C<br>FMUL_cod C                             | 0086<br>008A<br>008C<br>0090<br>0094<br>0096<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098                                 | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75<br>6D74<br>08D3<br>0E5A<br>0EC2<br>0E49                                | ;          | PUSH<br>PUSH<br>JSR<br>PUSH<br>PUSH<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W<br>POP<br>POP<br>POP<br>ADD.B<br>ADD.B<br>ADDX.B              | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5<br>R3L,R2H<br>@MULA<br>R4,R2<br>R5,R3<br>#H'0000,R1<br>R5<br>R4<br>R5L,R3H<br>R5L,R3H<br>R5L,R3H<br>R5L,R2L<br>R4L,R2H<br>R4H,R1L           | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1<br/>;Pop R5<br/>;Pop R4<br/>;R3H + R5L -&gt; R3H<br/>;R2L + R5H + C -&gt; R2H</pre>                                                                                   |
| 106 107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>124<br>125<br>126<br>127<br>128                                                                                                                 | FMUL_cod C<br>FMUL_cod C               | 0086<br>0082<br>0082<br>0090<br>0094<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098                                                 | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75<br>6D74<br>0BD3<br>0E5A<br>0E5A<br>0E22<br>0E49                        | ;          | PUSH<br>PUSH<br>JSR<br>PUSH<br>PUSH<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W<br>POP<br>POP<br>ADD.B<br>ADD.B<br>ADDX.B<br>ADDX.B<br>ADDX.B | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5<br>R3L,R2H<br>@MULA<br>R4,R2<br>R5,R3<br>#H'0000,R1<br>R5<br>R4<br>R5L,R3H<br>R5H,R2L<br>R4L,R2H<br>R4H,R1L                                 | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1<br/>;Pop R5<br/>;Pop R4<br/>;R3H + R5L -&gt; R3H<br/>;R2L + R5H + C -&gt; R2H<br/>;R1H + R4L + C -&gt; R1L</pre>                                                      |
| 106 107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>120                                                                                                                               | FMUL_cod C<br>FMUL_cod C | 0086<br>0082<br>0082<br>0090<br>0094<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098                                                 | 5E000000<br>6DF4<br>6DF5<br>0C32<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75<br>6D74<br>0BD3<br>0E5A<br>0E2A<br>0E2A<br>0E49<br>6D75<br>6D74        | ;          | PUSH<br>PUSH<br>JSR<br>PUSH<br>PUSH<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W<br>POP<br>POP<br>ADD.B<br>ADD.B<br>ADDX.B<br>ADDX.B<br>ADDX.B | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5<br>R3L,R2H<br>@MULA<br>R4,R2<br>R5,R3<br>#H'0000,R1<br>R5<br>R4<br>R5L,R3H<br>R5L,R3H<br>R5L,R2L<br>R4L,R2L<br>R4L,R2H<br>R4                | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1<br/>;Pop R5<br/>;Pop R4<br/>;R3H + R5L -&gt; R3H<br/>;R2L + R5H + C -&gt; R2H<br/>;R2H + R4L + C -&gt; R2H<br/>;R1L + R4H + C -&gt; R1L<br/>;Pop R5</pre>             |
| 106 107<br>108<br>109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>120<br>120<br>120<br>120<br>120<br>120<br>120<br>120<br>120<br>120 | FMUL_cod C<br>FMUL_cod C | 0086<br>0082<br>0082<br>0090<br>0094<br>0096<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098<br>0098                                 | 5E000000<br>6DF4<br>6DF5<br>5E000000<br>6DF4<br>6DF5<br>0CB2<br>5E000000<br>0D42<br>0D53<br>79010000<br>6D75<br>6D74<br>0BD3<br>0E5A<br>0E22<br>0E49<br>6D75<br>6D74<br>6D75<br>6D74        | ;          | PUSH<br>PUSH<br>JSR<br>PUSH<br>JSR<br>PUSH<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>POP<br>POP<br>ADD.B<br>ADDX.B<br>ADDX.B<br>ADDX.B            | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5<br>R3L,R2H<br>@MULA<br>R4,R2<br>R5,R3<br>#H'0000,R1<br>R5<br>R4<br>R5L,R3H<br>R5L,R3H<br>R5L,R3H<br>R5L,R2L<br>R4H,R1L                      | <pre>;Push R4<br/>;Push R5<br/>;R3L * (R0L:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (R0L:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1<br/>;Pop R5<br/>;Pop R4<br/>;R3H + R5L -&gt; R3H<br/>;R2L + R5H + C -&gt; R2L<br/>;R2H + R4L + C -&gt; R2L<br/>;R2H + R4H + C -&gt; R1L<br/>;Pop R5<br/>;Pop R4</pre> |
| 106 107<br>108 109<br>110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>0<br>131<br>132                                                                                                                                                  | FMUL_cod C<br>FMUL_cod C | 0086<br>0082<br>0082<br>0090<br>0094<br>0096<br>0098<br>0098<br>0098<br>0098<br>0098<br>0080<br>0088<br>0080<br>0080<br>0080<br>0080 | 52000000<br>60P4<br>60P5<br>0032<br>52000000<br>60P4<br>60P5<br>0022<br>52000000<br>0042<br>0053<br>79010000<br>6075<br>6074<br>0803<br>025A<br>0262<br>0249<br>6075<br>6074<br>052<br>0249 | ;          | PUSH<br>PUSH<br>JSR<br>PUSH<br>OV.B<br>JSR<br>MOV.B<br>JSR<br>MOV.W<br>MOV.W<br>POP<br>POP<br>ADD.B<br>ADDX.B<br>ADDX.B<br>ADDX.B          | R4<br>R5<br>R3H,R2H<br>@MULA<br>R4<br>R5<br>R3L,R2H<br>@MULA<br>R4,R2<br>R5,R3<br>#H'0000,R1<br>R5<br>R4<br>R5L,R3H<br>R5H,R2L<br>R4L,R2H<br>R4H,R1L<br>R5<br>R4<br>R5,R2<br>R4L,R1L | <pre>;Push R4<br/>;Push R5<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;<br/>;R3L * (ROL:R1) -&gt; (R4:R5)<br/>;Push R4<br/>;Push R5<br/>;Clear R1<br/>;Pop R5<br/>;Pop R4<br/>;R3H + R5L -&gt; R3H<br/>;R2L + R5H + C -&gt; R2H<br/>;R1L + R4H + C -&gt; R1L<br/>;Pop R5<br/>;Pop R4<br/>;R2 + R5 -&gt; R2</pre>        |



| 134                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | 0.080                                                                                                                        | 6076                                                                                                             | ;     | POP                                                                                                                                        | R6                                                                                                                                         | Pop R6                                                                                                                                                                   |
|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | POP                                                                                                                                        | R4                                                                                                                                         | ;Pop R6<br>;Pop R4                                                                                                                                                       |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | ADDS.W                                                                                                                                     |                                                                                                                                            | леор кч                                                                                                                                                                  |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | MOV.W                                                                                                                                      | R4,R4                                                                                                                                      |                                                                                                                                                                          |
| 139                                                                                                                        |                                                                                                                                                                                                                                                          |                                                                                                                              |                                                                                                                  | ;     |                                                                                                                                            | ,                                                                                                                                          |                                                                                                                                                                          |
| 140                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | 00C4                                                                                                                         | 474A                                                                                                             |       | BEQ                                                                                                                                        | LBL16                                                                                                                                      | Branch if R4=0                                                                                                                                                           |
| 141                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | 00C6                                                                                                                         | 4B48                                                                                                             |       | BMI                                                                                                                                        | LBL16                                                                                                                                      | ;Branch if R4<0                                                                                                                                                          |
| 142                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | 00C8                                                                                                                         |                                                                                                                  | LBL12 | 2                                                                                                                                          |                                                                                                                                            |                                                                                                                                                                          |
| 143                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | 00C8                                                                                                                         | 1B04                                                                                                             |       | SUBS.W                                                                                                                                     | #1,R4                                                                                                                                      |                                                                                                                                                                          |
| 144                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | 00CA                                                                                                                         | 0D44                                                                                                             |       | MOV.W                                                                                                                                      | R4,R4                                                                                                                                      |                                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | BEQ                                                                                                                                        | LBL13                                                                                                                                      | ;Branch if R4=0                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | SHLL                                                                                                                                       | R3L                                                                                                                                        | ;Shift mantissa 1 bit left                                                                                                                                               |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | ROTXL                                                                                                                                      |                                                                                                                                            |                                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                                 |                                                                                                                              |                                                                                                                  |       | ROTXL<br>ROTXL                                                                                                                             |                                                                                                                                            |                                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | ROTXL                                                                                                                                      |                                                                                                                                            |                                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | ROTXL                                                                                                                                      |                                                                                                                                            |                                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | BCC                                                                                                                                        | LBL12                                                                                                                                      | ;Branch if C=0                                                                                                                                                           |
|                                                                                                                            | -<br>FMUL_cod C                                                                                                                                                                                                                                          |                                                                                                                              |                                                                                                                  |       | ROTXR                                                                                                                                      | R1H                                                                                                                                        | Rotate mantissa 1 bit right                                                                                                                                              |
| 154                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | OODE                                                                                                                         | 1309                                                                                                             |       | ROTXR                                                                                                                                      | R1L                                                                                                                                        |                                                                                                                                                                          |
| 155                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | 00E0                                                                                                                         | 1302                                                                                                             |       | ROTXR                                                                                                                                      | R2H                                                                                                                                        |                                                                                                                                                                          |
| 156                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | 00E2                                                                                                                         |                                                                                                                  | LBL1  | 3                                                                                                                                          |                                                                                                                                            |                                                                                                                                                                          |
| 157                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | 00E2                                                                                                                         | 0B04                                                                                                             |       | ADDS.W                                                                                                                                     | #1,R4                                                                                                                                      |                                                                                                                                                                          |
| 158                                                                                                                        |                                                                                                                                                                                                                                                          |                                                                                                                              |                                                                                                                  | ;     |                                                                                                                                            |                                                                                                                                            |                                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | MOV.W                                                                                                                                      | #H'00FF,R5                                                                                                                                 | ;                                                                                                                                                                        |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | CMP.W                                                                                                                                      | R4,R5                                                                                                                                      |                                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | BCC                                                                                                                                        | LBL15                                                                                                                                      | Branch if R5>R4                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                                 |                                                                                                                              |                                                                                                                  |       | BLD<br>BCS                                                                                                                                 | #0,R6L<br>LBL14                                                                                                                            | ;Load sign bit<br>;Branch if C=1                                                                                                                                         |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | MOV.W                                                                                                                                      | #H'7F80,R0                                                                                                                                 | Set H'7F800000 to result                                                                                                                                                 |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | MOV.W                                                                                                                                      | #H'0000,R1                                                                                                                                 | Joee In Jiooodoo eo rebare                                                                                                                                               |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | RTS                                                                                                                                        |                                                                                                                                            |                                                                                                                                                                          |
| 167                                                                                                                        |                                                                                                                                                                                                                                                          |                                                                                                                              |                                                                                                                  | ;     |                                                                                                                                            |                                                                                                                                            |                                                                                                                                                                          |
| 168                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | OOFA                                                                                                                         |                                                                                                                  | LBL14 | 4                                                                                                                                          |                                                                                                                                            |                                                                                                                                                                          |
| 169                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | OOFA                                                                                                                         | 7900FF80                                                                                                         |       | MOV.W                                                                                                                                      | #H'FF80,R0                                                                                                                                 | ;Set H'FF800000 to product                                                                                                                                               |
| 170                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | OOFE                                                                                                                         | 79010000                                                                                                         |       | MOV.W                                                                                                                                      | #H'0000,R1                                                                                                                                 |                                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               | 0102                                                                                                                         | 5470                                                                                                             |       | RTS                                                                                                                                        |                                                                                                                                            |                                                                                                                                                                          |
| 172                                                                                                                        |                                                                                                                                                                                                                                                          |                                                                                                                              |                                                                                                                  | ;     |                                                                                                                                            |                                                                                                                                            |                                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  | LBL15 |                                                                                                                                            |                                                                                                                                            |                                                                                                                                                                          |
|                                                                                                                            | FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                                 |                                                                                                                              |                                                                                                                  |       | MOV.W                                                                                                                                      | R1,R1<br>LBL19                                                                                                                             | Branch if not R1=0                                                                                                                                                       |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | BNE<br>MOV.B                                                                                                                               | R2H,R2H                                                                                                                                    | /Branch II not RI=0                                                                                                                                                      |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | BNE                                                                                                                                        | LBL19                                                                                                                                      | ;Branch if not R2H=0                                                                                                                                                     |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               |                                                                                                                              |                                                                                                                  |       | MOV.W                                                                                                                                      | R1,R0                                                                                                                                      |                                                                                                                                                                          |
|                                                                                                                            | -<br>FMUL_cod C                                                                                                                                                                                                                                          |                                                                                                                              |                                                                                                                  |       | RTS                                                                                                                                        |                                                                                                                                            |                                                                                                                                                                          |
| 180                                                                                                                        |                                                                                                                                                                                                                                                          |                                                                                                                              |                                                                                                                  | ;     |                                                                                                                                            |                                                                                                                                            |                                                                                                                                                                          |
| 181                                                                                                                        | FMUL_cod C                                                                                                                                                                                                                                               | 0110                                                                                                                         |                                                                                                                  | LBL16 | 5                                                                                                                                          |                                                                                                                                            |                                                                                                                                                                          |
| 182                                                                                                                        | EMIT and C                                                                                                                                                                                                                                               |                                                                                                                              | 79050001                                                                                                         |       |                                                                                                                                            |                                                                                                                                            |                                                                                                                                                                          |
|                                                                                                                            | FMOL_COU C                                                                                                                                                                                                                                               | 0110                                                                                                                         |                                                                                                                  |       | MOV.W                                                                                                                                      | #H'0001,R5                                                                                                                                 | ;Set #H'0001 to R5                                                                                                                                                       |
|                                                                                                                            | FMUL_cod C                                                                                                                                                                                                                                               | 0114                                                                                                                         | F618                                                                                                             |       | MOV.B                                                                                                                                      | #H'0001,R5<br>#D'24,R6H                                                                                                                    | ;Set #H'0001 to R5<br>;Se bit counter                                                                                                                                    |
| 184                                                                                                                        | FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                                 | 0114<br>0116                                                                                                                 |                                                                                                                  | LBL1  | MOV.B                                                                                                                                      | #D'24,R6H                                                                                                                                  | ;Se bit counter                                                                                                                                                          |
| 184<br>185                                                                                                                 | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                                   | 0114<br>0116<br>0116                                                                                                         | 1101                                                                                                             | LBL1  | MOV.B<br>7<br>SHLR                                                                                                                         | #D'24,R6H<br>R1H                                                                                                                           |                                                                                                                                                                          |
| 184<br>185<br>186                                                                                                          | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                                     | 0114<br>0116<br>0116<br>0118                                                                                                 | 1101<br>1309                                                                                                     | LBL1  | MOV.B<br>7<br>SHLR<br>ROTXR                                                                                                                | #D'24,R6H<br>R1H<br>R1L                                                                                                                    | ;Se bit counter                                                                                                                                                          |
| 184<br>185<br>186<br>187                                                                                                   | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                       | 0114<br>0116<br>0116<br>0118<br>011A                                                                                         | 1101<br>1309<br>1302                                                                                             | LBL1  | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR                                                                                                       | #D'24,R6H<br>R1H<br>R1L<br>R2H                                                                                                             | ;Se bit counter<br>;Shift mantissa 1 bit right                                                                                                                           |
| 184<br>185<br>186<br>187<br>188                                                                                            | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                         | 0114<br>0116<br>0116<br>0118<br>011A<br>011C                                                                                 | 1101<br>1309<br>1302<br>0B04                                                                                     | LBL1  | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W                                                                                             | #D'24,R6H<br>R1H<br>R1L<br>R2H<br>#1,R4                                                                                                    | ;Se bit counter<br>;Shift mantissa 1 bit right<br>;Increment exponent                                                                                                    |
| 184<br>185<br>186<br>187<br>188<br>189                                                                                     | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                                                       | 0114<br>0116<br>0116<br>0118<br>011A<br>011C<br>011E                                                                         | 1101<br>1309<br>1302<br>0B04<br>1A06                                                                             | LBL1  | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B                                                                                    | #D'24,R6H<br>R1H<br>R1L<br>R2H<br>#1,R4<br>R6H                                                                                             | ;Se bit counter<br>;Shift mantissa 1 bit right                                                                                                                           |
| 184<br>185<br>186<br>187<br>188<br>189<br>190                                                                              | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                                           | 0114<br>0116<br>0118<br>0118<br>011A<br>011C<br>011C<br>011E<br>0120                                                         | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706                                                                     | LBL1  | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W                                                                                             | #D'24,R6H<br>R1H<br>R1L<br>R2H<br>#1,R4<br>R6H<br>LBL18                                                                                    | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter</pre>                                                            |
| 184<br>185<br>186<br>187<br>188<br>189<br>190<br>191                                                                       | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                             | 0114<br>0116<br>0118<br>0118<br>0112<br>0112<br>0120<br>0122                                                                 | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54                                                             | LBL1, | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ                                                                             | #D'24,R6H<br>R1H<br>R1L<br>R2H<br>#1,R4<br>R6H<br>LBL18                                                                                    | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter</pre>                                                            |
| 184<br>185<br>186<br>187<br>188<br>189<br>190<br>191<br>192                                                                | FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C<br>FMUL_cod C                                                                                                                                             | 0114<br>0116<br>0118<br>011A<br>011C<br>011C<br>0120<br>0122<br>0124                                                         | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54<br>47DE                                                     | LBL1  | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ<br>CMP.W                                                                    | #D'24,R6H<br>R1H<br>R2H<br>#1,R4<br>R6H<br>LBL18<br>R5,R4                                                                                  | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter<br/>;Branch if Z=1</pre>                                         |
| 184<br>185<br>186<br>187<br>188<br>189<br>190<br>191<br>192<br>193<br>194                                                  | FMUL_cod C<br>FMUL_cod C                                                                                                   | 0114<br>0116<br>0118<br>0118<br>0112<br>0112<br>0120<br>0122<br>0124<br>0126<br>0128                                         | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54<br>47DE<br>40EE                                             | LBL1  | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ<br>CMP.W<br>BEQ<br>BRA<br>8                                                 | #D'24,R6H<br>R1H<br>R2H<br>#1,R4<br>R6H<br>LBL18<br>R5,R4<br>LBL15<br>LBL17                                                                | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter<br/>;Branch if Z=1<br/>;Branch if R5=R4</pre>                    |
| 184<br>185<br>186<br>187<br>188<br>189<br>190<br>191<br>192<br>193<br>194                                                  | FMUL_cod C<br>FMUL_cod C                                                                                     | 0114<br>0116<br>0118<br>011A<br>011C<br>011C<br>0120<br>0122<br>0124<br>0126<br>0128<br>0128                                 | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54<br>47DE<br>40EE<br>79000000                                 |       | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ<br>CMP.W<br>BEQ<br>BRA<br>B<br>MOV.W                                        | #D'24,R6H<br>R1H<br>R2H<br>#1,R4<br>R6H<br>LBL18<br>R5,R4<br>LBL15<br>LBL17<br>#H'0000,R0                                                  | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter<br/>;Branch if Z=1<br/>;Branch if R5=R4</pre>                    |
| 184<br>185<br>186<br>187<br>188<br>189<br>190<br>191<br>192<br>193<br>194<br>195<br>196                                    | FMUL_cod C<br>FMUL_cod C                                                                       | 0114<br>0116<br>0118<br>011A<br>011C<br>011E<br>0120<br>0122<br>0124<br>0126<br>0128<br>0128<br>012C                         | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54<br>47DE<br>40EE<br>79000000<br>0D01                         |       | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ<br>CMP.W<br>BEQ<br>BRA<br>8<br>MOV.W<br>MOV.W                               | #D'24,R6H<br>R1H<br>R2H<br>#1,R4<br>R6H<br>LBL18<br>R5,R4<br>LBL15<br>LBL17<br>#H'0000,R0                                                  | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter<br/>;Branch if Z=1<br/>;Branch if R5=R4<br/>;Branch always</pre> |
| 184<br>185<br>186<br>187<br>188<br>189<br>190<br>191<br>192<br>193<br>194<br>195<br>196<br>197                             | FMUL_cod C<br>FMUL_cod C                                                         | 0114<br>0116<br>0118<br>011A<br>011C<br>011E<br>0120<br>0122<br>0124<br>0126<br>0128<br>0128<br>012C                         | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54<br>47DE<br>40EE<br>79000000<br>0D01                         | LBL18 | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ<br>CMP.W<br>BEQ<br>BRA<br>B<br>MOV.W                                        | #D'24,R6H<br>R1H<br>R2H<br>#1,R4<br>R6H<br>LBL18<br>R5,R4<br>LBL15<br>LBL17<br>#H'0000,R0                                                  | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter<br/>;Branch if Z=1<br/>;Branch if R5=R4<br/>;Branch always</pre> |
| 184<br>185<br>186<br>187<br>188<br>189<br>190<br>191<br>192<br>193<br>194<br>195<br>196<br>197<br>198                      | FMUL_cod C<br>FMUL_cod C                                                         | 0114<br>0116<br>0118<br>0118<br>0112<br>0120<br>0122<br>0124<br>0126<br>0128<br>0128<br>0122<br>0122                         | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54<br>47DE<br>40EE<br>79000000<br>0D01                         | LBL18 | MOV.B<br>7<br>SHLR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ<br>CMP.W<br>BEQ<br>BRA<br>8<br>MOV.W<br>MOV.W<br>RTS                                 | #D'24,R6H<br>R1H<br>R2H<br>#1,R4<br>R6H<br>LBL18<br>R5,R4<br>LBL15<br>LBL17<br>#H'0000,R0                                                  | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter<br/>;Branch if Z=1<br/>;Branch if R5=R4<br/>;Branch always</pre> |
| 184<br>185<br>186<br>187<br>190<br>191<br>192<br>193<br>194<br>195<br>196<br>197<br>198<br>199                             | FMUL_cod C<br>FMUL_cod C                                                         | 0114<br>0116<br>0118<br>0118<br>0112<br>0120<br>0122<br>0124<br>0126<br>0128<br>0128<br>0122<br>012E                         | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54<br>47DE<br>40EE<br>79000000<br>0D01<br>5470                 | LBL18 | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ<br>CMP.W<br>BEQ<br>BRA<br>8<br>MOV.W<br>MOV.W<br>RTS                        | #D'24,R6H<br>R1H<br>R1L<br>R2H<br>#1,R4<br>R6H<br>LBL18<br>R5,R4<br>LBL15<br>LBL17<br>#H'0000,R0<br>R0,R1                                  | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter<br/>;Branch if Z=1<br/>;Branch if R5=R4<br/>;Branch always</pre> |
| 184<br>185<br>186<br>187<br>190<br>191<br>192<br>193<br>194<br>195<br>196<br>197<br>198<br>199<br>200                      | FMUL_cod C<br>FMUL_cod C                             | 0114<br>0116<br>0116<br>0118<br>011A<br>011C<br>0120<br>0122<br>0124<br>0128<br>0128<br>0128<br>0122<br>0128                 | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54<br>47DE<br>40EE<br>79000000<br>0D01<br>5470                 | LBL18 | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ<br>CMP.W<br>BEQ<br>BRA<br>8<br>MOV.W<br>MOV.W<br>RTS<br>9<br>MOV.B          | #D'24,R6H<br>R1H<br>R2H<br>#1,R4<br>R6H<br>LBL18<br>R5,R4<br>LBL15<br>LBL17<br>#H'0000,R0<br>R0,R1                                         | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter<br/>;Branch if Z=1<br/>;Branch if R5=R4<br/>;Branch always</pre> |
| 184<br>185<br>186<br>187<br>188<br>189<br>190<br>191<br>192<br>193<br>194<br>195<br>196<br>197<br>198<br>199<br>200<br>201 | FMUL_cod C<br>FMUL_cod C                                                         | 0114<br>0116<br>0118<br>0118<br>0112<br>0120<br>0122<br>0124<br>0126<br>0128<br>0128<br>0126<br>0128<br>0120<br>0130<br>0130 | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54<br>47DE<br>40EE<br>79000000<br>0001<br>5470<br>0018<br>0021 | LBL18 | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ<br>CMP.W<br>BEQ<br>BRA<br>8<br>MOV.W<br>MOV.W<br>RTS<br>9<br>MOV.B<br>MOV.B | #D'24,R6H<br>R1H<br>R1L<br>R2H<br>#1,R4<br>R6H<br>LBL18<br>K5,R4<br>LBL15<br>LBL17<br>#H'0000,R0<br>R0,R1<br>R1H,R0L<br>R1H,R0L<br>R1L,R1H | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter<br/>;Branch if Z=1<br/>;Branch if R5=R4<br/>;Branch always</pre> |
| 184<br>185<br>186<br>187<br>188<br>189<br>190<br>191<br>192<br>193<br>194<br>195<br>196<br>197<br>198<br>199<br>200<br>201 | FMUL_cod C<br>FMUL_cod C | 0114<br>0116<br>0118<br>0118<br>0112<br>0120<br>0122<br>0124<br>0126<br>0128<br>0128<br>0126<br>0128<br>0120<br>0130<br>0130 | 1101<br>1309<br>1302<br>0804<br>1A06<br>4706<br>1D54<br>47DE<br>40EE<br>79000000<br>0001<br>5470<br>0018<br>0021 | LBL18 | MOV.B<br>7<br>SHLR<br>ROTXR<br>ROTXR<br>ADDS.W<br>DEC.B<br>BEQ<br>CMP.W<br>BEQ<br>BRA<br>8<br>MOV.W<br>MOV.W<br>RTS<br>9<br>MOV.B<br>MOV.B | #D'24,R6H<br>R1H<br>R2H<br>#1,R4<br>R6H<br>LBL18<br>R5,R4<br>LBL15<br>LBL17<br>#H'0000,R0<br>R0,R1                                         | <pre>;Se bit counter<br/>;Shift mantissa 1 bit right<br/>;Increment exponent<br/>;Decrement bit counter<br/>;Branch if Z=1<br/>;Branch if R5=R4<br/>;Branch always</pre> |

| 204 FMUL_cod C 0136 0CC0 | MOV.B R4L,R0H                 |                               |
|--------------------------|-------------------------------|-------------------------------|
| 205 FMUL_cod C 0138 7778 | BLD #7,R0L                    |                               |
| 206 FMUL_cod C 013A 4502 | BCS LBL20                     | ;Branch if C=1                |
| 207 FMUL_cod C 013C F000 | MOV.B #H'00,R0H               |                               |
| 208 FMUL_cod C 013E      | LBL20                         | ;Change floating point format |
| 209 FMUL_cod C 013E 1100 | SHLR ROH                      |                               |
| 210 FMUL_cod C 0140 6778 | BST #7,R0L                    |                               |
| 211 FMUL_cod C 0142 770E | BLD #0,R6L                    |                               |
| 212 FMUL_cod C 0144 6770 | BST #7,R0H                    |                               |
| 213 FMUL_cod C 0146 5470 | RTS                           |                               |
| 214                      | ;                             |                               |
| 215                      | ;                             |                               |
| 216                      | ;                             |                               |
| 217 FMUL_cod C 0148      | MULA                          | ;R2H * (R0L:R1) -> (R4:R5)    |
| 218 FMUL_cod C 0148 0D04 | MOV.W R0,R4                   | ;R0 -> R4                     |
| 219 FMUL_cod C 014A 0D15 | MOV.W R1,R5                   | ;R1 -> R5                     |
| 220 FMUL_cod C 014C 0C1E | MOV.B R1H,R6L                 | ;RlH -> R6L                   |
| 221                      | ;                             |                               |
| 222 FMUL_cod C 014E 5025 | MULXU R2H,R5                  | ;R2H * R5L -> R5              |
| 223 FMUL_cod C 0150 5026 | MULXU R2H,R6                  | ;R2H * R6L -> R6              |
| 224 FMUL_cod C 0152 5024 | MULXU R2H,R4                  | ;R2H * R4L -> R4              |
| 225                      | ;                             |                               |
| 226 FMUL_cod C 0154 08E5 | ADD.B R6L,R5H                 | ;R5H + R6L -> R5H             |
| 227 FMUL_cod C 0156 0E6C | ADDX.B R6H,R4L                | ;R4L + R6H + C -> R4L         |
| 228 FMUL_cod C 0158 9400 | ADDX.B #H'00,R4H              | ;R4H + #H'00 + C -> R4H       |
|                          |                               |                               |
|                          | VER 1.0B ** 08/18/92 10:22:23 |                               |
| 5                        |                               |                               |
| PROGRAM NAME =           |                               |                               |
|                          |                               |                               |
| 229 FMUL_cod C 015A 5470 | RTS                           |                               |
| 230                      | ;                             |                               |
| 231                      | . END                         |                               |
| *****TOTAL ERRORS 0      |                               |                               |
| *****TOTAL WARNINGS 0    |                               |                               |

PAGE

# 7.19 Square Root of a 32-Bit Binary Number

MCU: H8/300 Series H8/300L Series

Label name: SQRT

### 7.19.1 Function

- 1. The software SQRT finds the square root of a 32-bit binary number and outputs the result in 16-bit binary format.
- 2. All arguments used with the software SQRT are represented in unsigned integers.
- 3. All data is manipulated on general-purpose registers.

#### 7.19.2 Arguments

| Descript | ion                  | Memory area | Data length (bytes) |  |  |
|----------|----------------------|-------------|---------------------|--|--|
| Input    | 32-bit binary number | R4, R5      | 4                   |  |  |
| Output   | Square root          | R3          | 2                   |  |  |

#### 7.19.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| ×  | ×  | ×  | \$ | ×  | ×  | ×  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | ×  | ×  | ×  |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes)<br>94 |
|------------------------------|
|                              |
|                              |
| Data memory (bytes)          |
| 0                            |
| Stack (bytes)                |
| 0                            |
| Clock cycle count            |
| 1340                         |
| Reentrant                    |
| Possible                     |
| Relocation                   |
| Possible                     |
| Interrupt                    |
| Possible                     |

### 7.19.5 Notes

The clock cycle count (1340) in the specifications is for the example shown in figure 7.46.

### 7.19.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software SQRT:
    - R4: Contains, as an input argument, the upper word of a 32-bit binary number whose square root is to be found.
    - R5: Contains, as an input argument, the lower word of the 32-bit binary number whose square root is to be found.
    - R3: Contains, as an output argument, the square root of the 32-bit binary number.
  - b. Figure 7.46 shows an example of the software SQRT being executed. When the input arguments are set as shown in (1), the square root is placed in R3 shown in (2).





- 2. Notes on usage
  - a. When upper bits are not used (see figure 7.47), set 0's in them; otherwise, no correct result can be obtained because the square root is found on numbers including indeterminate data placed in the upper bits.





- b. Figures below the decimal point are discarded.
- 3. Data memory

The software SQRT does not use the data memory.

#### 4. Example of use

Set a 32-bit decimal number whose square root is to be found and call the software SQRT as a subroutine.



- 5. Operation
  - a. Figure 7.48 shows the method of finding the square root H'05 (binary) of H'22 (a 16-bit binary).



Figure 7.48 Computation to Find Square Root

(i) As shown in figure 7.48, the square root of a binary number can be found by processing the number by 2 bits in bit-descending order.

- (ii) The square root ((1)) is equal to Éø (found through processes A, B and C) divided by2. The software SQRT computes Éø to find the square root.
- b. The program is executed in the following steps:
  - (i) The number of steps (D'16) in which the 32-bit binary number is processed by 2 bits is placed in R6L.
  - (ii) The square root areas R2 and R3 and the work areas R0 and R1 are cleared.
  - (iii) R4, R5 and R0, R1 are rotated 2 bits to the left to place the upper 2 bits of the input square root in R0 and R1.
  - (iv) "1" is set in R2 and R3. (2)
  - (v) R2 and R3 are subtracted from R0 and R1 to find the difference. (D, (2), (3), (4)) The difference is placed in R0 and R1.
  - (vi) If the result is positive, R2 and R3 are incremented. (A, -(4))If the result is negative, R2 and R3 are decremented, and R2 and R3 are added to R0 and R1. (D, E, (6))
- c. In the software SQRT, R6 is decremented each time the process (iii) through (vi) of (b) is done. This processing continued until R6 reaches "0".







# 7.19.8 Program List

\*\*\* H8/300 ASSEMBLER VER 1.0B \*\* 08/18/92 10:23:40 PROGRAM NAME = 1 2 ;\* :32 BIT SQUARE ROOT (SQRT) 3 ;\* 00 - NAME 4 ;\* 5 6 ;\* 7 ;\* ENTRY :R4,R5 (32 BIT BINARY) 8 ;\* ;\* RETURN :R3 (SQUARE ROOT) 9 10 ;\* 11 12 ; 13 SORT cod C 0000 .SECTION SORT code, CODE, ALIGN=2 14 .EXPORT SORT 15 ; 16 SQRT\_cod C 00000000 SQRT .EQU \$ ;Entry point 17 SORT cod C 0000 FE10 MOV.B #D'16,R6L ;Set shift counter 18 SQRT\_cod C 0002 79000000 MOV.W #H'0000,R0 ;Clear R0 19 SQRT\_cod C 0006 0D01 MOV.W R0,R1 ;Clear Rl 20 SQRT\_cod C 0008 0D02 MOV.W R0,R2 ;Clear R2 21 SQRT\_cod C 000A 0D03 MOV.W R0,R3 ;Clear R3 22 SQRT\_cod C 000C LBL1 23 SQRT\_cod C 000C F602 MOV.B #H'02,R6H 24 SORT cod C 000E LBL2 25 SQRT\_cod C 000E 100D SHLL.B R5L ;Shift 32 bit binary 1 bit left 26 SQRT\_cod C 0010 1205 ROTXL.B R5H 27 SQRT\_cod C 0012 120C ROTXL.B R4L 28 SQRT\_cod C 0014 1204 ROTXL.B R4H 29 SQRT\_cod C 0016 1209 ROTXL.B R1L 30 SORT cod C 0018 1201 ROTXL.B R1H 31 SQRT\_cod C 001A 1208 ROTXL.B ROL 32 SQRT cod C 001C 1200 ROTXL.B ROH DEC.B R6H 33 SQRT\_cod C 001E 1A06 ;Decrement R6H 34 SORT cod C 0020 46EC BNE LBL2 ;Branch if Z=0 ORC.B #H'01,CCR 35 SQRT cod C 0022 0401 ;Set C flag of CCR 36 SQRT\_cod C 0024 120B ROTXL.B R3L ;Rotate square root 37 SQRT\_cod C 0026 1203 ROTXL.B R3H 38 SQRT\_cod C 0028 120A ROTXL.B R2L 39 SORT cod C 002A 1202 ROTXL B R2H SUB.W R3,R1 40 SQRT\_cod C 002C 1931 ;R1 - R3 -> R1 41 SORT cod C 002E 1EA8 SUBX.B R2L,R0L ;ROL - R2L - C -> ROL SUBX.B R2H,R0H 42 SQRT\_cod C 0030 1E20 :ROH - R2H - C -> ROH BCC LBL3 /Branch if C=0 43 SORT cod C 0032 4412 44 SQRT cod C 0034 0931 ADD.W R3,R1 ;R1 + R3 -> R1 45 SORT cod C 0036 0EA8 ADDX.B R2L.R0L ;ROL + R2L + C -> ROL 46 SQRT\_cod C 0038 0E20 ADDX.B R2H,R0H :ROH + R2H + C -> ROH ORC.B #H'01,CCR 47 SORT cod C 003A 0401 Bit set C flag of CCR 48 SORT cod C 003C BB00 SUBX.B #H'00,R3L ;R3L - #H'00 - C -> R3L 49 SORT cod C 003E B300 SUBX.B #H'00,R3H :R3H - #H'00 - C -> R3H ;R2L - #H'00 - C -> R2L 50 SQRT cod C 0040 BA00 SUBX.B #H'00,R2L SUBX.B #H'00,R2H 51 SQRT cod C 0042 B200 ;R2H - #H'00 - C -> R2H 52 SORT cod C 0044 400A BRA LBL4 ;Branch always 53 SORT cod C 0046 LBL3 ORC.B #H'01,CCR 54 SQRT cod C 0046 0401 ;Bit set C flag of CCR 55 SORT cod C 0048 9B00 ADDX.B #H'00,R3L ;R3L + #H'00 + C -> R3L 56 SQRT cod C 004A 9300 ADDX.B #H'00,R3H ;R3H + #H'00 + C -> R3H 57 SORT cod C 004C 9A00 ADDX.B #H'00,R2L ;R2L + #H'00 + C -> R2L 58 SORT cod C 004E 9200 ADDX.B #H'00,R2H ;R2H + #H'00 + C -> R2H 59 SQRT cod C 0050 LBL4 60 SQRT cod C 0050 1A0E DEC.B R6L ;Decrement shift counter 61 SQRT\_cod C 0052 46B8 BNE LBL1 ;Branch if Z=0 62 SQRT cod C 0054 1102 SHLR.B R2H 63 SQRT\_cod C 0056 130A ROTXR.B R2L

| 64 SQRT_cod C 0058 130 | 13 |   | ROTXR |
|------------------------|----|---|-------|
| 65 SQRT_cod C 005A 130 | B  |   | ROTXR |
| 66 SQRT_cod C 005C 547 | 70 |   | RTS   |
| 67                     |    | ; |       |
| 68                     |    |   | .END  |
| *****TOTAL ERRORS      | 0  |   |       |
| *****TOTAL WARNINGS    | 0  |   |       |
|                        |    |   |       |

ROTXR.B R3H ROTXR.B R3L RTS /Rotate square root

# Section 8 DECIMAL $\leftrightarrow$ HEXADECIMAL CHANGE

# 8.1 Change a 2-Byte Hexadecimal Number to a 5-Character BCD Number

MCU: H8/300 Series H8/300L Series

Label name: HEX

#### 8.1.1 Function

- 1. The software HEX changes a 2-byte hexadecimal number (placed in a general-purpose register) to a 5-character BCD (binary-coded decimal) number and places the result of change in general-purpose registers.
- 2. All arguments used with the software HEX are represented in unsigned integers.
- 3. All data is manipulated on general-purpose registers.

# 8.1.2 Arguments

| Descript | ion                                         | Memory area | Data length (bytes) |
|----------|---------------------------------------------|-------------|---------------------|
| Input    | 2-byte hexadecimal number                   | R0          | 2                   |
| Output   | 5-character BCD number (upper 1 character)  | R2L         | 1                   |
|          | 5-character BCD number (lower 4 characters) | R3          | 2                   |

#### 8.1.3 Internal Register and Flag Changes

| R0 | R1 | R2H R       | 2L R3     | R4 | R5 | R6 | R7 |  |
|----|----|-------------|-----------|----|----|----|----|--|
| ×  | •  | × <b>\$</b> | <b>\$</b> | •  | •  | •  | •  |  |
|    |    |             |           |    |    |    |    |  |
| I  | U  | н           | U         | Ν  | Z  | V  | С  |  |
| •  | •  | ×           | •         | ×  | ×  | ×  | ×  |  |

 $\times$  : Unchanged

• : Indeterminate

t : Result

| Program memory (bytes) |  |
|------------------------|--|
| 30                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 368                    |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |

# 8.1.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software HEX:
    - R0: Contains a 2-byte hexadecimal number as an input argument.
    - R2L: Contains the upper 1 character (1 byte) of a 5-character BCD number as an output argument.
    - R3: Contains the lower 4 characters (2 bytes) of the 5-character BCD number as an output argument.

Figure 8.1 shows the formats of the input and output arguments.



Figure 8.1 Example of Software FILL Execution

b. Figure 8.2 shows an example of the software HEX being executed. When the input argument is set as shown in (1), the 5-character BCD number is placed in R2L and R3 as shown in (2).



Figure 8.2 Example of Software HEX Execution

2. Notes on usage

When upper bits are not used (see figure 8.3), set 0's in them; otherwise, no correct result can be obtained because computation is made on numbers including indeterminate data placed in the upper bits.



Figure 8.3 Examples of Operation with Upper Bits Unused

3. Data memory

The software HEX does not use the data memory.

4. Example of use

Set a 2-byte hexadecimal number in R0 and call the software HEX as a subroutine.



- 5. Operation
  - a. A 4-bit binary number "B3B2B1B0" is represented by equations 1 and 2 below:



Figure 8.4 4-bit Binary Number "B<sub>3</sub>B<sub>2</sub>B<sub>1</sub>B<sub>0</sub>"

- b. First, equation 2 is used to compute  $\alpha = B_3 \times 2 + B_2$  (see figure 8.4) by executing an add instruction (the ADD.B instruction) and decimal correction (the DAA instruction). Next, a series of arithmetic operations such as  $\beta = \alpha \times 2 + B_1$  and  $\gamma = \beta \times 2 + B_0$  are performed to find a 5-character BCD number as the result.
- c. The software HEX uses R0 (input) and R2L and R3 (outputs) to compute  $\alpha = B_3 \times 2 + B_2$ .
  - (i) R2H is used as the counter that shifts R0 (containing the input argument) bit by bit.D'16 is set in R2H for a total of 16 shifts.

- (ii) R0 (containing the 2-byte hexadecimal number) is shifted 1 bit to the left, and the most significant bit is placed in the C flag.
- (iii) R2L and R3 (containing the 5-character BCD number) are processed in ascending order, as follows:

 $\begin{array}{ll} R3L+R3L+C \rightarrow R3L & \mbox{Decimal correction of } R3L \\ R3H+R3H+C \rightarrow R3H & \mbox{Decimal correction of } R3H \\ R2L+R2L+C \rightarrow R2L & \mbox{Decimal correction of } R2L \end{array}$ 

Thus,  $\alpha = B_3 \times 2 + B_2$  has been computed.

(iv) In the software HEX, R2H is decremented each time the process (ii) to (iii) is performed. This processing continues until R2H reaches "0".



# 8.1.7 Program List

| OGRAM NAME =                             |      |      |                   |        |        |                                          |
|------------------------------------------|------|------|-------------------|--------|--------|------------------------------------------|
| 1                                        |      | :*** | ******            | ****** | ****** | *****                                    |
| 2                                        |      | ;*   |                   |        |        |                                          |
| 3                                        |      |      | 00 - NA           | ME     |        | CHANGE 2 BYTE HEXADECIMAL                |
| 4                                        |      | ;*   |                   |        |        | TO BCD (HEX)                             |
| 5                                        |      | ;*   |                   |        |        |                                          |
| 6                                        |      | ;*** | ******            | *****  | ****** | ******                                   |
| 7                                        |      | ;*   |                   |        |        |                                          |
| 8                                        |      | ;*   | ENTRY             |        | :R0    | (HEXADECIMAL)                            |
| 9                                        |      | ;*   |                   |        |        |                                          |
| 10                                       |      | ;*   | RETURNS           |        | :R2L   | (UPPER 1 CHARACTER (BY BCD))             |
| 11                                       |      | ;*   |                   |        | R3     | (LOWER 4 CHARACTER (BY BCD))             |
| 12                                       |      | ;*   |                   |        |        |                                          |
| 13                                       |      | ;*** | ******            | ****** | ****** | *******                                  |
| 14                                       |      | ;    |                   |        |        |                                          |
| 15 HEX_code C 0000                       |      |      | .SECTIO           | N      | HEX_cc | de,CODE,ALIGN=2                          |
| 16                                       |      |      | .EXPORT           |        | HEX    |                                          |
| 17                                       |      | ;    |                   |        |        |                                          |
| 18 HEX_code C                            |      | HEX  | .EQU              |        |        | /Entry point                             |
| 19 HEX_code C 0000                       |      |      | MOV.W             |        |        | ;Clear R2                                |
| 20 HEX_code C 0004                       |      |      | MOV.W             |        |        | Clear R3                                 |
| 21 HEX_code C 0006                       | F210 |      |                   | #D'16, | R2H    | ;Set bit counter                         |
| 22 HEX_code C 0008                       |      | LOOP |                   |        |        |                                          |
| 23 HEX_code C 0008<br>24 HEX code C 000A |      |      | SHLL.B<br>ROTXL.B |        |        | ;Shift hexadecimal 1 bit left            |
| 24 HEX_CODE C 000A                       | 1200 | ;    | RUIAL.E           | RUH    |        |                                          |
| 25<br>26 HEX code C 000C                 | OFPR | ,    | ADDX.B            | כם זכם | r      | ;R3L + R3L -> R3L                        |
| 27 HEX code C 000C                       |      |      | DAA               |        |        | /RSL + RSL -> RSL<br>/Decimal adjust R3L |
| 28 HEX code C 0010                       |      |      | ADDX.B            |        | н      | ;R3H + R3H + C -> R3H                    |
| 29 HEX code C 0012                       |      |      | DAA               |        |        | Decimal adjust R3H                       |
| 30 HEX_code C 0014                       |      |      | ADDX.B            |        | L      | ;R2L + R2L + C -> R2L                    |
| 31 HEX code C 0016                       |      |      | DAA               |        |        | /Decimal adjust R2L                      |
| 32                                       |      | ;    |                   |        |        |                                          |
| 33 HEX_code C 0018                       | 1A02 |      | DEC.B             | R2H    |        | ;Decrement R2H                           |
| 34 HEX_code C 001A                       | 46EC |      | BNE               | LOOP   |        | ;Branch Z=0                              |
| 35 HEX_code C 001C                       | 5470 |      | RTS               |        |        |                                          |
| 36                                       |      | ;    |                   |        |        |                                          |
| 37                                       |      |      | .END              |        |        |                                          |

# 8.2 Change a 5-Character BCD Number to a 2-Byte Hexadecimal Number

MCU: H8/300 Series H8/300L Series

Label name: BCD

### 8.2.1 Function

- 1. The software BCD changes a 5-character BCD (binary-coded decimal) Number (3 bytes, placed in a general-purpose registers) to a 2-byte hexadecimal number and places the result of change in a general-purpose register.
- 2. All data is manipulated on general-purpose registers.
- 3. The 5-character BCD number can be up to H'65535.

#### 8.2.2 Arguments

| Description |                                             | Memory area | Data length (bytes) |  |  |
|-------------|---------------------------------------------|-------------|---------------------|--|--|
| Input       | 5-character BCD number (upper 1 character)  | R0L         | 1                   |  |  |
|             | 5-character BCD number (lower 4 characters) | R1          | 2                   |  |  |
| Output      | 2-byte hexadecimal number                   | R2          | 2                   |  |  |

#### 8.2.3 Internal Register and Flag Changes

| R0H R0L R1 |   | R2 | R3 | R4 | R5H | R5L R6 | R7  |   |  |
|------------|---|----|----|----|-----|--------|-----|---|--|
| ×          | ٠ | •  | \$ | ×  | •   | •      | × × | • |  |
|            |   |    |    |    |     |        |     |   |  |
| I          |   | U  | Н  | U  | N   | Z      | V   | С |  |
| •          |   | •  | ×  | •  | ×   | ×      | ×   | × |  |

 $\times$  : Unchanged

Indeterminate

t : Result
| Program memor | y (bytes) |
|---------------|-----------|
| 64            |           |
| Data memory   | (bytes)   |
| 0             |           |
| Stack (byte   | es)       |
| 2             |           |
| Clock cycle o | count     |
| 210           |           |
| Reentrar      | nt        |
| Possible      | 9         |
| Relocatio     | n         |
| Possible      | 9         |
| Interrup      | t         |
| Possible      | 9         |
|               |           |

## 8.2.5 Description

- 1. Details of functions
  - a. The following arguments are used with the software BCD:
    - R0L: Contains the upper 1 character (1 byte) of a 5-character BCD number as an input argument.
    - R1: Contains the lower 4 characters (2 bytes) of the 5-character BCD number as an input argument.
    - R2: Contains a 2-byte hexadecimal number as an output argument.

Figure 8.5 shows the formats of the input and output arguments.



Figure 8.5 Example of Software MOVE1 Execution

b. Figure 8.6 shows an example of the software BCD being executed. When the input argument is set as shown in (1), the 2-byte hexadecimal number is placed in R2 as shown in (2).



Figure 8.6 Example of Software BCD Execution

- 2. Notes on usage
  - a. The values of bits 4 through 7 of R0L (containing the upper 1 character of the 5-character BCD number) remain unchanged. They are cleared to "0" after execution of the software BCD.
  - b. The 5-character BCD number can be up to H'65535.
  - c. When upper bits are not used, set 0's in them; otherwise, no correct result can be obtained because computation is made on numbers including indeterminate data placed in the upper bits.
- 3. Data memory

The software BCD does not use the data memory.

4. Example of use

Set a 5-character BCD number in the input arguments and call the software BCD as a subroutine.

| WORK1 | . RES. B 3                                                         | Reserves a data memory area in which the user program places a 5-character BCD number (3 bytes).                     |
|-------|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| WORK2 | . RES. B 2                                                         | Reserves a data memory area in which the user program places a 2-byte hexadecimal number.                            |
|       | MOV. B @WORK1, R0L<br>MOV. B @WORK1+1, R1H<br>MOV. B @WORK1+2, R1L | Places in the input argument the 5-<br>character BCD number set by the user<br>program.                              |
|       | JSR @BCD                                                           | Calls the software BCD as a subroutine.                                                                              |
|       | MOV. B @WORK2, R2H }<br>MOV. B @WORK2+1, R2L }<br>                 | Places the 2-byte hexadecimal number<br>(set in the output argument) in the data<br>memory area of the user program. |

- 5. Operation
  - a. The software BCD consists of two processes:
    - (i) Popping up the 5-character BCD number character by character
    - (ii) Changing the popped-up data to a hexadecimal number on a 4-bit basis.
  - b. Figure 8.7 shows the method of computing a 1-character (4-bit) number.



## Figure 8.7 Method of Dividing 1-Byte Register Data by 2

- (i) H'04 is placed for computation of the 5 characters.
- (ii) The 5-character BCD number (R0L, R1H, R1L) is transferred to R6L starting with the most significant byte. Then the upper or lower 4 bits are selected.
- (iii) R0H is decremented each time the process (ii) is performed.
- (iv) When the process (ii) is performed, the software checks whether the counter (R0H) is even or odd.
  - When R0H is odd, R6L is ANDed with H'0F to pop up the lower 4 bits.

- When R0H is even, R6L is shifted 4 bits to the right to pop up the upper 4 bits.
- c. The BCD number is changed to a hexadecimal number in the following steps:
  - (i) A 4-character BCD  $"D_3D_2D_1D_0"$  is represented by equations 1 and 2 below:



Figure 8.8 4-character BCD Number "D<sub>3</sub>D<sub>2</sub>D<sub>1</sub>D<sub>0</sub>"

- (ii) First, equation 2 is used to compute  $\alpha = D_3 \times 10 + D_2$  (see figure 8.8). Next, a series of arithmetic operations such as  $\beta = \alpha \times 10 + D_1$  and  $\gamma = \beta \times 10 + D_0$  are performed to find a hexadecimal number as the result.
- (iii) Equations 3 and 4 are used to compute  $D_3 \times 10$ :

$$D_3 \times 10 = D_3 \times (2 + 8)$$
..... (equation 3)  
=  $D_3 \times 2 \times (1 + 2^2)$ .... (equation 4)

- (iv) The software HEX uses R2 and R3 to compute equation 4 by taking the following steps:
  - 1. Places  $D_3$  in R2 and shifts it 1 bit to the left.
  - 2. Transfers R2 to R3 and shifts it 1 bit to the left.
  - 3. Adds R3 to R2.
- d. The hexadecimal form of the 2-byte BCD number can be obtained by repeating the process b. to c. five times.





## 8.2.7 Program List

\*\*\* H8/300 ASSEMBLER VER 1.0B \*\* 08/22/92 11:09:49 PROGRAM NAME = 1 2 ;\* CHANGE 5 CHARACTER ;\* 00 - NAME 3 ;\* TO 2 BYTE HEXADECIMAL (BCD) 4 5 ;\* 6 7 ;\* 8 ;\* ENTRY :ROL (UPPER 1 CHAR (BY BCD)) 9 ;\* R1 (LOWER 4 CHAR (BY BCD)) 10 ; \* ;\* RETURN :R2 (2 BYTE HEXADECIMAL) 11 12 ;\* 13 14 ; 15 BCD\_code C 0000 .SECTION BCD\_code, CODE, ALIGN=2 .EXPORT 16 BCD ; 17 18 BCD\_code C 00000000 BCD .EQU \$ ;Entry point 19 BCD\_code C 0000 F004 MOV.B #H'04,R0H ;Set bit counter 20 BCD\_code C 0002 79020000 MOV.W #H'0000,R2 ;Clear R2 21 BCD\_code C 0006 0D26 MOV.W R2,R6 ;Clear R6 22 ; 23 BCD\_code C 0008 088A ADD.B ROL,R2L ;R2L + R0L -> R2L 24 BCD\_code C 000A 0C1E MOV.B R1H,R6L ;R1H -> R6L 25 BCD\_code C 000C 5506 BSR TRANS 26 BCD\_code C 000E 0C9E MOV.B R1L,R6L ;R1L -> R6L 27 BCD\_code C 0010 5502 BSR TRANS 28 BCD\_code C 0012 5470 RTS 29 ; 30 ;-----31 : 32 BCD\_code C 0014 TRANS ;Change BCD to hexadecimal MOV.B R6L,R5L BLD #0,R0H 33 BCD\_code C 0014 0CED ;R6L -> R5L 34 BCD code C 0016 7700 ;load bit 0 of ROH 35 BCD\_code C 0018 4406 BCC LBL2 ;Branch if C=0 36 BCD code C 001A T.BT.1 37 BCD\_code C 001A 0CDE MOV.B R5L,R6L ;R51 -> R6L 38 BCD\_code C 001C EEOF AND.B #H'OF,R6L ;Clear bit 7-4 of R6L 39 BCD\_code C 001E 4008 BRA LBL3 ;Branch always 40 BCD code C 0020 LBL2 41 BCD code C 0020 110E SHLR.B R6L Shift R6L 4 bit left 42 BCD\_code C 0022 110E SHLR.B R6L 43 BCD code C 0024 110E SHLP B R6L 44 BCD code C 0026 110E SHLR.B R6L 45 BCD code C 0028 LBL3 46 BCD\_code C 0028 100A ;Shift Hexadecimal 1 bit left SHLL B R2L 47 BCD code C 002A 1202 ROTXL B R2H 48 BCD code C 002C 0D23 MOV.W R2,R3 /R2 -> R3 49 BCD code C 002E 100A SHLL B R2L ;Shift Hexadecimal 2 bit left 50 BCD code C 0030 1202 ROTXL B R2H 51 BCD code C 0032 100A SHLL.B R2L 52 BCD code C 0034 1202 ROTXL.B R2H 53 BCD code C 0036 0932 ADD.W R3,R2 ;R3 + R2 -> R2 54 BCD code C 0038 08EA ADD.B R6L,R2L ADDX.B #0,R2H 55 BCD code C 003A 9200 DEC.B ROH 56 BCD code C 003C 1A00 Decrement bit counter BLD #0,R0H 57 BCD code C 003E 7700 ;load bit 0 of ROH 58 BCD code C 0040 45D8 BCS LBL1 ;Branch if C=! 59 BCD code C 0042 5470 RTS 60 ; .END 61 \*\*\*\*\*TOTAL ERRORS 0 \*\*\*\*\*TOTAL WARNINGS 0

# Section 9 Sorting

# 9.1 Set Constants

MCU: H8/300 Series H8/300L Series

Label name: SORT

#### 9.1.1 Function

- 1. The software SORT sorts the data placed on the data memory, byte by byte, in descending order.
- 2. The number of bytes to be sorted can be up to 255.
- 3. Data to be sorted is represented as unsigned integers.

#### 9.1.2 Arguments

| Descript | ion                                    | Memory area | Data length (bytes) |
|----------|----------------------------------------|-------------|---------------------|
| Input    | Number of bytes of data to be sorted   | R0L         | 1                   |
|          | Start address of the data to be sorted | R4          | 2                   |
| Output   | _                                      | _           | _                   |

#### 9.1.3 Internal Register and Flag Changes

| R0 | R1 | R2 | R3 | R4 | R5 | R6 | R7 |  |
|----|----|----|----|----|----|----|----|--|
| ×  | ×  | •  | •  | ×  | ×  | •  | •  |  |
|    |    |    |    |    |    |    |    |  |
| I  | U  | Н  | U  | Ν  | Z  | V  | С  |  |
| •  | •  | ×  | •  | ×  | ×  | ×  | ×  |  |

 $\times$  : Unchanged

• : Indeterminate

\$ : Result

| Program memory (bytes) |  |
|------------------------|--|
| 34                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 789482                 |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |
|                        |  |

## 9.1.5 Note

The clock cycle count (789482) in the specifications is for sorting 255-byte data in descending order.

#### 9.1.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software SORT:
    - R0L: Contains the number of bytes of data to be sorted 1 as an input argument.
    - R4: Contains the start address of the data to be sorted (stored on RAM).



b. Figure 9.1 shows an example of the software SORT being executed. When the input argument is set as shown in (1), the data is sorted in descending order as shown in (2).

Figure 9.1 Example of Software SORT Execution

- 2. Notes on usage
  - a. Do not set "0" in R0L; otherwise, the software SORT will not operate normally.
  - b. R0L must contain the number of bytes of data to be sorted -1.
- 3. Data memory

The software SORT does not use the data memory.

# Renesas

#### 4. Example of use

Set the input arguments in registers and call the software SORT as a subroutine.



- 5. Operation
  - a. Figure 9.2 shows an example of sorting where three pieces of data are sorted in descending order.



Figure 9.2 Example of Sorting

- (i) The software searches the three pieces of data for the biggest number and sorts it at the extreme left. (See (1), (2) and (3) of figure 9.2.)
- (ii) Next, the software identifies the greater of the second and last numbers as counted from the left and places it at the second place from the left. (See (4) and (5) of figure 9.2.)

# Renesas

- b. Processing by programs
  - (i) R4 is used as the pointer for placing the biggest number. R5 is used as the pointer that indicates the address of the memory area containing the source number.
  - (ii) The comparand is placed in R1L.
  - (iii) The source number is placed in R1H.
  - (iv) R1L and R1H are compared with each other. If the source number is greater than the comparand (R1H > R1L), the two numbers are exchanged.
  - (v) The process (iii) to (iv) is repeated until the counter R0L indicating the remaining source numbers reaches "0".
  - (vi) When R0L reaches "0", the data stored in @R4 is assumed the biggest of the data compared.
  - (vii)The ROH indicating the number of remaining comparands is decremented.



## 9.1.8 Program List

\*\*\* H8/300 ASSEMBLER VER 1.0B \*\* 08/18/92 10:26:21 PROGRAM NAME = 1 2 ;\* ;\* 00 - NAME :SORTING (SORT) 3 ;\* 4 5 ;\* 6 7 ;\* ENTRY :ROL (BYTE NUMBER) 8 ;\* R4 (START ADDRESS OF DATA) 9 ;\* 10 ;\* RETURN :NOTHING 11 ;\* 12 13 ; .SECTION SORT\_code,CODE,ALIGN=2 14 SORT\_cod C 0000 15 .EXPORT SORT 16 ; 17 SORT\_cod C 00000000 SORT .EQU \$ ;Entry point MOV.B ROL,ROH 18 SORT\_cod C 0000 0C80 ;Set data counter 19 SORT\_cod C 0002 0D45 MOV.W R4,R5 ;R4 -> R5 20 SORT\_cod C 0004 6849 MOV.B @R4,R1L ;@R4 -> datal 21 SORT\_cod C 0006 LBL1 22 SORT\_cod C 0006 0B05 ADDS.W #1,R5 ;Increment address pointer1 (R5++) 23 SORT\_cod C 0008 6851 MOV.B @R5,R1H ;@R5 -> data2 24 SORT\_cod C 000A 1C19 CMP.B R1H,R1L 25 SORT\_cod C 000C 4404 BHS LBL2 ;Branch if C=0 26 SORT\_cod C 000E 68D9 MOV.B R1L,@R5 ;Store datal @R5 27 SORT\_cod C 0010 0C19 MOV.B R1H,R1L ;data2 -> data1 28 SORT\_cod C 0012 LBL2 29 SORT\_cod C 0012 1A00 DEC.B ROH ;Decrement data counter 30 SORT\_cod C 0014 46F0 BNE LBL1 ;Branch if Z=0 31 SORT\_cod C 0016 68C9 MOV.B R1L,@R4 ;datal -> @R4 32 SORT\_cod C 0018 1A08 DEC.B ROL ;Decrement byte number 33 SORT\_cod C 001A 4704 BEO EXIT ;Branch Z=0 34 SORT\_cod C 001C 0B04 ADDS.W #1,R4 ;Increment address pointer2 (R4++) 35 SORT\_cod C 001E 40E0 BRA SORT ;Branch always EXIT 36 SORT\_cod C 0020 37 SORT\_cod C 0020 5470 RTS ; 38 .END 39 \*\*\*\*\*TOTAL ERRORS 0 \*\*\*\*\*TOTAL WARNINGS 0

# Section 10 ARRAY

# 10.1 2-Dimensional Array (ARRAY)

MCU H8/300 Series H8/300L Series

Label name: ARRAY

#### 10.1.1 Function

- 1. The software ARRAY retrieves data from a 2-dimensional array (hereafter called an "array") and sets its address and elements (x, y) of the array when the data matches.
- 2. Data to be processed by the software ARRAY are 1-byte unsigned integers.
- 3. The elements of an array are 1-byte unsigned integers.
- 4. An array can be set up in the range 255 bytes  $\times$  255 bytes.

#### 10.1.2 Arguments

| Description |                                 | Memory area  | Data length (bytes) |
|-------------|---------------------------------|--------------|---------------------|
| Input       | Data to be retrieved            | R0L          | 1                   |
|             | Start address of the array      | R4           | 2                   |
|             | Number of rows of the array     | R2L          | 1                   |
|             | Number of columns of the array  | R3L          | 1                   |
| Output      | Address of matched data         | R4           | 2                   |
|             | Array element x of matched data | R5H          | 1                   |
|             | Array element y of matched data | R5L          | 1                   |
|             | Presence of matched data        | C flag (CCR) |                     |

#### 10.1.3 Internal Register and Flag Changes

| R0H | H ROL | . R1 | R2H | R2L | R3H | R3L | R4 | R5H | R5L | R6 | R7 |
|-----|-------|------|-----|-----|-----|-----|----|-----|-----|----|----|
| ×   | •     | •    | ×   | ×   | ×   | ×   | \$ | \$  | \$  | ×  | •  |

| I    | U         | н | U | Ν | Z | V | С  |  |
|------|-----------|---|---|---|---|---|----|--|
| •    | •         | × | • | × | × | × | \$ |  |
| × :l | Jnchanged |   |   |   |   |   |    |  |
| • :1 |           |   |   |   |   |   |    |  |

t : Result

## 10.1.4 Specifications

| Program memory (bytes) |  |
|------------------------|--|
| 46                     |  |
| Data memory (bytes)    |  |
| 0                      |  |
| Stack (bytes)          |  |
| 0                      |  |
| Clock cycle count      |  |
| 1986                   |  |
| Reentrant              |  |
| Possible               |  |
| Relocation             |  |
| Possible               |  |
| Interrupt              |  |
| Possible               |  |

## 10.1.5 Note

The clock cycle count (1986) in the specifications is for the example shown in figure 10.1. If either element x or y is "0", the software terminates immediately and clears the C flag.

#### 10.1.6 Description

- 1. Details of functions
  - a. The following arguments are used with the software ARRAY:
    - (i) Input arguments

| R0L: | Data to be retrieved               |
|------|------------------------------------|
| R4:  | Start address of the array         |
| R2L: | Number of rows of the array (x)    |
| R3L: | Number of columns of the array (y) |
|      |                                    |

(ii) Output arguments

| R4:           | Address of the matched data                           |
|---------------|-------------------------------------------------------|
| R5H:          | Array element x of the matched data                   |
| R5L:          | Array element y of the matched data                   |
| C flag (CCR): | Indicates the state at the end of the software ARRAY. |
| C flag = 1:   | Matched data is found on the array.                   |
| C flag = 0:   | Matched data is not found on the array.               |

b. Figure 10.1 shows an example of the software ARRAY being executed. When the input arguments are set as shown in (1), the software ARRAY references the array  $(16 \times 16)$  in figure 10.2 and places the address of the matched data in R4, the array element x in R5H, and the array element y in R5L as shown in (2).



Figure 10.1 Example of Software ARRAY Execution



Figure 10.2 Array Space

c. Execution of the software ARRAY requires an array as shown in figure 10.3.



Figure 10.3 2-Dimensional Array

- (i) The size of an array is identified by the number of rows (x) and the number of columns (y).
- (ii) The elements of an array are represented by x (row) and y (column), which range from (0, 0) to (x 1, y 1).
- (iii) The start address of an array is (0, 0), at which retrieval starts in the order as shown in figure 10.3.
- 2. Notes on usage

Do not set "0" as x and y; otherwise, the software ARRAY do not start retrieval of data, clears the C flag, and terminates.

3. Data Memory

The software ARRAY does not use the data memory.

4. Example of Use

Set the data to be retrieved and the start address, the number of rows and the number of columns of an array to be searched, and call the software ARRAY as a subroutine.

| r       |        |           |                                      |                                                               |
|---------|--------|-----------|--------------------------------------|---------------------------------------------------------------|
| I-WORK1 | .RES.W | 1         | Reserves a data address of the a     | ta memory area for the start array.                           |
| I-WORK2 | .RES.B | 1         | Reserves a data of rows of the a     | ta memory area for the number<br>array (x).                   |
| I-WORK3 | .RES.B | 1         | Reserves a data<br>of columns of the | ta memory area for the number he array (y).                   |
| I-WORK4 | .RES.B | 1         | Reserves a data be retrieved.        | ta memory area for the data to                                |
|         |        |           |                                      |                                                               |
| O-WORK1 | .RES.W | 1         | Reserves a dat<br>address of the r   | ta memory area for the matched data.                          |
| O-WORK2 | .RES.B | 1         |                                      | ta memory area for the element when the data is matched.      |
| O-WORK3 | .RES.B | 1         |                                      | ta memory area for the element when the data is matched.      |
|         |        |           |                                      |                                                               |
|         | MOV. B | @I_WORK4  | I, R0L                               | Places the data to be retrieved.                              |
|         | MOV. W | @I_WORK1  | , R4                                 | Places the start address of the array.                        |
|         | MOV. B | @I_WORK2  | 2, R2H                               | $\cdots$ Places the number of rows of the array (x).          |
|         | MOV. B | @I_WORK3  | 3, R2L                               | Places the number of columns of the array (y).                |
|         | JSR    | @ARRAY    |                                      | Calls the software ARRAY as a subroutine.                     |
|         | MOV. W | R4, @O_W0 | ORK1                                 | Stores the address of the matched data.                       |
|         | MOV. B | R2H, @O_V | VORK2                                | Stores the element of the array (x) when the data is matched. |
|         | MOV. B | R2L, @O_W | /ORK3                                | Stores the element of the array (y) when the data is matched. |
|         |        |           |                                      |                                                               |



# 10.1.8 Program List

| 1                                                  |        | * * * * * * * | *******         | ******                    | ******                                                     |
|----------------------------------------------------|--------|---------------|-----------------|---------------------------|------------------------------------------------------------|
| 2                                                  | ;*     |               |                 |                           |                                                            |
| 3                                                  |        | 0 - NAM       | ME              |                           | :2-DIMENSIONAL ARRAY (ARRAY)                               |
| 4                                                  | ; *    |               |                 |                           | *****                                                      |
| 5                                                  | ;***** | ******        | *******         | ******                    | * * * * * * * * * * * * * * * * * * * *                    |
| 6<br>7                                             |        | NTRY          |                 |                           |                                                            |
| 7                                                  | ;*     | NIRI          |                 |                           | (REFERENCE DATA)<br>(NUMBER OF COLUM [X])                  |
| 9                                                  | ;*     |               |                 | R3L                       | (NUMBER OF ROW [Y])                                        |
| 10                                                 | ;*     |               |                 |                           | (ARRAY START ADDR)                                         |
| 11                                                 | ;*     |               |                 |                           | (inddif blinti inbit)                                      |
| 12                                                 |        | ETURNS        |                 | R5H                       | (ARRAY ELEMENT OF COLUM [x])                               |
| 13                                                 | ;*     |               |                 |                           | (ARRAY ELEMENT OF LOW [y])                                 |
| 14                                                 | ;*     |               |                 |                           | (MATCH DATA ADDR)                                          |
| 15                                                 | ;*     |               |                 |                           | OF CCR (C=1;TRUE , C=0;FALSE)                              |
| 16                                                 | ; *    |               |                 |                           |                                                            |
| 17                                                 | ;***** | * * * * * * * | *******         | ******                    | *****                                                      |
| 18                                                 | ;      |               |                 |                           |                                                            |
| 19 ARRAY_CO C 0000                                 | . 5    | .SECTION      |                 | ARRAY_code, CODE, ALIGN=2 |                                                            |
| 20                                                 | .1     | EXPORT        | ARRAY           |                           |                                                            |
| 21                                                 | ;      |               |                 |                           |                                                            |
| 22 ARRAY_CO C 00000000                             | ARRAY  |               | .EQU            | \$                        | ;Entry point                                               |
| 23 ARRAY_CO C 0000 0D41                            |        |               | R4,R1           |                           |                                                            |
| 24 ARRAY_CO C 0002 79060000                        |        |               | #H'0000,1       | R6                        | ;Clear R6                                                  |
| 25 ARRAY_CO C 0006 1CAE                            |        |               | R2L,R6L         |                           |                                                            |
| 26 ARRAY_CO C 0008 4720                            |        |               | EXIT1           |                           | ;Branch if Z=1 then exit                                   |
| 27 ARRAY_CO C 000A 1CBE                            |        |               | R3L,R6L         |                           |                                                            |
| 28 ARRAY_CO C 000C 471C<br>29 ARRAY_CO C 000E 50A3 |        | -             | EXIT1<br>R2L,R3 |                           | ;Branch if Z=1 then exit<br>;Get total number of array(R3) |
| 30 ARRAY_CO C 0010                                 | LBL1   | ULAU          | KZL,KS          |                           | Get total number of allay(RS)                              |
| 31 ARRAY_CO C 0010 6840                            |        | OV B          | @R4,R0H         |                           | ;Load array data                                           |
| 32 ARRAY_co C 0012 1C80                            |        |               | ROL,ROH         |                           | , load array data                                          |
| 33 ARRAY_CO C 0014 470A                            |        |               | LBL2            |                           | ;Branch if data find                                       |
| 34 ARRAY_CO C 0016 1B03                            |        |               | #1,R3           |                           | /Decrement R3                                              |
| 35 ARRAY_CO C 0018 1D36                            |        |               | R3,R6           |                           |                                                            |
| 36 ARRAY_CO C 001A 4710                            |        |               | EXIT2           |                           | ;Branch if false                                           |
| 37 ARRAY_co C 001C 0B04                            | AI     | DDS.W         | #1,R4           |                           | ;Increment data pointer                                    |
| 38 ARRAY_co C 001E 40F0                            | BI     | RA            | LBL1            |                           | ;Branch always                                             |
| 39 ARRAY_CO C 0020                                 | LBL2   |               |                 |                           |                                                            |
| 40 ARRAY_CO C 0020 0D45                            | MO     | w.vc          | R4,R5           |                           |                                                            |
| 41 ARRAY_CO C 0022 1915                            | St     | UB.W          | R1,R5           |                           | ;Get count number of find data                             |
| 42 ARRAY_CO C 0024 51A5                            | DI     | IVXU          | R2L,R5          |                           | ;Get array element [x,y]                                   |
| 43 ARRAY_co C 0026 0401                            |        |               | #H'01,CC        | R                         | ;Set C flag of CCR                                         |
| 44 ARRAY_CO C 0028 4002                            |        | RA            | EXIT2           |                           | ;Branch always                                             |
| 45 ARRAY_CO C 002A                                 | EXIT1  |               |                 |                           |                                                            |
| 46 ARRAY_CO C 002A 06FE                            |        | NDC.B         | #H'FE,CC        | R                         | ;Clear C flag of CCR                                       |
| 47 ARRAY_CO C 002C                                 | EXIT2  |               |                 |                           |                                                            |
| 48 ARRAY_co C 002C 5470                            | R      | rs            |                 |                           |                                                            |
| 49                                                 | ;      |               |                 |                           |                                                            |