#### Old Company Name in Catalogs and Other Documents

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

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

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

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

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

#### Notice

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



### RA78K/ I ASSEMBLER PACKAGE USER'S MANUAL for LANGUAGE



**NEC Corporation** 



#### Errata

The followings are corrections in the RA78K/I Assembler Package User's Manual for Language:

| Page                   | For                         | Read                      |
|------------------------|-----------------------------|---------------------------|
| i,[Target Device]      | uPD78122,uPD78124,uPD78P124 | Expurgation               |
| iv,"Assembler related" | EEM-                        | EEU-1205                  |
| iv,"Debugger related"  | IE-78120-R ~ (PC-DOS) based | Expurgation               |
|                        | EEM-1047                    | Expurgation               |
| 1-14,Table 1-1         | PC-9800 series              | IBM PC                    |
|                        | MS-DOS                      | PC-DOS                    |
| A-15~17                | Table C-2                   | Expurgation               |
| A-18,line 3~4          | For the uPD78122 ~          | Expurgation               |
|                        | to read as "addr16"         |                           |
| A-28,Last              | 0 <u>110</u> 0 <u>001</u>   | 0 <u>001</u> 0 <u>110</u> |
|                        | A register                  | L register                |
|                        | L register                  | A register                |

## RA78K/ I ASSEMBLER PACKAGE USER'S MANUAL for LANGUAGE

**NEC Corporation** 

#### INTRODUCTION

Phase-out/Discontinued

This manual is designed to facilitate correct understanding of the basic functions of each program in the RA78K/I Assembler Package (hereinafter referred to as "this package or the package") and the methods of describing source programs for the RA78K/I. This manual does not cover how to operate the respective programs of the RA78K/I assembler package. Therefore, after you have comprehended the contents of this manual, read the RA78K/I Assembler Package User's Manual for Operation (hereinafter referred to as "the Operation Manual") to operate each program in the assembler package.

This manual is applicable to the package product versions V2.0 and upwards of the RA78K/I assembler package.



[Target Devices]

The software of the following microcomputers can be developed with this package:

- o uPD78112, uPD78P112
- o uPD78122, uPD78124, uPD78P124

[Readers of Manual]

Although this manual is intended for those who are familiar with the functions and instructions of the microcomputer subject to software development, the manual can also be used by those who use an assembler program for the first time.

[Organization of Manual] This manual consists of the following six chapters and appendixes:

Chapter 1 - General Outlines the functions of this package including the role of the package in microcomputer development.

Chapter 2 - How to Describe Source Programs Describes the general rules applicable to the description of a source program such as the basic configuration and description format of source programs, and expressions and operators of the assembler.

Chapters 3 & 4 Directives and Control Instructions Details the description format, function, and use of each of the assembler directives and control instructions, including application examples.

Chapter 5 - Macros Outlines macro functions such as macrodefintion, macro reference (macrocall), and macroexpansion. Macro directives are explained in Chapter 3.

Chapter 6 - Product Utilization Introduces some measures recommended for effective utilization of this package.

#### Appendixes

Contain a list of instructions (uCOM-78K/I), a list of directives and control instructions, a list of reserved words, a list of hints on use and restrictions, etc.

NOTE: The uCOM-78K/I instruction set is not detailed in this manual. For these instructions, refer to the user's manual of each microcomputer subject to software development.

Phase-out/Discontinued [Recommended Usage of Manual] For those who use an assembler for the first time: Read from Chapter 1, General of this manual. For those who have a general understanding of assembler programs: You may skip Chapter 1, General of this manual. (However, it is advisable to read Section 1.3, "Reminders Before Program Development".) Source programs for the uCOM-78K/I can be described in several different ways. Be sure to read Chapter 2, "How to Describe Source Programs". For those which wish to know the directives and control instructions of the assembler: Read Chapters 3 and 4, respectively, because the format, function, use, and application examples of each directive or control instruction are detailed in these chapters. The uCOM-78K/I instructions are listed in the respective appendixes. Use the lists for quick reference.

[Symbols and Abbreviations] The following symbols and abbreviations are used in this manual:

| Symbol           | Meaning                                              |
|------------------|------------------------------------------------------|
| • • •            | Continuation (repetition) of data in the same format |
| []               | Parameter(s) in brackets can be omitted.             |
| ** **            | Characters enclosed in " " (double quotes) must be   |
|                  | input as is.                                         |
| ( )              | Characters enclosed in parentheses must be input     |
|                  | as is.                                               |
| <                | Characters enclosed in < > must be input as is       |
|                  | (or indicates a title).                              |
| <u></u>          | Important point                                      |
| ц.               | One or more blanks (spaces) must be input:           |
| $\bigtriangleup$ | Indicates one blank (space).                         |
| •<br>•           | This part of the program description is omitted.     |

[References]

The documents related to this manual are shown below.

| Document name                                                        | Document No. |
|----------------------------------------------------------------------|--------------|
| o Assembler related                                                  | Doodone Not  |
| RA78K/I Assembler Package User's Manual                              | EEM-         |
| for Operation - PC-9800 series (MS-DOS)                              |              |
| and IBM PC (PC-DOS) based                                            |              |
| o Debugger related                                                   | 2            |
| IE-78112-R User's Manual Volume I - Hardware                         | EEP-1026     |
| IE-78112-R User's Manual Volume II - Software                        | EEM-1023     |
| IE-78112-R System Software Operation Manual<br>IBM PC (PC-DOS) based | EEM-1028     |
| IE-78120-R System Software User's Manual<br>IBM PC (PC-DOS) based    | EEM-1047     |
|                                                                      | 1            |
| o Device related                                                     | ``           |
| uPD78112 User's Manual                                               | IEM-1136     |
| Product Catalog for D78112CW/GF                                      | IP-1091      |
|                                                                      |              |

NOTE: Contact your nearest NEC dealer for the latest information on the reference documentation.

\*MS-DOS<sup>TM</sup> is a trademark of Microsoft Corp. \*\*IBM  $PC^{TM}$  and PC-DOS<sup>TM</sup> are trademarks of IBM Corp.

#### TABLE OF CONTENTS

|      |                                                   | Page  |
|------|---------------------------------------------------|-------|
| CHAI | PTER 1 GENERAL                                    | 1 – 1 |
| 1.1  | Assembler Overview                                | 1-1   |
|      | 1.1.1 What is an assembler?                       | 1 – 1 |
|      | 1.1.2 What is a relocatable assembler?            | 1-6   |
| 1.2  | Functional Outline of Assembler Package           | 1-9   |
|      | 1.2.1 Creation of source module file with editor  | 1-10  |
|      | 1.2.2 Assembler                                   | 1-11  |
|      | 1.2.3 Linker                                      | 1-12  |
|      | 1.2.4 Locater                                     | 1-13  |
| 1.3  | Reminders Before Program Development              | 1-14  |
|      | 1.3.1 Size of source module file                  | 1-14  |
|      | 1.3.2 Number of files that can be input to Linker | 1-14  |
|      | 1.3.3 Restriction on number of symbols            | 1-14  |
|      | 1.3.4 Maximum performance characteristics of      |       |
|      | assembler package                                 | 1-15  |
| 1.4  | Features of Assembler Package                     | 1-16  |
|      |                                                   |       |
| CHAI | PTER 2 HOW TO DESCRIBE SOURCE PROGRAMS            | 2-1   |
| 2.1  | Basic Configuration of Source Program             | 2-1   |
|      | 2.1.1 Module header                               |       |
|      | 2.1.2 Module body                                 | 2-3   |
|      | 2.1.3 Module tail                                 | 2-3   |
|      | 2.1.4 Overall configuration of source program     | 2-4   |
|      | 2.1.5 Description example of source program       | 2-5   |
| 2.2  | Description Format of Source Program              |       |
|      | 2.2.1 Configuration of statement                  |       |
|      | 2.2.2 Character set                               |       |
|      | 2.2.3 Fields of statement                         |       |
| 2.3  | Expressions and Operators                         |       |
|      | 2.3.1 Functions of operators                      |       |
|      | 2.3.2 Restrictions on Operations                  |       |
| 2.4  | Characteristics of Operands                       |       |
|      | 2.4.1 Size and address range of operand value     | 2-49  |
|      | 2.4.2 Symbol attributes and relocation            | 0 - 1 |
|      | attributes of operands                            | 2-51  |

.

| CHAPTER 3 DIRECTIVES                                    |          |
|---------------------------------------------------------|----------|
| 3.1 Overview of Directives                              |          |
| 3.2 Directives for Segment Definition                   |          |
| (1) CSEG                                                |          |
| (2) DSEG                                                |          |
| (3) BSEG                                                | 3-16     |
| (4) ORG                                                 | 3-20     |
| (5) ENDS                                                | 3-24     |
| 3.3 Directives for Symbol Definition                    | 3-26     |
| (1) EQU                                                 | 3-27     |
| (2) SET                                                 | 3-34     |
| 3.4 Directives for Memory Initialization and            |          |
| Area Reservation                                        | 3-36     |
| (1) DB                                                  | 3-37     |
| (2) DW                                                  | 3-39     |
| (3) DS                                                  | 3-42     |
| (4) DBIT                                                | 3-44     |
| 3.5 Directives for Linkage                              | 3-46     |
| (1) EXTRN                                               | 3-48     |
| (2) EXTBIT                                              | 3-50     |
| (3) PUBLIC                                              | 3-52     |
| (4) NAME                                                | ••• 3-54 |
| 3.6 Directive for Automatic Selection of BR Instruction | 3-56     |
| (1) BR                                                  | 3-57     |
| 3.7 Macro Directives                                    | 3-61     |
| (1) MACRO                                               | 3-62     |
| (2) LOCAL                                               | 3-64     |
| (3) REPT                                                | 3-67     |
| (4) IRP                                                 | 3-70     |
| (5) EXITM                                               | 3-73     |
| (6) ENDM                                                | 3-77     |
| 3.8 Directive for Assembly Termination                  | 3-79     |
| (1)                                                     |          |
|                                                         |          |

| CHAPTER 4 CONTROL INSTRUCTIONS                    |                 | 4 – 1 |
|---------------------------------------------------|-----------------|-------|
| 4.1 Overview of Control Instructions              | • • • • • • • • | 4-1   |
| 4.2 INCLUDE Control Instruction                   |                 | 4-2   |
| (1) INCLUDE                                       |                 | 4-3   |
| 4.3 Assembly List Control Instructions            |                 | 4-5   |
| (1) EJECT                                         |                 | 4-6   |
| (2) NOLIST                                        |                 | 4-8   |
| (3) LIST                                          |                 | 4-10  |
| (4) SUBTITLE                                      |                 | 4-12  |
|                                                   |                 |       |
| 4.4 Control Instructions for Conditional Assembly | • • • • • • • • | 4-16  |
| (1) IF, ELSEIF, ELSE, ENDIF                       |                 | 4-17  |
| (2) SET, RESET                                    |                 | 4-24  |
|                                                   |                 |       |
| CHAPTER 5 MACROS                                  |                 | 5-1   |
| 5.1 Overview of Macro                             |                 | 5-1   |
| 5.2 Utilization of Macros                         |                 | 5-3   |
| 5.2.1 Macrodefinition                             |                 | 5-3   |
| 5.2.2 Macro reference                             |                 | 5-4   |
| 5.2.3 Macroexpansion                              |                 | 5-5   |
| 5.3 Symbols within Macro                          |                 | 5-7   |
|                                                   |                 |       |
| CHAPTER 6. PRODUCT UTILIZATION                    |                 | 6-1   |

#### APPENDIXES

| APPENDIX A | LIST OF RESERVED WORDS              | A-1  |
|------------|-------------------------------------|------|
| APPENDIX B | LIST OF DIRECTIVES                  | A-4  |
| APPENDIX C | INSTRUCTION SET OF uCOM-78K/I       | A-7  |
| APP C-1.   | Instruction Set and Its Operation   | A-7  |
| APP C-2.   | Instruction Codes                   | A-27 |
| APPENDIX D | MAXIMUM PERFORMANCE CHARACTERISTICS | A-36 |

INDEX

.

#### ILLUSTRATIONS AND TABLES

.

| Fig. 1-1. | Assembler Package 1-1                                 |
|-----------|-------------------------------------------------------|
| Fig. 1-2. | Flow of Assembler 1-2                                 |
| Fig. 1-3. | Development Process of Microcomputer-applied          |
|           | Product 1-3                                           |
| Fig. 1-4. | Software Development Process                          |
| Fig. 1-5. | Assembly Phase by This Package                        |
| Fig. 1-6. | Re-assembly for Debugging 1-7                         |
| Fig. 1-7. | Program Development Utilizing Existing Modules 1-8    |
| Fig. 1-8. | Program Development Procedure with This Package 1-9   |
| Fig. 1-9. | Creation of Source Module File                        |
| Fig. 1-10 | . Functions of Assembler 1-11                         |
| Fig. 1-11 | . Functions of Linker 1-12                            |
| Fig. 1-12 | Functions of Locater 1-13                             |
| Fig. 2-1. | Configuration of Source Module                        |
| Fig. 2-2. | Overall Configuration of Source Program               |
| Fig. 2-3. | Examples of Source Module Configurations 2-5          |
| Fig. 2-4. | Configuration of Sample Program                       |
| Fig. 2-5. | Fields That Make Up A Statement                       |
| Fig. 3-1. | Memory Allocation to Segments                         |
| Fig. 3-2. | Relocation of Code Segment                            |
| Fig. 3-3. | Relocation of Data Segment                            |
| Fig. 3-4. | Relocation of Bit Segment 3-15                        |
| Fig. 3-5. | Relocation of Absolute Segment                        |
| Fig. 3-6. | Relationship of Symbols between Two Modules 3-46      |
|           |                                                       |
| Table 1-1 | . Size of Source Module File 1-14                     |
| Table 2-1 | . Items That Can Be Described in Module Header 2-2    |
| Table 2-2 | . Symbol Types 2-13                                   |
| Table 2-3 | . Types of Symbol Attributes 2-15                     |
| Table 2-4 | • Methods of Representing Numeric Constant Types 2-18 |
| Table 2-5 | . Special Characters That Can Be Described in         |
|           | Operand Field 2-20                                    |
| Table 2-6 | . Types of Operators 2-24                             |
| Table 2-7 | . Order of Precedence of Operators 2-24               |
| Table 2-8 | . Types of Relocation Attributes 2-43                 |
| Table 2-9 | . Combinations of Operators and Terms by Relocation   |
|           | Attribute 2-44                                        |

| able  | 2-10. | Combinations of Operators and Terms by         |      |
|-------|-------|------------------------------------------------|------|
|       |       | Relocation Attribute (External Reference Term) | 2-45 |
| able  | 2-11. | Types of Symbol Attributes                     | 2-46 |
| 'able | 2-12. | Combinations of Operators and Terms by Symbol  | 2-47 |
| 'able | 2-13. | Conditions for Size of Operand Value           | 2-50 |
| 'able | 2-14. | Conditions for Address Range of Operand Value  | 2-51 |
| 'able | 2-15. | Operand Attributes of Instructions             | 2-53 |
| Table | 3-1.  | List of Directives                             | 3-1  |
| Table | 3-2.  | Segment Definition Methods and Memory Address  |      |
|       |       | Allocation                                     | 3-3  |
| Table | 3-3.  | Functions of Relocation Attributes             | 3-6  |
| Table | 3-4.  | Uses of Relocation Attributes                  | 3-6  |
| Table | 3-5.  | Default Segment Names of Code Segments         | 3-7  |
| Table | 3-6.  | Representation Formats of Operands             |      |
|       |       | Indicating Bit Values                          | 3-28 |
| Table | 3-7.  | Bit Address Map                                | 3-33 |
| Table | 3-8.  | Bit Value That Can Be Described as Operand     |      |
|       |       | of EXTBIT                                      | 3-59 |
| Table | 3-9.  | Optimization Conditions of BR Directive        | 3-59 |
| Table | 4-1.  | List of Control Instructions                   | 4–1  |



1.1 Assembler Overview

The RA78K/I Assembler Package is a series of programs designed to translate a source program coded in the assembly language of the uCOM-78K/I series microprocessors, into machine language coding.

The assembler package contains three programs: Assembler, Linker, and Locater.





#### 1.1.1 What is an assembler?

(1) Assembly language and machine language An assembly language is the most fundamental programming

language for microprocessors.

To have a microprocessor do its job, programs and data are required. These programs and data must be written by a human being (i.e., a programmer) and stored in the memory section of a microcomputer. Programs and data that can be handled by the microcomputer is nothing but a set or combinations of binary numbers which is called machine language (i.e., the language that can be understood or interpreted by the computer). To create a program in machine language coding, namely, by a set of binary numbers is not an easy job for a human being, because it's difficult for him or her to remember the coding and he or she is likely to make errors in coding. For this reason, there is a method of creating a program using an abbreviated symbol (or mnemonic symbol) which represents the meaning of a machine language instruction to assist the human memory. A programming language system by this symbolic coding is called an assembly language.

To translate a program created in the assembly language into a set of binary numbers that can be understood by the microprocessor, another program is required. This program is called an assembler.



Fig. 1-2. Flow of Assembler

(2) Development of microcomputer-applied products and role of this package

Fig. 1-3 illustrates the standing of the programming in assembly language in the development process of microcomputer-applied product.



Fig. 1-3 Development Process of Microcomputer-applied Product



The software development process will be further detailed in Fig. 1-4 on the next page.

Phase-out/Discontinued

#### Fig. 1-4. Software Development Process



The assembly phase in the software development process will be reviewed in further detail by giving an example of this package.





#### 1.1.2 What is a relocatable assembler?

The machine language translated from a source language by the assembler will be stored in the memory of the microcomputer before use. In this case, in which memory location each machine language instruction will be stored must have been determined. Therefore, information on "the allocation of each machine language instruction to a specific address in memory" will be added to the machine language converted by the assembler.

Phase-out/Discontinued

Depending on the method of allocating addresses to machine language instructions, an assembler can be broadly divided into an absolute assembler and a relocatable assembler.

o Absolute assembler

Allocates the machine language instructions converted in one-time assembly operation to absolute addresses.

o Relocatable assembler

Addresses determined for the machine language instructions converted in one-time assembly operation are tentative. Absolute addresses will be determined by a program called the locater.

In the past, when a program was created with the absolute assembler, programmers had to, as a rule, complete programming at a time. However, if you create a large program at a time, the program becomes complicated, making analysis and maintenance of the program troublesome. To avoid this, such a large program is developed by dividing it into several subprograms (i.e., modules) for each functional unit. This programming technique is called the modular programming.

The relocatable assembler is an assembler suitable for modular programming. The following advantages can be derived from modular programming with the relocatable assembler:

(1) Increase in development efficiency

It's difficult to write a large program at a time. In such a case, divide the program into modules for each function and the program can be developed with two or more programmers engaged in writing subprograms at the same time. This will certainly increase development efficiency of the program.

If any bugs are found in the program, you do not need to re-assemble the entire program just to correct part of the program. Only the subprogram (module) requiring correction(s) can be re-assembled. This will help shorten the debugging time.



#### Fig. 1-6. Re-assembly for Debugging

(2) Utilization of resources

Highly reliable, highly versatile modules which have been previously created can be utilized for creation of another program. If you accumulate such high-versatility modules as software resources, you can save time and labor in developing a new program.

Fig. 1-7. Program Development Utilizing Existing Modules



1.2 Functional Outline of Assembler Package An ordinary program development procedure with this assembler package is illustrated in Fig. 1-8. The development of a program is basically performed by using the assembler, linker, and locater.

Phase-out/Discontinued

In the following discussions, the assembler, linker, and locater programs are collectively referred to as "the assembler package or this package" and the assembler program, as "the assembler".

Fig. 1-8. Program Development Procedure with This Package



1.2.1 Creation of source module file with editor Devide one program functionally into several modules. Each module becomes the unit of coding as well as the unit of input to the assembler. A module serving as the unit of input to the assembler is called a source module. After coding each source module, the source module is written into a file with the editor. The file thus created is called a source module file.

The source module file becomes an input file to the assembler (RA78K1).



Fig. 1-9. Creation of Source Module File

#### 1.2.2 Assembler

The assembler accepts source module files as input files and translates assembly language into machine language. If any coding error is found in the input source module, the assembler outputs an assembly error. If no assembly error is found, the assembler outputs an object module file which contains machine language information and relocation information relating to the allocation address of each machine language instruction. The assembler also outputs information at assembly time as an assembly list file.





Assembly list file

1.2.3 Linker

The linker accepts two or more object module files output by the assembler or link module file output by the linker itself as input files and gathers them for output as a single link module file. The linker also outputs information at link time as a link list file.

Phase-out/Discontinued





#### 1.2.4 Locater

The locater accepts the object module file output by the assembler or the link module file output by the linker as an input file and determines the addresses to be allocated to machine language instructions and outputs the result of the locate operation as a HEX-format object module file.

Phase-out/Discontinued

The locater also outputs the symbol information required in symbolic debugging with an in-circuit emulator as a symbol table file and the allocation address information at locate time as a locate list file.

Fig. 1-12. Functions of Locater



The processing of this package terminates when the processes up to the locater have been completed normally.



1.3 Reminders Before Program Development

Before you set your hand to the development of a program, keep in mind the following points:

1.3.1 Size of source module file

The size of a source module file that can be input to the assembler is limited to one of the following values depending on the operating (or execution) environment of the assembler.

Table 1-1. Size of Source Module File

| Host machine      | OS              | Size of source module   |
|-------------------|-----------------|-------------------------|
|                   |                 | file that can be input  |
| MD-086/116 series | Concurrent CP/M | 64K bytes max.          |
| PC-9800 series    | MS-DOS          | 64K bytes max.          |
|                   | CP/M-86         |                         |
| VAX-11 series     | VMS             | Approx. 850K bytes max. |

With a source module file having a size of 64K bytes, assuming that each line of the source module consists of an average of 30 characters, a program of up to about 2K steps can be assembled as a single source module file.

1.3.2 Number of files than can be input to Linker The number of object module files and/or link module files that can be input to the linker is 100.

1.3.3 Restriction on number of symbols The number of local symbols and that of PUBLIC symbols, which can be defined in the assembler, linker, and locater, respectively, are restricted as shown in the table below.

|           | Number of symbols      |                       |
|-----------|------------------------|-----------------------|
|           | No. of local symbols   | No. of PUBLIC symbols |
| Assembler | Approx. 1,800          | 256                   |
| Linker    | 1,800 x No. of modules | Approx. 2,000         |
| Locater   | 1,800 x No. of modules | Approx. 2,000         |

- NOTE: If any PUBLIC symbols have been defined, the number of local symbols that can be defined in the assembler must be reduced to the following value:
  - No. of local symbols that can be used in Assembler = Approx. 1,800 - No. of PUBLIC symbols defined

1.3.4 Maximum performance characteristics of assembler package The maximum performance characteristics of the assembler package that should be kept in your mind before program development are listed in the following tables.

(1) Maximum performance characteristics of Assembler

| Item                          | Restriction    |
|-------------------------------|----------------|
| Symbol length                 | 6 characters   |
| No. of characters per line    | 99 characters  |
| No. of code segments per type | 1 segment      |
| No. of absolute segments      | 10 segments    |
| No. of macrodefinitions       | 10 definitions |

(2) Maximum performance characteristics of Linker

| Item                           | Restriction  |
|--------------------------------|--------------|
| No. of input module files      | 100 files    |
| No. of different segment names | 255 names    |
| No. of absolute segments       | 100 segments |

(3) Maximum performance characteristics of Locater

| Item                        | Restriction  |  |  |
|-----------------------------|--------------|--|--|
| No. of relocatable segments | 256 segments |  |  |
| in the input module         | 1            |  |  |

1.4 Features of Assembler Package

This package has the following features:

(1) Macro function

When the same group of instructions must be described in a source program over and over again, a macro can be defined by giving a single macro name to the group of instructions. By using this macro function, coding efficiency and readability of the program can be increased.

- (2) Optimize function of branch instructions The assembler package has an assembler directive to automatically select a branch instruction (i.e., BR directive). To create a program with high memory efficiency, a 2-byte branch instruction must be described according to the branch destination range of the branch instruction. However, it is troublesome for the programmer to describe a branch instruction by paying attention to the branch destination range for each branching. If the BR directive is described, the assembler generates the appropriate branch instruction according to the branch destination range. This is called the optimize function of branch instructions.
- (3) Conditional assembly function With this function, part of a source program can be specified for assembly or non-assembly according to a predetermined condition. If a debug statement is described in a source program, whether or not the debug statement should be translated into machine language can be selected by setting a switch for conditional assembly. When the debug statement is no longer required, the source program can be assembled without major modifications to the program.

CHAPTER 2. HOW TO DESCRIBE SOURCE PROGRAMS

2.1 Basic Configuration of Source Program
When a source program is described by dividing it into several modules, each module which becomes the unit of input to the assembler is called a source module. (If a source program consists of only one module, the source program means the same as the source module.)
Each source module which becomes the unit of input to the assembler consists mainly of the following three parts:
(1) Module header
(2) Module body

(3) Module tail

Fig. 2-1. Configuration of Source Module

| Module header |  |  |  |  |  |
|---------------|--|--|--|--|--|
| Mođule body   |  |  |  |  |  |
| Module tail   |  |  |  |  |  |

.

#### 2.1.1 Module header

In the module header, five different items can be described as shown in Table 2-1 below.

| Table A | z=1, items inat | Call be Described in Mouure | neudor                                 |  |
|---------|-----------------|-----------------------------|----------------------------------------|--|
| Item    | Item that can   | Explanation                 | Chapter/section                        |  |
| No.     | be described    |                             | in this manual                         |  |
| 1       | Assembler       | Assembler option(s) which   | See 4, "Control                        |  |
|         | options         | are normally specified in   | Instructions".                         |  |
|         |                 | the start-up command line   |                                        |  |
|         |                 | of the assembler can be     | ,                                      |  |
|         |                 | described before NAME       |                                        |  |
|         |                 | directive in the module     |                                        |  |
|         |                 | header.                     |                                        |  |
| 2       | NAME directive  | This directive can be       | See 3.5, "Linkage                      |  |
|         |                 | described only in the       | directives".                           |  |
|         |                 | module header and must      |                                        |  |
|         |                 | always be described.        | ······································ |  |
| 3       | PUBLIC, EXTRN,  | These directives can be     | See 3.5, "Linkage                      |  |
| 1       | or EXBIT        | described only in the       | directives."                           |  |
|         | directive       | module header.              |                                        |  |
| 4       | EQU or SET      | These directives can be     | See 3.3, "Symbol                       |  |
| į       | directive       | described after PUBLIC,     | definition                             |  |
|         |                 | EXTRN, or EXBIT direc-      | directives."                           |  |
|         |                 | tive in the module          |                                        |  |
|         |                 | header.                     |                                        |  |
| 5       | Control         | Control instructions        | See 4, "Control                        |  |
|         | instructions    | can be described after      | Instructions."                         |  |
|         |                 | NAME directive in the       |                                        |  |
|         |                 | module header.              |                                        |  |

| Table 2-1. | Items | That | Can | Be | Described | in | Module | Header_ |
|------------|-------|------|-----|----|-----------|----|--------|---------|
|            |       |      |     |    |           |    |        |         |

NOTE: These items must be described in the module header in the order of item numbers. (Namely, assembler option(s) (Item No. 1) must be described before the NAME directive (Item No. 2). Comment(s) can be described anywhere after the assembler option(s) in the module header and control instruction(s) can be described after the NAME directive in the module header.

2.1.2 Module body
In the module body, the following items cannot be described:

o Assembler options
o NAME directive
o PUBLIC, EXTRN, and EXTBIT directives

All other directives, control instructions, and uCOM-78K/I
instructions can be described in the module body.
The module body must be described by dividing it into units each
called a segment.
The user may define the following four segments with a directive
corresponding to each segment:
(1) Code segment ...... Must be defined with the CSEG directive.
(2) Data segment ...... Must be defined with the BSEG directive.

(4) Absolute segment ... Must be defined with the ORG directive.

The module body may be configured with any segment combinations, provided a data segment and a bit segment must be defined before a code segment.

#### 2.1.3 Module tail

The module tail indicates the end of the source module. The END directive must be described in this part.



2.1.4 Overall configuration of source program The overall configuration of a source module becomes as shown below.

Fig. 2-2. Overall Configuration of Source Program

|     | Assembler option(s)<br>NAME directive<br>EQU and SET directives<br>PUBLIC, EXTRN, and EXTBIT<br>directives<br>Control instruction(s) | Module header |
|-----|--------------------------------------------------------------------------------------------------------------------------------------|---------------|
|     | Directives (other than<br>NAME, PUBLIC, EXTRN, EXTBIT)<br>Control instruction(s)<br>Instruction(s)                                   | Module body   |
|     | END directive                                                                                                                        | Module tail   |
| 000 |                                                                                                                                      |               |

NOTE: \_\_\_\_\_\_ indicates that the directive must always be described.

Examples of simple source module configurations are shown in Fig. 2-3 on the next page.

Fig. 2-3. Examples of Source Module Configurations



2.1.5 Description example of source program

In this subsection, a description example of a uCOM-78K/I source program is shown, in the hope that you can have a general idea of how to describe a source module. (This example is attached to the package product as a sample program file.)

The configuration of the sample program can be illustrated simply as follows:

Fig. 2-4. Configuration of Sample Program

<Module name: SAMPM>

.



This sample program was created by dividing a single source program into two modules. The module "SAMPM" is a main routine of this program and the module "SAMPS", a subroutine which is to be called within the main routine.

<Main routine>

| \$     | PROCESS     | OR(112)                  | :(1)                                    |               |
|--------|-------------|--------------------------|-----------------------------------------|---------------|
|        | NAME        | SAMPM                    | :(2)                                    |               |
| ;***** | *******     | ******                   |                                         |               |
| :*     |             |                          | *                                       |               |
| ;*     | HEX ->      | ASCII Conversion Program | *                                       |               |
| :*     |             |                          | * · · · · · · · · · · · · · · · · · · · | Module header |
| :*     |             | main-routine             | *                                       |               |
| 1#     |             |                          | · •                                     |               |
| ;***** | ******      | ********                 | ********                                |               |
|        |             | MAIN, START              | :(3)                                    | <u>}</u>      |
|        | EXTRN       | CONVAH                   | :(4)                                    |               |
|        | EVINA       | CONTROL 1                |                                         |               |
|        | DSEG        |                          | ;(5)                                    |               |
|        | ORG         | OFE40H                   |                                         |               |
| HDTSA: |             | 1                        |                                         |               |
| STASC: |             | 2                        |                                         |               |
|        |             |                          |                                         |               |
|        | CSEG        |                          | ;(6)                                    |               |
|        | ORG         | он                       | :(7)                                    |               |
| MAIN:  | DW          | START                    |                                         |               |
|        |             |                          |                                         |               |
|        | CSEG        |                          | :(8)                                    |               |
| START  | MOY         | SP, #0E0H                |                                         |               |
|        | - MOA       | MM, #00                  |                                         |               |
|        | MOA         | STBC, #00                |                                         |               |
|        |             |                          |                                         | Module body   |
|        | MOA         | HDTSA, #1AH              | test bey Drends data in Mi real-tar     |               |
|        | MOAM        | HL, #HDTSA               | ;set hex 2-code data in HL registor     |               |
|        | <b>a</b> 11 | 1000001010               | :convert ASCII <- HEX                   |               |
|        | CALL        | ICONVAH                  | :output BC-register <- ASCII code       |               |
|        | MOVW        | HL, #STASC               | set HL <- store ASC11 code table        |               |
|        | MOYH        | A, B                     |                                         |               |
|        | MOY         | (HL), A                  |                                         |               |
|        | INC         | L                        |                                         |               |
|        | MOV         | Ă,C                      |                                         |               |
|        | MOV         | (HL), A                  | · · · ·                                 |               |
|        | BR          | \$\$                     |                                         |               |
|        |             |                          |                                         |               |

- (1) Assembler option
- (2) Declaration of a module name
- (3) Declaration of a symbol referenced from another module as an external definition symbol
- (4) Declaration of a symbol defined in another module as an external reference symbol
- (5) Declaration of the start of a data segment(6) Declaration of the start of a code segment
- (7) Declaration of the start of an absolute segment from address OH
- (8) Declaration of the start of the code segment (meaning the end of the absolute segment)
- (9) Declaration of the end of the module

<Subroutine>



(10) Assembler option

- (11) Declaration of a module name
- (12) Declaration of a symbol referenced from another module as an external definition symbol
- (13) Declaration of the start of a code segment
- (14) Declaration of the end of the module

2.2 Description Format of Source Program

2.2.1 Configuration of statement

A source program consists of statements.

Each statement consists of the four fields shown in Fig. 2-5.

Fig. 2-5. Fields That Make Up A Statement



 The Symbol field and the Mnemonic field must be separated from each other with a colon (:) or one or more blank (or TAB) characters.

(2) The Mnemonic field and the Operand field must be separated from each other with one or more blank (or TAB) characters. Depending on the instruction described in the Mnemonic field, the Operand field may not be required.

③ The Comment field if used must be preceded with a semicolon (;).

A statement must be described within a line. (A line must be terminated with a LF (OAH) code.) Up to 99 characters can be described per line.

The following lines may also be described:

- o Dummy line ( a line without statement description)
- o Line consisting of the Symbol field alone
- o Line consisting of the Comment field alone

# 2.2.2 Character Set

Use the following alphabetic, numeric, and special characters to describe statements.

(1) Alphabetic characters

A B C D E F G H I J K L M N O P Q R S T U V W X Y Z a b c d e f g h i j k l m n o p q r s t u v w x y z

\_\_\_ NOTE 2-1

When any lowercase letter is used in a symbol or reserved word description, the lowercase letter is interpreted as its uppercase equivalent.

(2) Numeric characters

| Character                             | Name             | Main use                           |  |  |
|---------------------------------------|------------------|------------------------------------|--|--|
| ?                                     | Question mark    | Symbol equivalent to alphabetic    |  |  |
|                                       |                  | characters                         |  |  |
| @ Unit price                          |                  | Symbol equivalent to alphabetic    |  |  |
|                                       | symbol           | characters                         |  |  |
| _                                     | Underscore       | Symbol equivalent to alphabetic    |  |  |
| _                                     |                  | characters                         |  |  |
| Blank                                 |                  | Delimiter of each field            |  |  |
| НТ (09Н)                              | TAB code         | Character equivalent to Blank      |  |  |
| ,                                     | Comma            | Delimiter between the 1st and 2nd  |  |  |
|                                       | · .              | operands                           |  |  |
| #<br>*                                | Colon            | Delimiter between the Symbol and   |  |  |
|                                       | 1                | Mnemonic fields                    |  |  |
| ; Semicolon                           |                  | Symbol indicating the start of     |  |  |
|                                       |                  | the Comment field                  |  |  |
| CR (0DH)                              | Carriage return  | Symbol indicating the end of a     |  |  |
|                                       | code             | line                               |  |  |
| LF (OAH)                              | Line feed code   | Same as above                      |  |  |
| +                                     | Plus sign        | ADD operator or positive sign      |  |  |
| -                                     | Minus sign       | SUBTRACT operator or negative sign |  |  |
| *                                     | Asterisk         | MULTIPLY operator                  |  |  |
| 1                                     | Slash            | DIVIDE operator                    |  |  |
| •                                     | Period           | BIT operator                       |  |  |
| ( ) Left and right Symbols            |                  | Symbols specifying the order of    |  |  |
|                                       | parentheses      | arithmetic operations to be        |  |  |
| · · · · · · · · · · · · · · · · · · · |                  | performed                          |  |  |
| 1                                     | Single quotation | Symbol indicating the start or     |  |  |
| Ĺ                                     | mark             | end of a character constant        |  |  |

.

| Character | Name                 | Main use                                                        |  |  |
|-----------|----------------------|-----------------------------------------------------------------|--|--|
| \$        | Dollar sign          | o Symbol indicating the location counter                        |  |  |
|           |                      | o Symbol indicating the start of<br>an assembler option         |  |  |
|           |                      | o Symbol specifying a relative<br>addressing mode               |  |  |
| #         | Sharp sign           | Symbol specifying an immediate addressing mode                  |  |  |
| 1         | Exclamation<br>point | o Symbol specifying an absolute<br>addressing mode              |  |  |
|           |                      | o Symbol specifying the operand<br>representation format addr16 |  |  |
|           |                      | of a MOV instruction                                            |  |  |
|           | Braces               | o Symbol specifying an indirect<br>addressing mode              |  |  |

# 2.2.3 Fields of Statement

The respective fields that make up a statement are detailed in this subsection.

(1) Symbol field



A symbol is described in the Symbol field. The term "symbol" refers to a name given to a numerical data or address. By using symbols, the contents of a source program can be understood more easily.

The types and attributes of symbols and the conventions of symbol description are explained below.

,

[Symbol types]

Symbols are available in the types shown in Table 2-2, depending on their use and method of definition.

Table 2-2. Symbol Types

| 1            |                                       |                             |
|--------------|---------------------------------------|-----------------------------|
| Symbol type  | Use                                   | Method of definition        |
| Name         | Used as a numerical data              | This type is described      |
|              | in a source program.                  | in the Symbol field of      |
|              |                                       | the EQU, SET, or DBIT       |
|              |                                       | directive, or in the        |
|              |                                       | Operand field of the        |
|              |                                       | EXTBIT directive.           |
| Label        | Used as an address data               | This type is described      |
|              | in a source program.                  | in the Symbol field of      |
|              |                                       | an instruction or the       |
|              |                                       | DB, DW, or DS directive.    |
|              |                                       | <u>A colon (:) must be</u>  |
|              |                                       | <u>used as a delimiter.</u> |
|              |                                       | This type is also           |
|              |                                       | described in the Operand    |
|              |                                       | field of the EXTRN          |
|              |                                       | directive.                  |
| Segment name | Used as a segment name                | This type is described      |
|              | subject to operation                  | in the Symbol field of      |
|              | in a locater option                   | the CSEG, DSEG, BSEG,       |
|              | · · · · · · · · · · · · · · · · · · · | or ORG directive.           |
| Module name  | Used as a module name                 | This type is described      |
|              | in symbolic debugging                 | in the Operand field        |
| <u></u>      |                                       | of the NAME directive.      |
| Macro name   | Used as a macro name                  | This type is described      |
|              | for macro reference in                | in the Symbol field of      |
|              | a source program.                     | the MACRO directive.        |

[Conventions of symbol description]

All symbols must be described according to the following rules:

Phase-out/Discontinued

- A symbol must be made up of alphanumeric characters and special characters (?, @, and \_) that can be used as a symbol in a manner equivalent to alphabetic characters. The first character of the symbol must always be one of the alphabetic characters or special characters (?, @, and ).
- ② A symbol must be made up of not more than six characters. If a symbol consisting of seven or more characters is described, an error will result.
- ③ No reserved word can be used as a symbol. Reserved words are indicated in Appendix A, List of Reserved Words.
- (4) The same symbol cannot be described two or more times (provided that the name defined with the SET directive can be re-defined with the SET directive).
- (5) Lowercase letters described as a symbol will be interpreted as their uppercase equivalents.
- 6 When describing a label in the Symbol field, separate the Symbol field from the Mnemonic field with a delimiter ":".

(Example of correct symbol descriptions)

| TEN   | EQU   | 10н           | ; | "TEN" is a name.           |
|-------|-------|---------------|---|----------------------------|
| NEXT: | BR    | <b>!</b> 100H | ; | "NEXT" is a label.         |
| C1    | CSEG  |               | ; | "C1" is a segment name.    |
|       | NAME  | SAMPLE        | ; | "SAMPLE" is a module name. |
| MAC1  | MACRO |               | ; | "MAC1" is a macro name.    |

(Example of incorrect symbol descriptions)

| SEVENTY | EQU | 70H   | ; "SEVENTY" is a name.               |
|---------|-----|-------|--------------------------------------|
| 1ST:    | MOV | A,#0H | ; No numeric character can be used   |
|         |     |       | as the 1st character of a symbol.    |
| NEXT    | BR  | 1100н | ; "NEXT" is a label and must be      |
|         |     |       | separated from Mnemonic field        |
|         |     |       | with a colon (:)                     |
| TEN     | EQU | 10н   | ; "TEN" and "ten" are the same named |
| ten     | EQU | 20H   | symbols. Description of "ten" will   |
|         |     |       | thus result in an error.             |

[Symbol attributes] Names and labels each have a value and an attribute. Segment names, module names, and macro names have no value. A value refers to the value of a defined numerical data or address data itself. The attribute of a symbol is called a symbol attribute and must be one of the types indicated in Table 2-3.

Phase-out/Discontinued

| Table 2 | 2-3. | Types | of | Symbol | Attributes |
|---------|------|-------|----|--------|------------|
|---------|------|-------|----|--------|------------|

| Attribute type | Classification                              |  |  |  |
|----------------|---------------------------------------------|--|--|--|
| NUMBER         | o Names defined with EQU and SET directives |  |  |  |
|                | (provided that labels, bit values, and      |  |  |  |
|                | symbols having a bit value defined with     |  |  |  |
|                | the directives are excluded.)               |  |  |  |
| ADDRESS        | o Symbols defined as labels                 |  |  |  |
|                | o Names defined as labels with EQU and SET  |  |  |  |
|                | directives                                  |  |  |  |
| BIT            | o Names defined as bit values with EQU and  |  |  |  |
|                | SET directives                              |  |  |  |
| <u></u>        | o Names defined with DBIT directive         |  |  |  |

(Examples)

| TEN    | EQU        | 10н           | ; | Name "TEN" has attribute NUMBER<br>and value 10H.  |
|--------|------------|---------------|---|----------------------------------------------------|
| START: | ORG<br>MOV | 80H<br>A,#10H | ; | Label "START" has attribute                        |
| BIT1   | EQU        | OFE20H. 0     | ; | Name "BIT1" has attribute BIT and value OFE20H. 0. |

(2) Mnemonic field



```
Phase-out/Discontinued
   In the Mnemonic field, a mnemonic instruction or directive is
   described.
   With an instruction or directive requiring an operand or
   operands, the Mnemonic field must be separated from the
   Operand field with one or more Blank or TAB characters.
(Example of correct descriptions)
     MOV
           A, #0H
     CALL
           !CONVAH
     RET
(Example of incorrect descriptions)
     MOVA, #0H
                      ; No blank exists between Mnemonic and
                        Operand fields.
     CAL L !CONVAH
                      ; A blank exists in Mnemonic field.
     HLT
                      ; uCOM78/I has no such instruction as
                        "HLT".
```

(3) Operand field



In the Operand field, the data (operands) required for the instruction or directive described in the Mnemonic field must be described. Depending on the instruction or directive, no operand can be described in the Operand field or two or more operands must be described in the Operand field. When describing two or more operands, delimit each operand with a comma (,). The following five types of data can be described in the Operand field: o Constants (numeric constant and character constant) o Register names o Special characters (\$, #, !, and [ ]) o Names and labels o Expressions The size and attribute of the required operand may be different depending on the instruction or directive. Refer to Section 2.4, "Characteristics of Operands" for the sizes and attributes of operands.

See APPENDIX C, "uCOM-78K/I Instruction Set" for the operand representation formats and description methods in the uCOM-78K/I instruction set.

Each of these five types of data that can be described in the Operand field is detailed below.

#### [Constants]

A constant is a fixed value or data item and is also referred to as an immediate data.

Constants are divided into numeric constants and character constants.

o Numeric constants

A binary, octal, decimal, or hexadecimal number can be described as a numeric constant. The method of representing each numeric constant type is shown in Table 2-4 below.



Table 2-4. Methods of Representing Numeric Constant Types

| Constant type    | Method of representation         | Example |
|------------------|----------------------------------|---------|
| Binary constant  | Character "B" is suffixed to a   | 1101B   |
| (Binary number)  | string of binary characters      |         |
|                  | (value).                         |         |
| Octal constant   | Character "O" is suffixed to a   | 740     |
| (Octal number)   | string of octal characters       |         |
|                  | (value).                         |         |
| Decimal constant | A string of decimal characters   | 128     |
| (Decimal number) | (value) is described with or     | 128D    |
|                  | without suffixing character "D"  |         |
|                  | to the string.                   |         |
| Hexadecimal      | Character "H" is suffixed to a   | 8 CH    |
| constant         | string of hexadecimal characters | 0A6H    |
| (Hexadecial      | (value). If the first character  |         |
| number)          | of the constant begins with one  |         |
|                  | of the characters "A through F", |         |
|                  | "0" must be prefixed to the      |         |
|                  | constant.                        |         |

o Character constants

```
A character constant is expressed by enclosing a character
or a string of characters shown in 2.2.2, "Character set"
with a pair of single quotation marks.
As a result of an assembly process, the character or
characters are converted into 7-bit ASCII code with the
parity bit (MSB) set as "0".
To use a single quotation mark as it is originally intended,
the single quotation mark must be input twice in succession.
  Examples:
     'A'
     1 1
                ; Represents a single blank.
     1111
                ; Represents a pair of single quotation
                  marks.
     'main'
```

[Register names]
The following registers can be described in the Operand
field.
o General-purpose registers
o General-purpose register pairs
o Special function registers

General-purpose registers and general-purpose register pairs include those which can be described with their absolute names (R0 to R7 and RP1 to RP3), as well as with their function names (X, A, B, C, D, E, H, L,, AX, BC, DE, and HL). A register name that can be described in the Operand field may be different depending on the type of instruction. See APPENDIX C.1, "Instruction Set and Its Operation" for details of the method of describing each register.

[Special characters]

Special characters that can be described in the Operand field are shown in Table 2-5.

• • •

Table 2-5. Special Characters That Can Be Described in

| Operand           | T TETU                                                                          |
|-------------------|---------------------------------------------------------------------------------|
| Special character | Function                                                                        |
| \$                | o Indicates the location address of the instruction having this operand (or the |
|                   | 1st byte of the address with a multiple-                                        |
|                   | byte instruction).                                                              |
|                   | o Indicates a relative addressing mode for                                      |
|                   | a Branch instruction.                                                           |
| 1                 | o Indicates an absolute addressing mode                                         |
|                   | for a Branch or Call instruction.                                               |
|                   | o Indicates the specification of addr16                                         |
|                   | which allows all memory space to be                                             |
|                   | specified for a MOV instruction.                                                |
| #                 | Indicates an immediate data.                                                    |
|                   | Indicates an indirect addressing mode.                                          |

(Application examples of special characters)

| Address | Source | program    |   |
|---------|--------|------------|---|
| 100     | LOOP:  | INC A      |   |
| 101     |        | BNZ \$\$-1 | 1 |

In (1) above, the first "\$" in the Operand field indicates the relative addressing of the conditional branch instruction BNZ. The second "\$" indicates the location address 101 to which the first byte of the object code for the instruction "BNZ \$\$-1" is to be assigned. The description in (1) can be substituted with "BNZ \$LOOP".

Source program

| BR !100H      | ; "!" indicates the absolute address- |
|---------------|---------------------------------------|
|               | ing of BR (unconditional branch)      |
|               | instruction.                          |
| MOV A, !2000H | ; "!" indicates addr16 specification  |
|               | of MOV instruction                    |
| SUB A, #10H   | ; "#" indicates an immediate data.    |

2-20

TEN EQU 10H SUB A, #TEN ; "#" indicates an immediate data. ; "[ ]" indicate an indirect AND A, [HL] addressing mode. [Names and labels] If a name or label is described in the Operand field, the value of the name or label becomes a numerical data subject to operation by the instruction or directive described in the Mnemonic field. (Application example of name) TEN EOU 10H MOV A, #TEN ; This description can be substituted with "MOV A, #10H". (Application example of label) ORG 100H LOOP: INC A BNZ \$LOOP ; This description can be substituted with "BNZ \$100H". [Expressions] In the Operand field, expressions can be described. An expression is a valid series of constants, \$ indicating a location address, names, or labels, that are connected with operators and can be used as an operand of an instruction. For the expressions and operators, see Section 2.3, "Expressions and Operators". (Example of expression description) TEN EQU 10H

MOV A, #TEN-5H

In this example, "#TEN-5H" is an expression. In this expression, name "TEN" and numeric constant "5H" are connected with the "-" (minus) operator. The value of the expression is OBH. Therefore, this description can be substituted with "MOV A, #OBH".

(4) Comment field



In the Comment field, any remarks to identify or explain a particular step or operation in a program may be described following the input of a semicolon (;). By describing comments in the Comment field, an easy-tounderstand source program can be created. The comments described in the Comment field are not subject to assembler operation (i.e., conversion into machine language) but are output as is on an assembly list.

# (Examples of comment descriptions)

\$ PROCESSOR(112) NAME SAMPS :\* \* :\* HEX -> ASC11 Conversion Program ٠ :\* ± Lines consisting of :\* sub-routine ۰ Comment field only :\* \* :\* input condition = (HL) <- hex 2 code</pre> \* 1\* :\* output condition : BC-register <-ASCI1 2 code \*</pre> ;\* \* PUBLIC CONVAH

|         | CSEG |         |                       |                                       |
|---------|------|---------|-----------------------|---------------------------------------|
| CONVAH: | MOY  | A (HL)  | :load hex code -> Acc |                                       |
|         | SHR  | A, 4    | thex upper code load  |                                       |
|         | CALL | ISASC   |                       |                                       |
|         | MOA  | 8, A    | store result          | Lines in which comments are described |
|         | MON  | A, THUT | :load hex code -> Acc | ale described                         |
|         | AND  | A, #OFH | thex lower code load  |                                       |
|         | CALL | ISASC   |                       |                                       |
|         | MOV  | C, A    | istore result         |                                       |
|         |      |         |                       |                                       |

RET

#### 2.3 Expressions and Operators

An expression is a valid series of constants, \$ indicating a location address, names, or labels connected with operators. Elements of an expression other than the operators are called terms and are referred to as the 1st term, 2nd term, and so forth from left to right, in their order of description. Operators are available in the types shown in Table 2-6, and their order of precedence in calculation has been predetermined as shown in Table 2-7.

A pair of parentheses (i.e., left and right parentheses) are used to change the order in which calculations are to be performed.

Example: MOV A, #5\*(SYM+1)

; ①

Phase-out/Discontinued

In (1) above, "5\*(SYM+1)" is an expression. "5" is the 1st term of the expression and "SYM" and "1" are the 2nd and 3rd terms, respectively. "\*, +, and ()" are operators.

| Table | 2-6. | Types | of | Operators |
|-------|------|-------|----|-----------|
|-------|------|-------|----|-----------|

| Type of operator          | Operators                       |
|---------------------------|---------------------------------|
| Arithmetic operators      | +, -, *, /, MOD, + sign, - sign |
| Logical operators         | OR, AND, NOT, XOR               |
| Relational operators      | EQ, NE, GT, GE, LT, LE          |
| Shift operators           | SHR, SHL                        |
| Byte-separating operators | HIGH, LOW                       |
| Bit operator              | . (Period)                      |
| Other operators           | ( )                             |

#### Table 2-7. Order of Precedence of Operators

| Priority |   | Operator                                |
|----------|---|-----------------------------------------|
| High     | 1 | HIGH, LOW                               |
|          | 2 | + sign, - sign, NOT                     |
|          | 3 | * (Multiply), / (Divide), MOD, SHR, SHL |
|          | 4 | + (Add), - (Subtract)                   |
|          | 5 | AND                                     |
|          | 6 | OR, XOR                                 |
|          | 7 | EQ, NE, GT, GE, LT, LE                  |
| Low      | 8 | . (Bit operator)                        |

Phase-out/Discontinued

Operations on expressions are performed according to the following rules:

- ① Operations are performed according to the order of precedence given to each operator. If two or more operators of the same order of precedence exists in an expression, the operation designated by the leftmost operator is first carried out.
- (2) An expression in parentheses is carried out before expressions outside the parentheses.
- ③ Each term in an operation is handled as an unsigned 16-bit data and the result of the operation is also handled as an unsigned 16-bit. (However, the result of the operation designated by the HIGH, LOW, EQ, NE, GT, LT, or LE operator will be handled as an 8-bit data.) Example: 65535 = 0FFFFH

-1 = -(0001H) = 0FFFFH

④ If an overflow occurs in an operation due to its result exceeding 16 bits, only the low-order 16 bits of the result become valid and thus an error will not result. Example: 65535 + 1 = (OFFFFH) + (0001H) = (10000H) → 0000H

2.3.1 Functions of operators

The functions of the respective operators are described in this subsection.

# (1) + (ADD) operator

# Function

Returns the sum of the value of the 1st term of an expression and the value of its 2nd term.

# Application Example

|        | ORG    | 100H       |       |   |
|--------|--------|------------|-------|---|
| START: | BR     | ! \$ + 6 H | ; (a) | j |
|        | :<br>: |            |       | i |

# Explanation

The BR instruction causes a jump to "current address + address 6", namely, to address "100H + 6H = 106H". Therefore, (a) in the above example can also be described as: START: BR !106H

(2) - (SUBTRACT) operator

# <u>Function</u>

Returns a difference between the value of the 1st term of an expression and the value of its 2nd term.

# Application Example

|   |      | ORG | 100H            |
|---|------|-----|-----------------|
| B | АСК: | BR  | ! ВАСК-3H ; (b) |
|   |      | i   |                 |

# Explanation

The BR instruction causes a jump to "address assigned to BACK - address 3", namely, to address "100H - 3H = 0FDH". Therefore, (b) in the above example can also be described as: BACK: BR !0FDH



(3) \* (MULTIPLY) operator

# Function

Returns the product of the value of the 1st term of an expression and the value of its 2nd term.

Application Example

```
TEN EQU 10H
MOV A. #TEN*3 ; (c)
:
```

## Explanation

With the EQU directive, value "10H" is defined in name "TEN". "#" indicates an immediate data. Expression "TEN\*3" is the same as "10\*3" and returns value 30H. Therefore, (c) in the above expression can also be described as: MOV A, #30H

(4) / (DIVIDE) operator

#### Function

Divides the value of the 1st term of an expression by the value of its 2nd term and returns the integer part of the result with its fractional part truncated. An error will result if the divisor is 0.

Application Example

MOV A, #256/50 ; (d)

#### Explanation

The result of division "256/50" is 5 with remainder 6. The \* operator returns value "5" which is the integer part of the result of the division. Therefore, (d) in the above example can also be described as:

# (5) + sign

# Function

Returns the value of the term of an expression as is.

Phase-out/Discontinued

.

# Application Example

FIVE EQU +5

# Explanation

The value "5" of the term is returned without change. With the EQU directive, value "5" is defined in name "FIVE".

# (6) - sign

# Function

Returns the value of the term of an expression by twos complement.

# Application Example

NO EQU -1

# Explanation

-1 becomes the twos complement of 1. The twos complement of binary 0000 0000 0000 0001 becomes: 1111 1111 1111 Therefore, with the EQU directive, value "OFFFFH" is defined in name "NO".

# (7) MOD (Remainder) operator

# Function

Obtains the remainder in the result of dividing the value of the 1st term of an expression by the value of its 2nd term. An error will result if the divisor (2nd term) is 0.

Phase-out/Discontinued

Application Example

MOV A, #256 MOD 50 ; (e)

Explanation

The result of division "256/50" is 5 with remainder 6. The MOD operator returns the remainder 6. Therefore, (e) in the above example can also be described as: MOV A, #6

#### (1) NOT operator

# Function

Negates the value of the term of an expression on a bit-by-bit basis and returns the result.

Phase-out/Discontinued

#### Application Example

MOVW AX, #NOT 3H ; (a)

# Explanation

NOT logical operation is performed on value 3H as follows: NOT) 0000 0000 0000 0011

1111 1111 1111 1100

The result becomes OFFFCH.

Therefore, (a) in the above example can also be described as: MOV AX, #0FFFCH

# (2) AND operator

#### Function

Performs an AND (logical sum) operation between the value of of the 1st term of an expression and the value of its 2nd term on a bit-by-bit basis and returns the result.

#### Application Example

MOV A, #110H AND OFFH ; (b)

#### **Explanation**

AND operation is performed between two values 110H and OFFH as follows: 0000 0001 0001 0000 <u>AND) 0000 0000 1111 1111</u> 0000 0000 0001 0000 The result becomes 10H. Therefore, (b) in the above example can also be described as: MOV A, #10H

#### (3) OR operator

#### Function

Performs an OR (logical product) operation between the value of the 1st term of an expression and the value of its 2nd term on a bit-by-bit basis and returns the result.

Phase-out/Discontinued

Application Example

MOV A, #0AH OR 1101B ; (c)

**Explanation** 

OR operation is performed between two values OAH and 1101B as follows:

0000 0000 0000 1010

OR) 0000 0000 0000 1101

0000 0000 0000 1111

The result becomes OFH.

Therefore, (c) in the above example can also be described as: MOV A, #0FH

(4) XOR operator

Function

Performs an Exclusive-OR operation between the value of the 1st term of an expression and the value of its 2nd term on a bit-by-bit basis and returns the result.

Application Example

MOV A. #9AH XOR 9DH ; (d)

Explanation

XOR operation is performed between two values 9AH and 9DH as follows:

0000 0000 1001 1010 XOR) 0000 0000 1001 1101

0000 0000 0000 0111

The result becomes 7H.

Therefore, (d) in the above example can also be described as: MOV A, #7H (1) EQ (Equal) operator <u>Function</u> Returns OFFH if the value of the 1st term of an expression is equal to the value of its 2nd term (i.e., true) and 00H if both values are not equal (i.e., false).

Phase-out/Discontinued

Application Example

A1 EQU 12C4H A2 EQU 12C0H MOV A. #A1 EQ (A2+4) ; (a) MOV X. #A1 EQ A2 ; (b)

# Explanation

In (a) above,

expression "A1 EQ (A2+-4)" becomes "12C4H EQ (12C0H+4)". The operator compares the value of the 1st term and that of the 2nd term and returns OFFH because the value of the 1st term is equal to the value of the 2nd term. In (b) above, expression "A1 EQ A2" becomes "12C4H EQ 12C0H". The operator compares the value of the 1st term and that of the 2nd term and returns 00H because the value of the 1st term is not equal to the value of the 2nd term.

2-32

# (2) NE (Not Equal) operator

#### Function

Returns OFFH if the value of the 1st term of an expression is not equal to the value of its 2nd term (i.e., true) and 00H if both values are equal (i.e., false).

Phase-out/Discontinued

Application Example

| A 1 | EQU | 5678H  |    |         |       |  |
|-----|-----|--------|----|---------|-------|--|
| A 2 | EQU | 5670H  |    |         |       |  |
|     | моч | A, #A1 | NE | A 2     | ; (c) |  |
|     | MOV | A, #A1 | NE | (A2+8H) | ; (d) |  |

#### **Explanation**

In (c) above,

expression "A1 NE A2" becomes "5678H NE 5670H". The operator compares the value of the 1st term and that of the 2nd term and returns 0FFH because the value of the 1st term is not equal to the value of the 2nd term. In (d) above,

expression "A1 NE (A2+8H)" becomes "5678H NE (5670H+8H)". The operator compares the value of the 1st term and that of the 2nd term and returns 00H because the value of the 1st term is equal to the value of the 2nd term.

# (3) GT (Greater-Than) operator

## Function

Returns OFFH if the value of the 1st term of an expression is greater than the value of its 2nd term (i.e., true) and 00H if the value of the 1st term is equal to or less than the value of the 2nd term (i.e., false).

1.

Phase-out/Discontinued

Application Example

| L A | EQU | 1023H     |          |       |   |  |
|-----|-----|-----------|----------|-------|---|--|
| A 2 | EQU | 1013H     |          |       |   |  |
|     |     |           |          |       | , |  |
|     | ΜΟν | A, #A1 G' | Г А2 ·   | ; (e) |   |  |
|     | MOV | X. #A1 G' | (A2+10H) | ; (1) |   |  |

Explanation

In (e) above,

expression "A1 GT A2" becomes "1023H GT 1013H". The operator compares the value of the 1st term and that of the 2nd term and returns OFFH because the value of the 1st term is greater than the value of the 2nd term. In (f) above, expression "A1 GT (A2+10H)" becomes "1023H GT (1013H+10H)". The operator compares the value of the 1st term and that of the 2nd term and returns 00H because the value of the

1st term is equal to the value of the 2nd term.

# (4) GE (Greater-than or Equal) operator

#### Function

Returns OFFH if the value of the 1st term of an expression is greater than or equal to the value of its 2nd term (i.e., true) and 00H if the value of the 1st term is less than the value of the 2nd term (i.e., false).

Phase-out/Discontinued

Application Example

A1 EQU 2037H A2 EQU 2015H MOV A. #A1 GE A2 ; (g) MOV X. #A1 GE (A2+23H) ; (h)

Explanation

In (g) above,

expression "A1 GE A2" becomes "2037H GE 2015H". The operator compares the value of the 1st term and that of the 2nd term and returns OFFH because the value of the 1st term is greater than the value of the 2nd term. In (h) above, expression "A1 GE (A2+23H)" becomes "2037H GE (2015H+23H)".

The operator compares the value of the 1st term and that of the 2nd term and returns 00H because the value of the 1st term is less than the value of the 2nd term.

#### (5) LT (Less-Than) operator

# Function

Returns OFFH if the value of the 1st term of an expression is less than the value of its 2nd term (i.e., true) and 00H if the value of the 1st term is equal to or greater than the value of the 2nd term (i.e., false).

Phase-out/Discontinued

Application Example

A1 EQU 1000H A2 EQU 1020H MOV A. #A1 LT A2 ;(i) MOV X. #(A1+20H) LT A2 ;(j)

Explanation

In (i) above, expression "A1 LT A2" becomes "1000H LT 1020H". The operator compares the value of the 1st term and that of the 2nd term and returns OFFH because the value of the 1st term is less than the value of the 2nd term. In (j) above, expression "(A1 + 20H) LT A2" becomes "(1000H + 20H) LT 1020H". The operator compares the value of the 1st term and that of the 2nd term and returns 00H because the value of the 1st term is equal to the value of the 2nd term.

#### (6) LE (Less-Than or Equal) operator

#### Function

Returns OFFH if the value of the 1st term of an expression is less than or equal to the value of its 2nd term (i.e., true) and 00H if the value of the 1st term is greater than the value of the 2nd term (i.e., false).

Phase-out/Discontinued

Application Example

A1 EQU 103AH A2 EQU 1040H MOV A, #AI LE A2 ; (k) MOV X, #(A1+7H) LE A2 ; (l)

**Explanation** 

In (k) above,

expression "A1 LE A2" becomes "103AH LE 1040H". The operator compares the value of the 1st term and that of the 2nd term and returns OFFH because the value of the 1st term is less than the value of the 2nd term. In (1) above, expression "(A1 + 7H) LE A2" becomes "(103AH + 7H) LE 1040H". The operator compares the value of the 1st term and that of the 2nd term and returns 00H because the value of the

1st term is greater than the value of the 2nd term.

| (1) | SHR (Shift Right) operator                                   |
|-----|--------------------------------------------------------------|
|     | Function                                                     |
|     | Returns a value obtained by shifting the value of the 1st    |
| •   | term of an expression to the right the number of bits        |
|     | specified by the value of the 2nd term. In this case, zeroes |
|     | equivalent to the specified number of bits shifted move in   |
|     | from the MSB side.                                           |
|     |                                                              |

Application Example

MOV A, #1AFH SHR 5 ; (a)

**Explanation** 

This operator shifts value "1AFH" to the right by 5 bits.



As the result of the Shift Right operation, value ODH is returned.

Therefore, (a) in the above example can also be described as: MOV A, #0DH

# (2) SHL (Shift Left) operator

#### Function

Returns a value obtained by shifting the value of the 1st term of an expression to the left the number of bits specified by the value of the 2nd term. In this case, zeroes equivalent to the specified number of bits shifted move in from the LSB side.

Phase-out/Discontinued

Application Example

MOV A, #11H SHL 3 ; (b)

## Explanation

, · .

This operator shifts value "11H" to the left by 3 bits.



As the result of the Shift Left operation, value 88H is returned.

Therefore, (b) in the above example can also be described as: MOV A, #88H

### (1) HIGH operator

Function

Returns the high-order 8-bit value of the term of an expression.

Phase-out/Discontinued

Application Example

```
ORG 1234H
START:
:
MOV A, #HIGH START ; (a)
```

# Explanation

Because label "START" has value 1234H, the HIGH operator returns the high-order 8 bits of the value, namely, 12H. Therefore, (a) in the above example can also be described as: MOV A, #12H

(2) LOW operator

Function

Returns the low-order 8-bit value of the term of an expression.

Application Example

```
ORG 5678H
WORK:
:
MOV A. #LOW WORK ; (b)
```

#### Explanation

Because label "WORK" has value 5678H, the LOW operator returns the low-order 8 bits of the value, namely, 78H. Therefore, (b) in the above example can also be described as: MOV A, #78H

#### Other Operators

(1) . (Bit position specification) <u>Function</u> Calculates a bit address from the value indicated by the 1st term of an expression and the bit position indicated by the 2nd term of the expression and returns the result.

Application Example

MOV CY, 0FE20H. 3

#### Explanation

This operator sets the value of the 3rd bit at address OFE20H in the Carry (CY) flag.

Assuming that data 2BH is stored at address OFE20H,

0FE20H 0 0 1 0 1 0 1 1

0 (i.e., the value of the 3rd bit) is set in the CY flag.

NOTE 2-2

- o The value of the 1st term of an expression must be within the range of OFE20H to OFFFFH.
- o The value of the 2nd term of the expression must be within the range of 0 to 7.

(2) ()

#### Function

Causes an operation in parentheses to be performed prior to operations outside the parentheses. This operator is used to change the order of precedence of

Phase-out/Discontinued

Application Example

other operators.

MOV A. #(4+3)\*2

Explanation

$$\underbrace{(4+3)}_{(2)} * 2$$

Calculations are performed in the order of expressions (1) and (2) and value 14 is returned as the result. If parentheses are not used as shown below,

calculations are performed in the order of expressions (1) and (2) and a different value 10 is returned as the result.

See Table 2-7 for the order of precedence of operators.

#### 2.3.2 Restrictions on Operations

The operation of an expression is performed by connecting terms with operator(s). Elements that can be described as terms include constants, \$, names, and labels. Each term has a relocation attribute and a symbol attribute.

Depending on the types of relocatable attribute and symbol attribute inherent in each term, operators that can work on the term are limited. Therefore, when describing an expression, it is important to pay attention to the relocation attribute and symbol attribute of each of the terms constituting the expression.

#### (1) Operators and relocation attributes

As previously mentioned, each of the terms which constitute an expression has a relocation attribute. Terms can be divided into three types when classified by their relocation attributes: Absolute term, Relocatable term, and External reference term.

Types of relocation attributes in operations, nature of each attribute, and terms applicable to each attribute are shown in Table 2-8.

| Туре        | Nature            | Applicable term              |
|-------------|-------------------|------------------------------|
| Absolute    | Term whose value  | o Constants                  |
| term        | is determined     | o Labels defined within an   |
|             | at assembly time  | absolute segment             |
|             |                   | o \$ indicating the location |
|             |                   | address defined within an    |
|             |                   | absolute segment             |
|             |                   | o Names defined the above    |
|             |                   | constants, labels, or \$     |
| Relocatable | Term whose value  | o Labels defined within a    |
| term        | is not determined | relocatable segment          |
|             | at assembly time  | o \$ indicating the location |
|             |                   | address defined within a     |
|             |                   | relocatable segment          |
|             |                   | o Names defining relocatable |
|             | <u> </u>          | labels                       |

Table 2-8. Types of Relocation Attributes

.

. .

Table 2-8. Types of Relocation Attributes (contd)

| Туре      | Nature            | Applicable term             |
|-----------|-------------------|-----------------------------|
| External  | Term which exter- | o Labels defined with EXTRN |
| reference | nally references  | directive                   |
| term      | the symbol of     | o Names defined with EXTBIT |
|           | another module    | directive                   |

Combinations of the type of operator and terms on which each operator can work are shown in Table 2-9.

Table 2-9. Combinations of Operators and Terms by Relocation

| Attribute            |          |        | ······································ |              |
|----------------------|----------|--------|----------------------------------------|--------------|
| Relocation attribute | X: ABS   | X: ABS | X: REL                                 | X: REL       |
| of term              | •        |        |                                        |              |
| Type of operator     | Y: ABS   | Y: REL | Y: ABS                                 | Y: REL       |
| X + Y                | A        | R      | <u> </u>                               |              |
| X - Y                | A        |        | R                                      | · <u>A</u> * |
| X * Y                | A        |        |                                        |              |
| х / ч                | <u>A</u> |        |                                        |              |
| X MOD Y              | <u>A</u> | -      |                                        |              |
| X SHL Y              | A        |        |                                        | - '          |
| X SHR Y              | <u>A</u> |        |                                        | -            |
| X EQ Y               | <u>A</u> |        |                                        | A*           |
| X LT Y               | A        |        |                                        | <u>A*</u>    |
| X LE Y               | A        |        |                                        | A*           |
| X GT Y               | A        |        |                                        | A*           |
| X GE Y               | А        | _      | -                                      | A*           |
| X NE Y               | А        |        |                                        | <u>A</u> *   |
| X AND Y              | A        | -      |                                        | -            |
| X OR Y               | A        | -      |                                        | -            |
| X XOR Y              | A        | _      |                                        |              |
| NOT X                | Α        | A      | -                                      | - ·          |
| + X                  | Α        | А.     | R                                      | R            |
| - X                  | A        | A      |                                        | _            |
| HIGH X               | A        | A      | R                                      | R            |
| LOW X                | A        | A      | R                                      | R            |
| Х. Ү                 | A        |        | R                                      |              |



<Legend> ABS: Absolute term

REL: Relocatable term

- A : The result of the operation becomes an absolute term.
- R : The result of the operation becomes an relocatable term.
- : The operation cannot be performed.
- \* The operation is allowed only between the symbols defined within the same segment.

The following four operators can work on external reference terms: +, HIGH, LOW, and . (Bit position specification). (However, note that only one external reference term can be described in an expression.)

Combinations of the type of operator and external reference terms on which each operator can work are shown in Table 2-10.

Table 2-10. Combinations of Operators and Terms by Relocation

| Relocation attribute<br>of term | X: ABS | X: EXT | X: REL | X: EXT   | X: EXT |
|---------------------------------|--------|--------|--------|----------|--------|
| Type of operator                | Y: EXT | Y: ABS | Y: EXT | Y: REL   | Y: EXT |
| X + Y                           | -      | E      | -      |          | _      |
| + X                             | A      | E      | R      | E        | E      |
| HIGH X                          | A      | E      | R      | <u> </u> | E      |
| LOW X                           | A      | E      | R      | E        | E      |
| х. у                            | Е      | Е      | -      | Е        | -      |

Attribute (External Reference Term)

<Legend> ABS: Absolute term

REL: Relocatable term

- EXT: External reference term
- A : The result of the operation becomes an absolute term.
- R : The result of the operation becomes an relocatable term.
- E : The result of the operation becomes an external reference term.

- : The operation cannot be performed.

· · · ·

(2) Operators and symbol attributes

As previously mentioned, each of the terms which constitute an expression has a symbol attribute in addition to a relocation attribute. Terms can be divided into three types when classified by their system attributes: NUMBER term, ADDRESS term, and BIT term.

Types of system attributes in operations and terms applicable to each attribute are shown in Table 2-11.

| Table | 2-11. | Types | of | Symbol | Attributes |
|-------|-------|-------|----|--------|------------|
|-------|-------|-------|----|--------|------------|

•

| Туре         | Applicable term                                 |
|--------------|-------------------------------------------------|
| NUMBER term  | o Names and labels which have NUMBER attribute  |
|              | o Constants                                     |
| ADDRESS term | o Names and labels which have ADDRESS attribute |
|              | o \$ indicating the location counter            |
| BIT term     | o Names which have BIT attribute                |

Combinations of the type of operator and terms on which each operator can work are shown in Table 2-12. Operations on BIT terms are possible only with unary operator "+ X".



| Table 2-12. Co | ombinations | of | Operators | and | Terms | by | Symbol |
|----------------|-------------|----|-----------|-----|-------|----|--------|
|----------------|-------------|----|-----------|-----|-------|----|--------|

| Attribute        | <b></b>    | · ·       |           | r         |
|------------------|------------|-----------|-----------|-----------|
| Symbol attribute | X: ADDRESS | X:ADDRESS | X:NUMBER  | X:NUMBER  |
| of term          |            |           |           |           |
| Type of operator | Y: ADDRESS | Y:NUMBER  | Y:ADDRESS | Y:ADDRESS |
| X + Y            |            | A         | <u>A</u>  | <u>N</u>  |
| <u>X - Y</u>     | N          | A         | <u> </u>  | N         |
| Х * Ү            | <u> </u>   |           |           | N         |
| Х / Ү            |            | -         |           | N         |
| X MOD Y          |            |           |           | N         |
| X SHL Y          |            |           |           | N         |
| X SHR Y          |            |           |           | N         |
| X EQ Y           | N          |           |           | N         |
| X LT Y           | N          |           |           | N         |
| X LE Y           | N          |           |           | N         |
| X GT Y           | N          |           |           | N         |
| X GE Y           | N          |           |           | N         |
| X NE Y           | N          |           |           | N         |
| X AND Y          |            |           |           | <u>N</u>  |
| X OR Y           |            |           |           | <u>N</u>  |
| X XOR Y          |            |           |           | N         |
| NOT X            |            |           | N         | N         |
| + X              | A          | A         | <u>N</u>  | <u>N</u>  |
| - X              |            |           | N         | N         |
| HIGH X           | A          | A         | N         | N         |
| LOW X            | A          | <u>A</u>  | N         | <u>N</u>  |
| х. ү             |            | В         | <u> </u>  | В         |

<Legend> ADDRESS: ADDRESS term

NUMBER : NUMBER term

A : The result of the operation becomes an ADDRESS term.

- N : The result of the operation becomes a NUMBER term.
- B : The result of the operation becomes a BIT term.
- : The operation cannot be performed.

Phase-out/Discontinued

(3) How to check restrictions on the operationAn example of an operation by the relocation attribute and symbol attribute of each term is shown here.

Example: BR <u>\$TABLE+5H</u> Here, assume that "TABLE" is a label defined in a relocatable code segment.

 Operator and relocation attribute Because "TABLE+5H" is "relocatable term + absolute term", apply this operation to Table 2-9, "Combinations of Operators by Relocatable Attribute".

Type of operator  $\longrightarrow$  X + Y

Relocation attribute of term  $\longrightarrow$  X:ABS, Y:REL From the table, you will find that the result becomes a relocatable term.

② Operator and symbol attribute Because "TABLE+5H" is "ADDRESS term + NUMBER term", apply this operation to Table 2-12, "Combinations of Operators and Terms by Symbol Attribute".

Type of operator  $\longrightarrow$  X + Y

Symbol attribute of term  $\longrightarrow$  X:ADDRESS, Y:NUMBER From the table, you will find that the result becomes an ADDRESS term. 2.4 Characteristics of Operands

Instructions and directives requiring an operand or operands differ from one type of instruction to another in the size and address range of the required operand value and in the symbol attribute of the operand.

Phase-out/Discontinued

For example, an instruction "MOV r1, #byte" functions to transfer the value indicated by "byte" to register "r1". In this case, because r1 is an 8-bit register, the size of the data "byte" to be transferred must be 8 bits or less.

If an instruction is described as "MOV RO, #100H", an assembly error occurs because the size of the 2nd operand "100H" of the instruction exceeds the capacity of the 8-bit register RO. So, when you describe an operand, attention must be paid to the following points:

- o Is the size of the operand value or its address range suitable for the operand (numerical data, name, or label) of the instruction?
- o Is the symbol attribute suitable for the operand (name or label) of the instruction?

2.4.1 Size and address range of operand value Certain conditions are set for the size and address range of the value of a numerical data, name, or label that can be described as the operand of an instruction or directive. With instructions, conditions for the size and address range of an operand value are governed by the operand representation format of each instruction. With directives, such conditions are governed by the type of directive.

These conditions are shown in Tables 2-13 and 2-14 below.

2-49

| Instructions | Representation    | Size of operand value |
|--------------|-------------------|-----------------------|
|              | format of operand |                       |
|              | word              | 16 bits max.          |
|              | byte              | 8 bits max.           |
|              | bit               | 3 bits max.           |
|              | n                 | 3 bits max.           |
| Directives   | Type of directive | Size of operand value |
|              | EQU               | .16 bits max.         |
|              | SET               | 16 bits max.          |
|              | DB                | 8 bits max.           |
|              | DW .              | 16 bits max.          |
|              | DS                | 16 bits max.          |

Table 2-13. Conditions for Size of Operand Value

NOTE 2-3

When describing names or labels as operands, note that names or labels with the following attributes will be handled as 16-bit data.

o Name or label with symbol attribute ADDRESS

o Name or label defined with the EXTRN directive If any of these names or labels is described as an 8-bit operand, an error will result. To avoid this error, describe the name or label by correcting it to an 8-bit value with the HIGH or LOW operator.

. . .

| Instructions | Representation<br>format of operand | Address range of operand value |
|--------------|-------------------------------------|--------------------------------|
|              | saddr                               | OFE20H to OFF1FH               |
|              | saddrp                              | Even value of OFE20H to OFF1FH |
|              | addr13                              | 0000H to 1FFFH                 |
|              | addr16                              | 0000H to 3EFFH                 |
|              | addr11                              | 0800H to OFFFH                 |
|              | addr5                               | Even value of 0040H to 007EH   |
| Directives   | Type of directive                   | Address range of operand value |
|              | ORG                                 | 0000H to OFFFFH                |
|              | BR                                  | 0000H to OFEFFH                |

Table 2-14. Conditions for Address Range of Operand Value

2.4.2 Symbol attributes and relocation attributes of operands When describing a name, label, or \$ (location counter) as the operand of an instruction, the name or label may or may not be described as an operand depending on the symbol attribute and relocation attribute of the operand as the term in an expression (see 2.3.2, "Restrictions on operations") or the reference direction of the name or label.

Names and labels are referenced in two directions: Backward and Forward.

 o Backward reference .... Name or label to be referenced as an operand has been defined in a previous line.
 o Forward reference .... Name or label to be referenced as an operand has been defined in a subsequent line.



. ...

These attributes of the operands of instructions and directives are shown in Tables 2-15 and 2-16 below.

| Table | 2-15. | Operand | Attributes | of | Instructions |
|-------|-------|---------|------------|----|--------------|
|-------|-------|---------|------------|----|--------------|

| F           |      |      | ·    |         | <u></u> |       | l       |          |          |
|-------------|------|------|------|---------|---------|-------|---------|----------|----------|
| Symbol      | NUMB | ER   |      | ADDRESS |         |       | NUMBER  |          | Special  |
| attribute   |      |      |      |         |         | or    |         | function |          |
|             |      |      |      |         |         |       | ADDRESS |          | register |
| Relocation  | Abso | lute | Absc | lute    | Reloca  | table | Exte    | rnal     | (sfr     |
| attribute   | term |      | term |         | term    |       | ref.    | term     | name)    |
| Reference   | B₩   | FW   | BW   | FW      | BW      | FW    | BW      | FW       |          |
| Operand     |      |      |      |         |         |       |         |          |          |
| format      |      |      |      |         |         |       |         |          |          |
| sfr         | _    | _    | -    | _       | -       | -     | -       | -        | 0        |
| (FF00H -    |      |      |      |         |         |       |         |          |          |
| FFFFH)      |      |      |      |         |         |       |         |          |          |
| sfrp        | _    | -    | -    | -       | -       | -     | -       | -        | o        |
| (FF00H -    |      |      |      |         |         |       |         |          |          |
| FFFFH)      | ]    |      |      |         |         |       |         |          | Cf.2     |
| saddr       | 0    | -    | 0    | -       | _       | _     | 0       | -        | 0        |
| (FE20H -    |      |      |      |         |         |       |         |          | (FF00H-  |
| FF1FH)Cf.1  |      |      |      |         |         |       |         |          | FF1FH)   |
| saddrp      | 0    | -    | 0    | _       | -       | -     | o       | · _      | 0        |
| (Even value |      |      |      |         |         |       |         |          | (FF00H-  |
| of FE20H -  |      |      |      |         |         |       |         |          | FF1FH)   |
| FF1FH) Cf.1 | ļ    |      |      |         |         |       |         | ·        |          |
| addr13      | 0    | 0    | 0    | 0       | 0       | 0     | 0       | _        | _        |
| addr16      |      | _    |      |         |         |       |         |          |          |
| addr11      | 0    | 0    | 0    | 0       | 0       | 0     | . 0     |          | _        |
| (800н -     |      | -    |      | -       | _       |       |         |          |          |
| FFFFH)      |      |      |      |         | Cf.3    | Cf.3  | -       |          |          |
| addr5       | .0   | 0    | 0    | 0       | 0       | 0     | 0       | -        | _        |
| (Even value |      |      |      |         |         |       |         |          |          |
| of 40H -    |      |      |      |         | Cf.4    | Cf.4  |         |          |          |
| 7EH)        |      |      |      |         |         |       |         |          |          |

.

.

.

| Symbol<br>attribute            | NUMB         | ER   |              |           |                | NUMBE<br>or<br>ADDRE |                    | Special<br>function<br>register |               |
|--------------------------------|--------------|------|--------------|-----------|----------------|----------------------|--------------------|---------------------------------|---------------|
| Relocation<br>attribute        | Abso<br>term | lute | Abso<br>term |           | Reloca<br>term | table                | External ref. term |                                 | (sfr<br>name) |
| Reference<br>Operand<br>format | BW           | FW   | BW           | FW        | BW             | FW                   | BW                 | FW.                             |               |
| word<br>(16 bits)              | 0            | 0    | ο            | ο         | ο              | 0                    | 0                  |                                 | -             |
| byte<br>(8 bits)               | Ö            | ō    | ∆<br>Cf.5    | ∆<br>Cf.5 | ∆<br>Cf.5      | Cf.5                 | ∆<br>Cf.5          | _<br>                           | -             |
| bit<br>(3 bits)                | 0            | ο    | 0            | 0         | 0              | -<br>Cf.6            | 0                  | _                               | . –           |
| n<br>(3 bits)                  | 0            | 0    | 0            | 0         | 0              | -<br>Cf.6            | 0                  | -                               | -             |

Table 2-15. Operand Attributes of Instructions (contd)

o ... Can be described. - ... Cannot be described.

 $\triangle$  ... May be described by changing it to an 8-bit data.

- NOTE: 1. uPD78112 ..... FE40H to FF1FH
  - uPD78122, uPD78124 ..... FE20H to FF1FH 2. Only the register names capable of 16-bit manipulation
    - can be described.
  - 3. Only labels defined in the code segment with relocation attribute FIXED can be described.
  - 4. Only labels defined in the code segment with relocation attribute CALLTO can be described.
  - 5. A name or label with symbol attribute ADDRESS, \$ (which indicates the current location counter), and an external reference term are handled as 16-bit data regardless of their value range. If any of these symbols is described as operand "byte", an error will result. Change the operand value to an 8-bit data with the HIGH or LOW operator.
  - 6. A term with symbol attribute ADDRESS cannot be described for forward reference as an operand "bit" or "n". Even if you describe such operand by mistake, an error will not occur. However, note that correct object code generation may not be expected from the operand.

| Table | 2-16. | Operand | Attributes | of | Directives |
|-------|-------|---------|------------|----|------------|
|-------|-------|---------|------------|----|------------|

| Symbol<br>attribute | N  | UMBI | ER  |    |     | A  | DDRI | ESS |     |    |    |    | B  | LT |     |    |
|---------------------|----|------|-----|----|-----|----|------|-----|-----|----|----|----|----|----|-----|----|
| Relocation          | Ab | s.   | Ext |    | Ab  | 5. | Re   | 1.  | Ext |    | Ab | 5. | Re | 1. | Ext | t. |
| attribute           | te | rm   | ter | m  | te: | rm | te   | cm  | ter | m  | re | £. | te | rm | tei | cm |
| Reference           | BW | FW   | BW  | FW | BW  | FW | BW   | FW  | BW  | FW | BW | FW | BW | FW | BW  | FW |
| Directive           |    |      |     |    |     |    |      |     |     |    |    |    |    |    |     |    |
| ORG                 | 0  | -    | -   | -  | ο   | _  | -    | -   | -   | -  | -  | -  | -  | -  |     | -  |
| EQU                 | 0  | -    | -   | -  | 0   | -  | 0    |     | -   | -  | 0  | -  | 0  | -  | 0   | -  |
| SET                 | 0  | -    |     | -  | -   | ~  |      |     | _   | -  | -  |    | _  | -  | _   | -  |
| DB<br>(see Note)    | 0  | 0    | ۵   | -  | ۵   | ۵  | Δ    | ۵   | · Δ | -  | -  | -  | -  | -  | -   | _  |
| DW .                | 0  | 0    | 0   |    | 0   | 0  | 0    | 0   | 0   | -  | -  | -  | -  | -  | _   | _  |
| DS                  | 0  | _    | -   | -  | 0   | -  | -    | -   | -   | -  | -  | -  | -  | -  | -   | -  |
| BR                  | 0  | 0    | ο   | -  | ο   | ο  | ο    | 0   | 0   | -  | -  | _  | -  | -  |     | -  |

Abs. term ... Absolute term Rel. term ... Relocatable term
Ext. term ... External reference term
BW ... Backward reference FW ... Forward reference
o ... Can be described. - ... Cannot be described.
A ... May be described by changing it to an 8-bit data.

NOTE: A name or label with symbol attribute ADDRESS, \$ (which indicates the current location counter), and an external reference term are handled as 16-bit data regardless of their value range. If any of these symbols is described as the operand of the DW directive, an error will result. Change the operand value to an 8-bit data with the HIGH or LOW operator.



3.1 Overview of Directives

Directives are described in a source program just the same as ordinary instructions. Directives are pseudoinstructions in a program which give the assembler processor various instructions necessary for this package to perform a series of processes. Instructions will be translated into object codes (i.e., machine language), but directives will not, as a rule, be converted into object codes.

Directives are available in seven types as listed in Table 3-1 and have the following major functions:

o Facilitate description of source programs.

o Initialize memory and reserve areas.

o Provide the information required for the assembler, linker, and locater to perform their intended processing.

| No. | Type of directive      | Directives                      |
|-----|------------------------|---------------------------------|
| 1   | Segment definition     | CSEG, DSEG, BSEG, ORG, ENDS     |
|     | directives             |                                 |
| 2   | Symbol definition      | EQU, SET                        |
|     | directives             |                                 |
| 3   | Memory initialization/ | DB, DW, DS, DBIT                |
|     | area reservation       |                                 |
|     | directives             |                                 |
| 4   | Linkage directives     | PUBLIC, EXTRN, EXTBIT, NAME     |
| 5   | Automatic branch       | BR                              |
|     | instruction selection  |                                 |
|     | directive              |                                 |
| 6   | Macro directives       | MACRO, LOCAL, REPT, IRP, EXITM, |
|     |                        | ENDM                            |
| 7   | Assembly termination   | END                             |
|     | directive              |                                 |

Table 3-1. List of Directives

A detailed description of each of these directives will be provided in the following sections. In the description format of each directive, "[ ]" indicates that the parameter in braces may be omitted from specification and "..." indicates the repetition of description in the same format. For example, if the description format reads:

ase-out/Discontinued

[(size)][initial value[, ...]]

you may describe any of the following three:

o (size)

o (size) initial value 1, initial value 2, initial value 3

o initial value 1, initial value 2



3.2 Directives for Segment Definition

A source module is described in units of segments.

Segment definition directives are used to define these segments.

Segments are divided into the following five types:

- o Code segment
- o Data segment
- o Bit segment
- o Absolute segment
- o Stack segment

To which address range in memory each segment will be allocated is determined by the type of segment.

Table 3-2 shows the method of defining each segment and the memory address area in which each segment will be allocated.

| Table | 3-2. | Segment  | Definition | Methods | and | Memory | Address |
|-------|------|----------|------------|---------|-----|--------|---------|
|       |      | Allocati | ion        |         |     |        |         |

| Type of       | Method of      | Memory address area to be |
|---------------|----------------|---------------------------|
| segment       | definition     | allocated to each segment |
| Code segment  | CSEG directive | Within the internal ROM   |
|               |                | area                      |
| Data segment  | DSEG directive | Within the internal RAM   |
|               |                | area                      |
| Bit segment   | BSEG directive | Within the saddr area in  |
|               |                | the internal RAM          |
| Absolute      | ORG directive  | Addresses specified by    |
| segment       |                | ORG directive             |
| Stack segment | Automatically  | Within the internal RAM   |
|               | generated by   | area                      |
|               | the assembler  |                           |

If the user wishes to determine the memory allocation to a segment, describe (define) the segment as an absolute segment. An example of memory allocation to segments is shown in Fig. 3-1.

.

Fig. 3-1. Memory Allocation to Segments





CSEG

code segment

CSEG

#### (1) CSEG (code segment)

#### Description Format

| Symbol         | Mnemonic     | Operand                | Comment      |
|----------------|--------------|------------------------|--------------|
| <u>field</u>   | <u>field</u> | <u>field</u>           | <u>field</u> |
| [segment name] | CSEG         | [relocation attribute] | [;comment]   |
|                | <u></u>      |                        |              |

Function

- o The CSEG directive indicates to the assembler the start of a code segment.
- o All instructions described after this directive until the re-appearance of any segment definition directive (CSEG, DSEG, BSEG, ORG, or ENDS) in the source module will belong to the code segment and will be allocated within the ROM address area upon conversion into machine language.

Fig. 3-2. Relocation of Code Segment



o If the relocation attribute of a code segment is specified in the Operand field of the CSEG directive, the address range to be allocated to the code segment can be made further definitive.

There are two types of relocation attributes as shown in Table 3-3.

Table 3-3. Functions of Relocation Attributes

| Relocation<br>attribute | Function                                                                             |
|-------------------------|--------------------------------------------------------------------------------------|
| CALLT0                  | Instructs the assembler to allocate the code segment within addresses 40H to 7FH.    |
| FIXED                   | Instructs the assembler to allocate the code segment within addresses 800H to 0FFFH. |

Phase-out/Discontinued

#### <u>Use</u>

- o Describe instructions, DB directive, or DW directive in the code segment defined by the CSEG directive. (However, to allocate the segment from a fixed address, the ORG directive must be described.)
- o Specify relocation attributes in the following cases:

Table 3-4. Uses of Relocation Attributes

| Relocation<br>attribute | Use                                                                                                                 |
|-------------------------|---------------------------------------------------------------------------------------------------------------------|
| CALLT0                  | Code segment which defines the entry<br>address of a subroutine to be called<br>with a one-byte instruction "CALLT" |
| FIXED                   | Code segment which defines a subroutine<br>to be called with a two-byte instruction<br>"CALLF"                      |

o Description of one functional unit such as a subroutine should be defined as a single code segment. If the size of the unit is relatively large or if the subroutine is highly versatile (can be utilized for development of other programs), the subroutine should be defined as a single module.

#### Explanation

o By describing a segment name in the Symbol field of the CSEG directive, the code segment can be named. If no segment name is specified for a code segment, the assembler will automatically give a segment name to the code segment. This default segment name is available in three types and is assumed appropriately according to the type of code segment. The type of code segment is determined by the type of relocation attribute. The relationship of default segment names and code segment types is shown in Table 3-5.

Table 3-5. Default Segment Names of Code Segments

| Default      | Code segment | Classification of code                              |
|--------------|--------------|-----------------------------------------------------|
| segment name | type         | segment type                                        |
| CSEG         | CSEG         | Code segment without specified relocation attribute |
| CSEGT0       | CST0         | Code segment with relocation attribute "CALLTO"     |
| CSEGFX       | CSFX         | Code segment with relocation attribute "FIXED"      |

- o If two or more code segments of the same segment type exist in a source module, these code segments must have the same segment name. (See Application Example 4.) This is because of that the code segments of the same segment type described in a source module will be processed as a single code segment within the assembler. (See Application Examples 5 and 6.)
- o Code segments with the same segment name and the same segment type can be described in two or more different modules. These segments are called the same named segments. The same named code segments will be combined into a single code segment at linkage time.

3-7

| Example 1 | NAME     | SAMP 1  |       |   | _ |              |
|-----------|----------|---------|-------|---|---|--------------|
|           | CSEG     | CALLT 0 | ; (1) |   |   |              |
|           | TLAB1:DW | LABI    |       | • |   |              |
| -         | CSEG     |         | ; (2) |   |   |              |
|           | :        |         |       |   |   |              |
|           | CALLT    | (TLAB1) | ; (3) |   |   |              |
|           | CSEG     |         | ; (4) |   |   |              |
|           | LAB1: :  |         |       |   |   |              |
|           |          |         |       |   |   | <u>ب</u> ر ( |
|           | END      |         |       | - |   |              |

- (1) Within this code segment, the entry address of a subroutine to be called by the CALLT instruction is defined. Therefore, relocation attribute "CALLTO" must be specified for this code segment.
- (2) Within this code segment, instructions which may be allocated to any locations in the ROM area are described. Therefore, no relocation attribute will be specified for this code segment.
- (3) Label "TLAB1" is described to indicate the address in which the entry address of the subroutine is stored.
- (4) In this code segment, the subroutine to be called by the CALLT instruction in (3) is defined.

Example 2

| NAME    | SAMP3 |       |
|---------|-------|-------|
| CSEG    | FIXED | ; (1) |
| SUB1: : |       |       |
| CSEG    |       |       |
| :       |       |       |
| CALLF   | ISUB1 | ; (2) |
| :       |       |       |
| END     |       |       |

- (1) Within this code segment, the entry address of a subroutine to be called by the CALLF instruction is defined. Therefore, relocation attribute "FIXED" must be specified for this code segment.
- (2) Label "SUB1" is described as the operand of the CALLF instruction to indicate the address in which the entry address of the subroutine is stored.

Example 3



- (1) A code segment is defined without relocation attribute specification (segment type "CSEG"). Segment name is "SN41".
- (2) A code segment without specified relocation attribute (segment type "CSEG") has already been defined in (1) above. Therefore, this description results in an error. Change the segment name to "SN41".

Example 4

|      | NAME | SAMP5 |       |
|------|------|-------|-------|
| SN5  | CSEC |       | ; (1) |
|      | ÷    |       |       |
|      | ORG  | 1000H | ; (2) |
|      | :    |       |       |
| SN 5 | CSEG |       | ; (3) |
|      | ÷    |       |       |
|      | END  |       | j     |

- (1) A code segment is defined without relocation attribute specification (segment type "CSEG"). Segment name is "SN5".
- (2) An absolute segment is defined with start address "1000H".
- (3) This segment will be processed as a continuous segment which follows the code segment defined in (1) above, with segment type "CSEG" and segment name "SN5". The first address of the segment defined in (3) will be the address next to the last address of the segment defined in (1) above.

| Example 5 | < M | odule 1> |        |       |
|-----------|-----|----------|--------|-------|
|           |     | NAME     | SAMP61 |       |
|           | SN6 | CSEG     |        | ; (1) |
|           |     | :        |        |       |
|           |     | END      |        |       |

| < Mc | dule 2> |        |       |
|------|---------|--------|-------|
|      | NAME    | SAMP62 |       |
| SN6  | CSEG    |        | ; (2) |
| 1    | :       |        |       |
| L    | END     |        |       |

- (1) & (2)
  - Code segment "SN6" defined in (1) in module 1 becomes the same in segment name and segment type as the code segment defined in (2) in module 2. Therefore, these two code segments will be processed as a single code segment at linkage time.



DSEG

data segment

DSEG

#### (2) DSEG (data segment)

#### Description Format

| Symbol<br><u>field</u> | Mnemonic<br>field | Operand<br>field | Comment<br>field |
|------------------------|-------------------|------------------|------------------|
| [segment name]         | DSEG              | None             | [;comment]       |
|                        |                   |                  |                  |

#### Function

- o The DSEG directive indicates to the assembler the start of a data segment.
- o Memory areas defined by the DS directive after this directive until the re-appearance of any segment definition directive (CSEG, DSEG, BSEG, ORG, or ENDS) in the source module will belong to the data segment and will be finally allocated within the RAM address area.

Fig. 3-3. Relocation of Data Segment



Use

o Mainly describe the DS directive in the data segment defined by the DSEG directive. The data segment will be allocated within the RAM area. Therefore, no instructions can be described in any data segment.

Phase-out/Discontinued

- o In a data segment, the DS directive must be described to reserve a RAM work area to be used by the program and a label must be given to the address of each work area. When describing a source program, this label is used. Each area reserved as a data segment will be allocated by the locater so that it does not overlap with any other work areas on the RAM (stack area, general-purpose register area, and work areas defined by other modules).
- o A label defined within a relocatable data segment cannot be described as a label to indicate an address in the short direct addressing area.

Accessing data in the short direct addressing area can be processed by instructions with a short word length and a fewer number of clocks. Use this area by specifying absolute addresses for effective utilization. Short direct addressing area:

uPD78112 .....0FE40H to 0FF1FH uPD78122, uPD78124 ... 0FE20H to 0FF1FH

o A label defined within a relocatable data segment can be described only as an operand which is indicated by the operand representation format "addr13", "addr16", or "word".

**Explanation** 

- o By describing a segment name in the Symbol field of the DSEG directive, the data segment can be named.
  If no segment name is specified for a data segment, the assembler will automatically give a default segment name "DSEG" to the data segment.
- o All data segments will have "DSEG" as their segment type.

o If two or more data segments exist in a source module, these data segments must have the same segment name. (See Application Example 2.) This is because of that two or more data segments described in a source module will be processed as a single data segment within the assembler.

o Data segments with the same segment name can be described in two or more different modules. These segments are called the same named segments.

The same named data segments will be combined into a single data segment at linkage time.

o Data segments are segments which define the RAM addresses to be used in the source module. So, define these segments in the early part of the module body.

#### Application Examples





- The start of a data segment is defined with the DSEG directive.
- (2) This description corresponds to "MOV A, !addr16(addr13)".
- (3) This description corresponds to "MOV A, saddr". Relocatable label "WORK1" cannot be described as "saddr". Therefore, an error will occur as a result of this description.
- (4) This description corresponds to "MOVW rp1, #word".
- (5) This description corresponds to "MOVW AX,saddrp". Relocatable label "WORK2" cannot be described as "saddrp". Therefore, an error will result as a result of this description.

Example 2

|        | NAME | SAMP 2 |       |                                   |
|--------|------|--------|-------|-----------------------------------|
| DATAI  | DSEG |        | ; (1) |                                   |
|        | i    |        |       |                                   |
| DATA 2 | DSEG | 4      | ; (2) | This description is<br>erroneous. |
|        | :    |        |       |                                   |
|        | DSEG |        | ; (3) |                                   |
|        | :    |        |       | erroneous.                        |
| DATAI  | DSEG |        | ; (4) |                                   |
|        | :    |        |       |                                   |
|        | END  |        |       |                                   |

- (1) A data segment with segment name "DATA1" is defined with the DSEG directive.
- (2) A data segment has already been defined in (1) above. The segment name of the segment defined in (2) must be "DATA1", or an error will occur.
- (3) If no segment name is specified, "DSEG" is assumed as the segment name. Therefore, an error will also occur in this case for the same reason as (2) above.
- (4) This segment will be processed as a continuous segment which follows the data segment defined in (1) above. The first address of the segment defined in (4) will be the address next to the last address of the segment defined in (1) above.

Phase-out/Discontinued

BSEG

### bit segment

BSEG

#### (3) BSEG (bit segment)

#### Description Format

| Symbol<br><u>field</u> | Mnemonic<br>field                     | Operand<br>field | Comment<br><u>field</u> |
|------------------------|---------------------------------------|------------------|-------------------------|
| [segment name]         | BSEG                                  | None             | [;comment]              |
|                        | · · · · · · · · · · · · · · · · · · · | ··· •            |                         |

Function

- o The BSEG directive indicates to the assembler the start of a bit segment.
- o A bit segment is a segment which defines the RAM addresses to be used in the source module.
- o Memory areas defined by the DS directive after this directive until the re-appearance of any segment definition directive (CSEG, DSEG, BSEG, ORG, or ENDS) in the source module will belong to the bit segment and will be finally allocated within the RAM address area OFE20H to OFF1FH.

Fig. 3-4. Relocation of Bit Segment



o Describe the DBIT directive in the bit segment defined by the BSEG directive. (See Application Examples 1 and 2.) The bit segment will be allocated to the short direct addressing area in the RAM. Therefore, no instructions can be described in any bit segment.

Short direct addressing area:

uPD78112 .....0FE40H to 0FF1FH uPD78122, uPD78124 ... 0FE20H to 0FF1FH

- o In a bit segment, the DBIT directive must be described to reserve a one-bit work area to be used by the program and a name must be given to the bit address.
  When describing a source program, this name is used.
  Therefore, a bit segment defining this name should be described at the early part of the module body. (See Application Example 1.)
- o Each area reserved as a bit segment will be allocated by the locater so that it does not overlap with any other data segments or work areas.
- o A bit segment will be allocated without consideration to any byte boundary. If a bit address is to be defined with attention paid to a byte boundary, define the bit address with the EQU directive. (See Application Example 2.) For the bit address map, see Table 3-7 in 3.3 (1), "EQU directive".

#### **Explanation**

- o By describing a segment name in the Symbol field of the BSEG directive, the bit segment can be named. If no segment name is specified for a bit segment, the assembler will automatically give a default segment name "BSEG" to the bit segment.
- o All bit segments will have "BSEG" as their segment type.
- o The BSEG directive can be described only once in a source module. (See Application Example 3.)
- o Bit segments with the same segment name can be described in two or more different modules. These segments are called the same named segments.

<u>Use</u>

3-17

The same named bit segments will be combined into a single data segment at linkage time.

o No labels can be defined in a source module. The ORG directive cannot be described in a source module. (See Application Example 3.) The following directives and all control instructions can be used in a bit segment: Directives: DBIT, EQU, SET, MACRO, REPT, IRP

#### Application Examples

| Example 1 | ·   |       | · <u> </u> |       |
|-----------|-----|-------|------------|-------|
| Diampic   |     | NAME  | SAMP 1     |       |
|           |     | BSEG  |            | ; (1) |
|           | B 1 | DBIT  |            | Í     |
|           | B 2 | DBIT  |            |       |
|           | B 3 | DBIT  |            |       |
|           |     |       |            |       |
|           |     | CSEG  |            |       |
|           |     | MOV1  | CY, B1     | ; (2) |
|           |     | ÷     |            |       |
|           |     | AND 1 | CY, B2     | ; (3) |
|           |     | :     |            |       |
|           |     | END   |            |       |
|           |     |       |            | J     |

- (1) A bit segment is defined with the BSEG directive. Within the bit segment, a bit work area is defined for each bit with the DBIT directive. A bit segment should be described at the early part of the module body.
- (2) This description corresponds to "MOV1 CY, saddr.bit".
- (3) This description corresponds to "AND1 CY, saddr.bit".

Example 2

|       | NAME         | SAMP 2                             |       |
|-------|--------------|------------------------------------|-------|
| FLAGO | EQU          | 0 FE 2 0 H<br>FLAG . 0<br>FLAG . 1 | ; (1) |
|       | ŗ            | I DAG . I                          | , (1/ |
| FLAG2 | BSEG<br>DBIT |                                    | ; (2) |
|       | CSEG         |                                    |       |
|       | MOV1<br>:    | CY,FLAG0                           | ; (3) |
|       | MOV1<br>:    | CY, FLAG2                          | ; (4) |
|       | END          |                                    |       |

- Bit addresses (Bit 0 and Bit 1 of 0FE20H) are defined with consideration given to byte address boundaries.
- (2) Bit address FLAG2 defined in the bit segment is allocated without consideration to any byte address boundary.
- (3) This description can be substituted with "MOV1 CY, FLAG.0". Here, FLAG indicates a byte address. in this case for the same reason as (2) above.
- (4) In this description, no consideration is given to byte addresses.

| Example 3 | NAME             | SAMP3 |       |                                   |
|-----------|------------------|-------|-------|-----------------------------------|
|           | BSEG             |       |       |                                   |
|           | ORG<br>:         | 100H  | ; (1) | This description is<br>erroneous. |
|           | BSEG<br>:<br>END |       | ; (2) | This description is<br>erroneous. |

- This description results in an error, because the ORG directive has been described in the bit segment.
- (2) The BSEG directive cannot be described more than once within the same module.

Phase-out/Discontinued

ORG

origin

•

ORG

#### (4) ORG (origin)

#### Description Format

| Symbol         | Mnemonic | Operand    | Comment    |
|----------------|----------|------------|------------|
| <u>field</u>   | field    | field      | field      |
| [segment name] | ORG      | expression | [;comment] |
|                |          |            | ,          |

#### Function

- o The ORG directive sets the value of the expression specified by its operand in the location counter.
- o Instructions described or memory areas reserved after this directive until the re-appearance of any segment definition directive (CSEG, DSEG, BSEG, ORG, or ENDS) in the source module will belong to the absolute segment and will be allocated beginning with the address specified in the operand of this directive.





- o Describe the ORG directive to start allocation to a code segment or data segment from a specific address.
- o To store an interrupt branch address in the vector table area (OH to 3FH), specify the address with the ORG directive. (See Application Example 2.)

#### Explanation

o The absolute segment defined with the ORG directive belongs to the code segment or data segment defined with the CSEG or DSEG immediately before the ORG directive. Within an absolute segment which belongs to a data segment, no instructions can be described.

No absolute segment can be defined following a bit segment.

- o By describing a segment name in the Symbol field of the ORG directive, the absolute segment can be named. If no segment name is specified for an absolute segment, the assembler will automatically give a default segment name "ASEGn" to the absolute segment (where n is a value in the range of 1 to 10 and is given in the order of segment description within the source module).
- o All absolute segments will have "ASEG" as their segment type.
- o If a name or label is to be described as the operand of the ORG directive, the name or label must be an absolute term which has already been defined in the source module.
- o Addresses OH to 3FH are used as a vector table area, and addresses 40H to 7FH, as a table area for CALLT instruction. If any address lower than 7FH is specified as the operand of the ORG directive, the assembler will output a warning message to the console and an assembly list.
- o If no CSEG or DSEG directive has been described before the ORG directive, the absolute segment defined by the ORG directive is assumed to be an absolute segment in a code segment.

Use

NOTE 3-1

The ORG directive can be described up to 10 times within a source module. An error will result if 11 or more absolute segments are described within the module.

Phase-out/Discontinued

Application Examples

| IICALION EXA | mpres  |      |             |       | · · · · · · · · · · · · · · · · |
|--------------|--------|------|-------------|-------|---------------------------------|
| Example 1    | · ·    | NAME | SAMP 1      |       |                                 |
| Drampic      |        | DSEG | • •         |       |                                 |
|              | SADR   | ORG  | 0 F E 2 0 H | ; (1) |                                 |
|              | SADR1: | DS   | 1           |       |                                 |
|              | SADR2: | DS   | 1           |       |                                 |
|              | SADR3: | DS   | 2           |       |                                 |
|              |        | :    |             |       |                                 |
|              | MAINO  | ORG  | 100H        |       |                                 |
|              | · ·    | MOV  | A, SADR1    | ; (2) | This description is erroneous.  |
|              |        | :    |             |       | errolleous.                     |
|              |        | CSEG |             | ; (3) |                                 |
|              | MAIN1  | ORG  | 1000H       | ; (4) |                                 |
|              |        | MOV  | A, SADR2    |       |                                 |
|              |        | моуу | AX, SADR3   | ٠     |                                 |
|              |        | :    |             |       |                                 |
|              |        | END  |             |       |                                 |

- (1) An absolute segment which belongs to a data segment is defined. This absolute segment will be allocated to the short direct addressing area which starts from address "FE20H" (when the target device is uPD78112).
- (2) Within an absolute segment which belongs to a data segment, no instruction can be described.
- (3) This directive declares the start of a code segment.
- (4) This absolute segment will be allocated to an area which starts from address "1000H".

Example 2

|   |      | and the second | the second s |
|---|------|------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
|   | NAME | SAMP 2                                                                                                           |                                                                                                                |
|   | ORG  | 0 H                                                                                                              | ; (1)                                                                                                          |
|   | ;    |                                                                                                                  |                                                                                                                |
|   | CSEG |                                                                                                                  | ; (2)                                                                                                          |
|   | ORG  | 800H                                                                                                             | ; (3)                                                                                                          |
|   | :    |                                                                                                                  |                                                                                                                |
|   | ORG  | 1000H                                                                                                            | ; (4)                                                                                                          |
|   | :    |                                                                                                                  |                                                                                                                |
| , | END  |                                                                                                                  |                                                                                                                |
|   |      |                                                                                                                  |                                                                                                                |

- (1) This absolute segment belongs to a code segment and will be allocated to an area which starts from address "OH".
- (2) This directive indicates the start of a code segment.
- (3) This absolute segment will be allocated to an area which starts from address "800H".
- (4) This absolute segment will be allocated to an area which starts from address "1000H".

Three absolute segments are defined in (1), (3), and (4) above, without segment name. Therefore, the assembler will automatically give names ASEG1, ASEG2, and ASEG3 to the segments defined in (1), (3), and (4), respectively.

#### (5) ENDS (end of segment)

### Description Format

| Symbol | Mnemonic | Operand | Comment      |
|--------|----------|---------|--------------|
| field  | field    | field   | <u>field</u> |
| None   | ENDS     | None    | [;comment]   |
|        |          |         |              |
| L      |          |         |              |

#### Function

The ENDS directive indicates the end of the relocatable segment defined by the CSEG, DSEG, or BSEG directive.

#### <u>Use</u>

The ENDS directive is used in pairs with the CSEG, DSEG, or BSEG directive.

- o The ENDS directive indicates the end of each segment in source module description.
- o After the ENDS directive has been described, only comments can be described before the next segment definition directive (CSEG, DSEG, BSEG, or ORG) is described.
- o Description of the ENDS directive may be omitted.

### Application Example

|       | NAME    | SAMP 1 |       |                                |
|-------|---------|--------|-------|--------------------------------|
|       | BSEG    |        |       |                                |
|       | :       |        |       |                                |
|       | ENDS    |        | ; (1) |                                |
| idata | segment |        |       |                                |
|       | DSEG    |        | ; (2) |                                |
|       | :       |        |       |                                |
|       | ENDS    |        | ; (3) |                                |
| WORK: | DS      | 1      | ; (4) | This description is erroneous. |
|       | CSEG    |        | ; (5) |                                |
|       | ÷       |        |       |                                |
|       | ENDS    |        | ; (6) |                                |
|       | END     |        |       |                                |

- (1) This directive indicates the end of a bit segment.
- (2) This directive indicates the start of a data segment.Only comments can be described between (1) and (2).
- (3) This directive indicates the end of the data segment.
- (4) Only comments can be described between the ENDS directive and the CSEG directive in (5) below.
- (5) This directive indicates the start of a code segment.
- (6) This directive indicates the end of the code segment.

#### 3.3 Directives for Symbol Definition

Symbol definition directives assign names to numerical data to be used for describing a source module. By these names, the meaning of each data value becomes clear and you may easily understand the contents of the source module.

Symbol definition directives inform the assembler of the value of each name to be used in the source module.

The definitions of names with symbol definition directives must be described in the module header.

. •

Two directives are available for symbol definition: EQU and SET.

equate

EQU

EQU

#### (1) EQU (equate)

#### Description Format

| Symbol       | Mnemonic     | Operand      | Comment    |
|--------------|--------------|--------------|------------|
| <u>field</u> | <u>field</u> | <u>field</u> | field      |
| name         | EQU          | expression   | [;comment] |
|              |              |              |            |
|              |              |              |            |

#### <u>Function</u>

The EQU directive defines a name which has the value and attributes (symbol attribute and relocation attribute) of the expression specified in the Operand field.

#### <u>Use</u>

Define a numerical data to be used in the source module as a name and describe it in the operand of the directive in place of the numerical data.

Numerical data to be frequently used in the source module should be defined as names. By so doing, if you must change a data value in the source module, all you need to do is to change the operand value of the name. (See Application Example 1.)

- o When a name or label is to be described in the operand of the EQU directive, use the name or label which has already been defined in the source module.
- o Because the EQU directive defines data to be used in a source module, define the name for the data in the module header of the source module.
- o If an error exists in the statement in which a name has been defined with the EQU directive, the name will not be stored in memory. An error will also occur in the statement in which the name is referenced.



- o A name defined with the EQU directive cannot be defined . again within the same source module.
- o Any of the bit values shown in Table 3-6 can be used as the operand of the EQU directive. A name which has defined any of the bit values can be referenced only within the same module. However, a name which has defined "saddr.bit" can be used as an external definition symbol.
- Table 3-6. Representation Formats of Operands Indicating Bit Values

| Representation    | Range in which name can            |
|-------------------|------------------------------------|
| format of operand | be referenced                      |
| saddr.bit         | A name which has defined this bit  |
|                   | value can be referenced from       |
|                   | another module.                    |
| sfr.bit           | A name which has defined any of    |
| A.bit             | these bit values can be referenced |
| X.bit             | only within the same module.       |
| PSW.bit           |                                    |

o A name which has defined a bit value with the EQU directive has a bit address as its value. See Table 3-7 for the bit address map.

### Application Examples

#### Example 1

|        | NAME | SAMP 1        |      |
|--------|------|---------------|------|
| DATA1  | EQU  | 10H           | ;(1) |
| DATA2  | EQU  | 20H           |      |
| ADRS 1 | EQU  | OFE20H        | :(2) |
| ADRS2  | EQU  | OFE21H        |      |
|        | CSEG |               |      |
|        | MOV  | A, #DATA1     | ;(3) |
|        | ADD  | A, ADRS1      | ;(4) |
|        | MON  | ADRS2, #DATA1 | ;(5) |
|        | END  |               |      |
|        |      |               |      |

- (1) Name "DATA1" has value "10H", symbol attribute "NUMBER", and relocation attribute "ABSOLUTE".
- (2) Name "ADRS1" has value "OFE20H", symbol attribute "NUMBER", and relocation attribute "ABSOLUTE".
- (3) Name "DATA1" defined in (1) above is described as the operand of the MOV instruction with a value of 10H.
- (4) Name "ADRS1" defined in (2) above is described as the operand of the ADD instruction with a value of OFE20H.
- (5) Names "ADRS2" and "DATA1" which have already been defined are described as the operands of the MOV instruction.

If the value "10H" defined as "DATA1" must be changed to 50H, you only need to change 10H to 50H in the directive description (1). Descriptions (3) and (5) need not to be changed.

Example 2

|         | NAME  | SAMP2      |       |
|---------|-------|------------|-------|
| WORK 1  | EQU   | OFE40H     | :(1)  |
| WORK 10 | EQU   | WORK1.0    | ;(2)  |
| WORK 11 |       | WORK1.1    | ;(2)  |
| P12     | EQU   | P1.2       | ;(3)  |
| P13     | EQU   | P1.3       | ;(3)  |
| A4      | EQU   | A. 4       | ;(4)  |
| X5      | EQU   | X. 5       | ;(5)  |
| PSW5    | EQU   | PSW. 5     | ;(6)  |
| PSW6    | EQU   | PSW. 6     | ;(7)  |
|         | CSEG  |            |       |
|         | MOV1  | CY, WORK10 | ;(8)  |
|         | MOV1  | P12, CY    | ;(9)  |
|         | OR1   | CY, A4     | ;(10) |
|         | XOR 1 | CY, X5     | ;(11) |
|         | SETI  | PSW5       | ;(12) |
|         | CLR1  | PSW6       | ;(13) |
|         | END   |            |       |

- (1) Name "WORK1" has value "02FE40H", symbol attribute "NUMBER", and relocation attribute "ABSOLUTE".
- (2) Bit values "WORK1.0" and "WORK1.1" which are in the operand format "saddr.bit" are assigned names "WORK10" and "WORK11", respectively. Value "OFE40H" has already been defined in (1) for "WORK1" described as the operand of the EQU directive.
- (3) Bit values "P1.2" and "P1.3" which are in the operand format "sfr.bit" are assigned names "P12" and "P13", respectively.
- (4) Bit value "A.4" which is in the operand format "A.bit" is assigned name "A4".

- (5) Bit value "X.5" which is in the operand format "X.bit" is assigned name "X5".
- (6) Bit value "PSW.5" which is in the operand format "PSW.bit" is assigned name "PSW5".
- (7) Bit value "PSW.6" which is in the operand format "PSW.bit" is assigned name "PSW6".
- (8) This description corresponds to "MOV1 CY, saddr.bit".
- (9) This description corresponds to "MOV1 sfr.bit, CY".
- (10) This description corresponds to "OR1 CY, A.bit".
- (11) This description corresponds to "XOR1 CY, X.bit".
- (12) This description corresponds to "SET1 PSW.bit".
- (13) This description corresponds to "CLR1 PSW.bit".

Names which have defined "sfr.bit", "A.bit", "X.bit", and "PSW.bit" as in (3) through (7), can be referenced only within the same module.

A name which has defined "saddr.bit" can also be referenced as an external definition symbol from another module. (See 3.5 (2), "EXTBIT directive".)

As a result of assembling the source module in Example 2, the following assembly list is generated. See the object codes output on this list. (Also see APPENDIX C-2 for the instruction codes.)

```
ASSEMBLE LIST
```

| STNO | ADRS R | OBJECT | МΙ | SOURCE  | STATEMEI | NT         |         |
|------|--------|--------|----|---------|----------|------------|---------|
| ۱    |        |        |    |         | NAME     | SAMP2      |         |
| 2    |        | FE40   |    |         |          | OFE 40H    | :(1)    |
| 3    |        | 0200   |    | WORK 10 | 50U      | WORK1.0    | ÷(2)    |
| 4    |        | 0201   |    | WORK 11 | EQU      | WORK1.1    | _ 3 (2) |
| 5    |        | 080A   |    | P12     | EQU      | P1.2       | ;(3)    |
| 6    |        | 080B   |    |         | EQU      |            | ;(3)    |
| •    |        |        |    |         |          |            |         |
| 7    |        | 0000   |    | A4      | EQU      | A. 4       | ;(4)    |
| 8    |        | 0005   |    |         | EQU      |            | :(5)    |
| •    |        |        |    |         |          |            |         |
| 9    |        | OFF5   |    | PSW5    | EQU      | PSW. 5     | ;(6)    |
| 10   |        | OFF6   |    | PSW6    | EQU      | PSW. 6     | ;(7)    |
| 10   |        | 0.1.0  |    | 1 0 10  |          | r 34. 0    |         |
| 11   |        |        |    |         | CSEG     |            |         |
| 12   | 0000   | 080040 |    |         | MOVI     | CY, WORK10 | ;(8)    |
| 13   | 0003   | 081A01 |    |         | MOVI     | P 12, CY   | ;(9)    |
| 14   | 0006   | 034C   |    |         | OR1      | CY, A4     | ;(10)   |
| 15   | 0008   | 0365   |    |         | XORI     | CY, X5     | :(11)   |
| 16   | 000A   | 0285   |    |         | SETI     | PSW5       | ;(12)   |
| 17   | 000C   | 0296   |    |         | CLR1     | PSW6       | :(13)   |
| 18   |        |        |    |         | END      |            |         |

On lines (2) through (7) of the assembly list, bit address values for the bit values defined as names are indicated in the OBJECT (code) column. Each bit address becomes a value as shown in Table 3-7. A bit address is a value to be given for the convenience of assembly processing and the value itself has no meaning.

Table 3-7. Bit Address Map



NOTE: MSB ... Most significant bit LSB ... Least significant bit

SET

### (2) SET (set)

### Description Format

| Symbol       | Mnemonic     | Operand      | Comment      |
|--------------|--------------|--------------|--------------|
| <u>field</u> | <u>field</u> | <u>field</u> | <u>field</u> |
| name         | SET          | expression   | [;comment]   |
|              |              |              |              |

#### Function

- o The SET directive defines a name which has the value and attributes (symbol attribute and relocation attribute) of the expression specified in the Operand field.
- o The value and attribute of a name defined with the SET directive can be re-defined within the same module.
- o The value and attribute of a name defined with the SET directive are valid until the same name is re-defined.

#### <u>Use</u>

Define a numerical data (variable) to be used in the source module as a name and describe it in the operand of the directive in place of the numerical data (variable). If you wish to change the value of a name in the source module, a different value can be set in the same name with the SET directive.

#### **Explanation**

- o When a name is to be described in the operand of the SET directive, use the name which has already been defined in the source module.
- o The following items cannot be described as the operand
  of the SET directive:
   External reference term
   Label
   Name which has BIT attribute and BIT value

3-34

set

- o A name which has been defined with the SET directive can be referenced only within the same source module.
- o If an error exists in the statement in which a name has been defined with the SET directive, the name will not be stored in memory. An error will also occur in the statement in which the name is referenced.

#### Application Example

|       | NAME | SAMP 1    |       |
|-------|------|-----------|-------|
| COUNT | SET  | 1 0 H     | ; (1) |
|       | CSEG |           |       |
|       | ÷    |           |       |
|       | MOV  | B, #COUNT | ; (2) |
| LOOP: | :    |           |       |
|       | DEC  | В         |       |
|       | BNZ  | LOOP      |       |
|       | •    |           |       |
| СОИМТ | SET  | 20H       | ; (3) |
|       | ŧ    |           |       |
|       | моч  | B,#COUNT  | ; (4) |
|       | :    |           |       |
|       | END  |           |       |
|       |      |           |       |

- (1) Name "COUNT" has value "10H", symbol attribute "NUMBER", and relocation attribute "ABSOLUTE". The value and attributes are valid until re-definition in (3).
- (2) The value "10H" of name "COUNT" will be transferred to register B.
- (3) The value of name "COUNT" is changed to 20H.
- (4) The value "20H" of name "COUNT" will be transferred to register B.

3.4 Directives for Memory Initialization and Area Reservation Memory initializing directives define constant data to be used in a source program. The value of the defined constant data is generated as an object code.

Area reservation directives reserve memory areas to be used by the source program.

DB

#### (1) DB (define byte)

| Descri | ption | Format |
|--------|-------|--------|
|        |       |        |

| Symbol       | Mnemonic     | Operand                    | Comment    |
|--------------|--------------|----------------------------|------------|
| <u>field</u> | <u>field</u> | field                      | field      |
| [label:]     | DB           | [(size)][initial value[,]] | [;comment] |
|              |              |                            |            |

#### Function

The DB directive initializes a memory area in byte units with the initial value(s) specified in the Operand field. The number of bytes to be initialized can be specified as "size".

#### <u>Use</u>

The DB directive is used when defining a constant (numeric constant or character constant).

#### **Explanation**

| 0 | The  | following | three | parameters | can | be | specified | as | initial |
|---|------|-----------|-------|------------|-----|----|-----------|----|---------|
|   | valu | les:      |       |            |     |    |           |    |         |

(1) Constant

Numeric constant: Must be a constant consisting of not more than 8 bits. (Its value must be in the range of 0 to 255.) Character constant: Must be one character (7-bit ASCII

code).

(2) Name

The value of a name that can be described as the operand must be 8 bits or less. Its symbol attribute is "NUMBER" and its relocation attribute, "ABSOLUTE".

(3) Expression

The value of an expression that can be described as the operand must be an absolute term consisting of not more than 8 bits.

- o If both "size" and "initial value" are specified, the assembler checks if the specified size is equal to the specified initial value in the number of bytes.
- o If a size is specified but no initial value is specified, an area equivalent to the number of bytes specified by the size is initialized with value "00H".
- o The DB directive cannot be described within a bit segment.

#### Application Example

| -      | NAME | SAMP 1         |       |                    |
|--------|------|----------------|-------|--------------------|
|        | CSEG |                |       |                    |
| WORK 1 | DB   | (1)            | ;(1)  |                    |
| WORK 2 | DB   | (2)            | :(1)  |                    |
| •      | CSEG |                |       | · · · · ·          |
| MASSAG | DB   | 'ABCDEF'       | ; (2) |                    |
| DATA1  | DB   | OAH, OBH, OCH  | ; (3) |                    |
| DATA 2 | DB   | (3)100,101,102 | ; (4) |                    |
| DATA3  | DB   | (2)0AH         | ; (5) | This description i |
|        | :    |                |       | erroneous.         |
|        | END  |                |       |                    |

- (1) By specifying (size) only, each byte area is initialized with value "00H".
- (2) This directive initializes a 6-byte area with character constant "ABCDEF".
- (3) This directive initializes a 3-byte area with numeric constants "OAH, OBH, OCH".
- (4) This directive initializes a 3-byte area with numeric constants "100, 101, 102". The assembler checks if the specified size agrees with the initial values in the number of bytes.
- (5) Because the specified size does not agree with the initial value in the number of bytes, this description will result in an error.

DW

#### (2) DW (define word)

#### Description Format

| Symbol   | Mnemonic | Operand                    | Comment      |
|----------|----------|----------------------------|--------------|
| field    | field    | <u>field</u>               | <u>field</u> |
| [label:] | DW       | [(size)][initial value[,]] | [;comment]   |
|          |          |                            |              |

#### Function

The DW directive initializes a memory area in word units (i.e., in units of 2 bytes) with the initial value(s) specified in the Operand field. The number of words to be initialized can be specified as "size".

#### <u>Use</u>

The DW directive is used when defining a 16-bit numeric constant such as an address or data.

#### Explanation

- o The following three parameters can be specified as initial values:
  - Numeric constant Must be a constant consisting of not more than 16 bits.
  - (2) Name or label Must be a name or label with a value of not more than 16 bits. A name with BIT attribute cannot be described as the
  - operand of this directive.
    ③ Expression

Must be an expression with a value of not more than 16 bits.

o If both "size" and "initial value" are specified, the assembler checks if the specified size is equal to the specified initial value in the number of words.

- o If a size is specified but no initial value is specified, an area equivalent to the number of words specified by the size is initialized with value "00H".
- o The DW directive cannot be described within a bit segment.

### Application Example

|         | NAME | SAMPLE         |       |
|---------|------|----------------|-------|
|         | CSEG |                |       |
| WORK1:  | DW   | (10)           | ;(1)  |
| VORK 2: | DW   | (128)          | ;(1)  |
|         | CSEG |                |       |
|         | ORG  | 0 H            |       |
|         | DW   | MÁIN           | ; (2) |
|         | DW   | SUBI           | ; (2) |
|         | CSEG |                |       |
| AIN :   | :    |                |       |
|         | CSEG | 1              |       |
| UB1 :   | :    |                |       |
| ATA :   | DW   | (2)1234H,5678H | : (3) |
|         |      |                |       |
|         | END  |                |       |

- (1) By specifying (size) only, each word area is initialized with value "00H".
- (2) Vector entry addresses are defined with the DW directive.

.

(3) This directive initializes a 2-word area with value "34127856".

.

1000H (LOW address)

1001H (HIGH address)

NOTE 3-2 With a word value, the HIGH (high-order) address of memory is initialized with the high-order 2 digits of the value and the LOW (low-order) address of memory is initialized with the low-order 2 digits of the value. Source module Memory Example: NAME SAMPLE CSEG ORG 1000H Lewender

3

1

4

2

Low-order 2 digits

High-order 2 digits

DW

÷

END

<u>1234</u>H

DS

#### (3) DS (define storage)

#### Description Format

| Symbol   | Mnemonic | Operand      | Comment    | 1       |
|----------|----------|--------------|------------|---------|
| field    | field    | <u>field</u> | field      | · . · · |
| [label:] | DS       | expression   | [;comment] |         |
|          |          |              |            |         |
| ·        |          |              | ·          |         |

#### Function

The DS directive reserves a memory area for the number of bytes specified in the Operand field.

#### <u>Use</u>

The DS directive is mainly used to reserve a memory (RAM) area to be used by a source program. If a label is specified, the value of the first address of the reserved memory area is assigned to the label. In the source module, this label is used for description to manipulate the memory.

- o The contents of an area reserved with this directive are unknown.
- o When describing a name or label as the operand of this directive, the name or label must be an absolute term which has already been defined in the source module.
- o If a label is specified in the Symbol field, the label will have the first address of the reserved area as its value.
- o If a value of 0 is given to the operand of this directive, no memory area will be reserved.
- o The DS directive cannot be described within a bit segment.

NAME SAMPLE DSEC TABLE1:DS 10 ; (1) WORK1 : DS 1 ; (2) ; (3) WORK2 : DS 2 CSEG MOVW HL, #TABLE1 : MOV A. WORK1 : MOVW BC, #WORK2 ÷ END

- (1) This directive reserves a 10-byte work area, but the contents of the area are unknown. Label "TABLE1" is assigned to the first address of the area.
- (2) This directive reserves a 1-byte work area.
- (3) This directive reserves a 2-byte work area.

define bit

Phase-out/Discontinued

DBIT

### (4) DBIT (define bit)

| Description                                                                                                     | Format |
|-----------------------------------------------------------------------------------------------------------------|--------|
| the second se |        |

| Symbol | Mnemonic     | Operand      | Comment    |
|--------|--------------|--------------|------------|
| field  | <u>field</u> | <u>field</u> | field      |
| [name] | DBIT         | None         | [;comment] |
|        |              |              |            |
| -      |              |              |            |

#### Function

The DBIT directive reserves a 1-bit memory area within a bit segment.

#### <u>Use</u>

The DBIT directive is used to reserve a bit area within a bit segment.

- o The DBIT directive is described only in a bit segment.
- o The contents of a 1-bit area reserved with this directive are unknown.
- o If a name is specified in the Symbol field, the name will have a bit address as its value. See Table 3-7 for the bit address map.

### Application\_Example

| ,    | NAME | SAMPLE   |       |
|------|------|----------|-------|
|      | BSEG |          |       |
| BIT1 | DBIT |          | ; (1) |
| BIT2 | DBIT |          | ; (1) |
| ВІТЗ | DBIT |          | ; (1) |
|      | CSEG |          |       |
|      | MOVI | CY.BIT1  | ; (2) |
|      | :    |          |       |
|      | ORI  | CY, BIT2 | ; (3) |
|      | :    |          | ·     |
|      | END  |          |       |
| L    |      |          |       |

- (1) These three DBIT directives reserve a 1-bit area and define names (BIT1, BIT2, and BIT3) each having a bit address.
- (2) This instruction corresponds to "MOV1 CY,saddr.bit" and describes name "BIT1" of the bit area reserved in (1) above as operand "saddr.bit".
- (3) This instruction corresponds to "OR1 CY,saddr.bit" and describes name BIT2 as "saddr.bit".

#### 3.5 Directives for Linkage

Linkage directives function to make clear the relation between the external definition of a symbol and its external reference. Let's consider a case where a program is created by being divided into two modules: Module 1 and Module 2. In Module 1, if you wish to reference a symbol defined in Module 2, the symbol cannot be use without declaration in each module. For this reason, some sort of signal or indication as "I want to use the symbol" and "You may use the symbol" is required between the two modules. In Module 1, the <u>external reference declaration</u> of a symbol must be made to indicate that a symbol defined in another module must be referenced. On the other hand, in Module 2, the <u>external</u> <u>definition declaration</u> of a symbol must be made to indicate that the symbol may be referenced in another module. The symbol can be referenced for the first time when the two external reference and external definition declarations are

Phase-out/Discontinued

effectively made.

Linkage directives function to establish this interrelationship and are available in the following types:

o To declare external reference of symbol: EXTRN and EXTBIT directives

o To declare external definition of symbol: PUBLIC directive

Fig. 3-6. Relationship of Symbols between Two Modules



3-46

In Module 1 in Fig. 3-6, the symbol "MDL2" defined in Module 2 is referenced in (2). Therefore, the symbol is declared as an external reference with the EXTRN directive in (1). In Module 2, the symbol "MDL2" to be referenced from Module 1 is declared as an external definition in (3). The linker checks whether or not this external reference of the symbol corresponds to the external definition of the symbol.

| XTRN         |                 | external                              | EX      | TRN |
|--------------|-----------------|---------------------------------------|---------|-----|
|              | ۲               | · · · · · · · · · · · · · · · · · · · |         |     |
| 1) EXTRN     | (external)      |                                       | • •     |     |
|              |                 | · · ·                                 |         |     |
| Descriptio   | <u>n Format</u> | •                                     | -       | •   |
|              |                 | <u>_</u>                              | ·       |     |
| Symbol       | Mnemonic        | Operand                               | Comment | •   |
| £1.13        | <u>field</u>    | field                                 | field   |     |
| <u>field</u> |                 |                                       |         |     |

#### Function

The EXTRN directive declares that the symbol described in the Operand field is to be referenced in this module. The specified symbol has been defined in another module.

#### <u>Use</u>

When referencing a symbol defined in another module, the EXTRN directive must be used to declare the symbol as an external reference.

- o The EXTRN directive must be described in the module header of a source module. (See Section 2.1, "Basic Configuration of Source Program".)
- o Two or more symbols may be specified in the Operand field by delimiting each symbol name with a comma (,).
- o When referencing a symbol having a bit value, the symbol must be declared as an external reference with the EXTBIT directive.
- o No macro name can be described as the operand of the EXTRN directive. (See Chapter 5, Macro for the macro name.)

## Application Example

| (Module  | 1>     |              |       | <module< th=""><th>2&gt;</th><th></th><th></th></module<> | 2>     |             |         |
|----------|--------|--------------|-------|-----------------------------------------------------------|--------|-------------|---------|
| <u> </u> | NAME S | SAMP1        |       |                                                           | NAME   | SAMP 2      |         |
|          | EXTRN  | SADRI, SADR2 | ; (1) | ļ                                                         | PUBLIC | SADR1.SADR2 | 2 ; (4) |
|          | CSEG   |              |       |                                                           | DSEG   |             |         |
|          | :      |              |       |                                                           | ORG    | 0 F E 2 0 H |         |
| • •      | MOV    | A. SADR1     | ; (2) | SADRI                                                     | DS     | 1           | ; (5)   |
|          | ÷      |              |       | SADR-2                                                    | DS     | 2           | ; (6)   |
|          | MOVW   | DE, #SADR2   | ; (3) |                                                           | :      |             |         |
|          | MOVW   | AX, (DE)     |       |                                                           |        |             |         |
|          | :      |              |       |                                                           |        |             |         |
|          | END    |              |       |                                                           | END    |             |         |

- (1) This directive declares symbols "SADR1" and "SADR2" to be referenced in (2) and (3), respectively, as external references.Two or more symbols may be described in the Operand field.
- (2) This instruction references symbol "SADR1".
- (3) This instruction references symbol "SADR2".
- (4) This directive declares symbols "SADR1" and "SADR2" as external definitions.
- (5) This directive defines symbol "SADR1".
- (6) This directive defines symbol "SADR2".

#### external bit

Phase-out/Discontinued

#### (2) EXTBIT (external bit)

| Descripti | lon Format                                                                                                     |
|-----------|----------------------------------------------------------------------------------------------------------------|
|           | the second s |

| Symbol       | Mnemonic     | Operand                   | Comment    |
|--------------|--------------|---------------------------|------------|
| <u>field</u> | <u>field</u> | field                     | field      |
| [label:]     | EXTBIT       | <pre>symbol name[,]</pre> | [;comment] |
|              |              |                           | ÷          |
| L            |              |                           |            |

#### Function

The EXTBIT directive declares that the symbol having a bit value, described in the Operand field is to be referenced in this module. The specified symbol has been defined in another module.

#### Use

When referencing a symbol having a bit value (saddr.bit) defined in another module, the EXTBIT directive must be used to declare the symbol as an external reference.

- o The EXTBIT directive must be described in the module header of a source module.
- o Two or more symbols may be specified in the Operand field by delimiting each symbol name with a comma (,).
- o Only the bit value of a symbol which can be represented in the operand format "saddr.bit" can be described as the operand of the EXTBIT directive.

Table 3-8. Bit Value That Can Be Described as Operand of EXTBIT

| Representation    | Description as operand of |  |  |
|-------------------|---------------------------|--|--|
| Format of operand | EXTBIT directive          |  |  |
| saddr.bit         | Allowed                   |  |  |
| sfr.bit           |                           |  |  |
| A.bit             | Not allowed               |  |  |
| X.bit             |                           |  |  |
| PSW.bit           |                           |  |  |

Application Example

| <module 1=""></module> |                 | <module< th=""><th>2&gt;</th><th><u> </u></th><th></th></module<> | 2>     | <u> </u>     |       |
|------------------------|-----------------|-------------------------------------------------------------------|--------|--------------|-------|
| NAME S.                | AMP1            |                                                                   | NAME   | SAMP 2       |       |
| EXTBIT F               | LAG1. FLAG2;(1) |                                                                   | PUBLIC | FLAGI, FLAG2 | ; (4) |
| CSEG                   |                 | FLAGI                                                             | EQU    | 0FE20H.0     | ; (5) |
| :                      |                 | FLAG2                                                             | EQU    | 0FE20H.1     | ; (6) |
| . MOA1 C.              | Y, FLAG1 ;(2)   | ļ                                                                 | CSEG   |              |       |
| :                      |                 |                                                                   | :      |              |       |
| OR1 CT                 | Y, FLAG2;(3)    | 1                                                                 |        |              |       |
| ÷                      |                 |                                                                   |        |              |       |
| END                    |                 |                                                                   | END    |              |       |

(1) This directive declares symbols "FLAG1" and "FLAG2" to be referenced in (2) and (3), respectively, as external references.

Two or more symbols may be described in the Operand field.

- (2) This instruction references symbol "FLAG1". This description corresponds to "MOV1 CY,saddr.bit".
- (3) This instruction references symbol "FLAG2". This description corresponds to "OR1 CY,saddr.bit".
- (4) This directive declares symbols "FLAG1" and "FLAG2" as external definitions.
- (5) This directive defines symbol "FLAG1".
- (6) This directive defines symbol "FLAG2".

| PUBLIC     |          | public                            | Phase-out/Di |
|------------|----------|-----------------------------------|--------------|
| (3) PUBLIC | (public) | · · · · · · · · · · · · · · · · · | · · · ·      |
| Descriptio | n Format |                                   |              |
| Symbol     | Mnemonic | Operand                           | Comment      |
| field      | field    | <u>field</u>                      | field        |
|            | PUBLIC   | <pre>symbol name[,]</pre>         | [;comment]   |

#### Function

The PUBLIC directive declares that the symbol described in the Operand field is a symbol to be referenced from another module.

#### <u>Use</u>

When defining a symbol to be referenced from another module, the PUBLIC directive must be used to declare the symbol as an external definition.

- o The PUBLIC directive must be described in the module header of a source module.
- o Two or more symbols may be specified in the Operand field by delimiting each symbol name with a comma (,).
- o Symbol(s) to be described in the Operand field must have been defined within the same source module.
- o The following symbols cannot be used as the operand of the PUBLIC directive:
  - . Name defined with the SET directive
  - . Symbol defined with the EXTRN directive within the same module
  - . Name with a bit value other than "saddr.bit"
    - . Segment name
    - . Module name
    - . Macro name

NOTE 3-3

External declaration of segment name or module name: Even if a segment name or module name is declared with the PUBLIC or EXTRN directive, no error will occur. However, this declaration becomes invalid and if these symbols are referenced, an error will result at linkage time.

#### Application Example

Example of program consisting of three modules

| < Mod      | ule 1> |               | < Mod  | ule 2> |               |       |
|------------|--------|---------------|--------|--------|---------------|-------|
|            | NAME   | SAMP1         |        | NAME   | SAMP 2        |       |
|            | PUBLIC | A1, A2 ;(1)   |        | PUBLIC | B 1           | ; (2) |
|            | EXTRN  | B1,C1         |        | EXTRN  | A 1           |       |
|            | د      |               |        | CSEG   |               |       |
| <b>A</b> 1 | EQU    |               | B1:    | :      |               |       |
| A 2        | EQU    | 0 FE 2 0 H. 1 |        | MOV    | C, #A1        |       |
|            |        |               |        | ÷      |               |       |
|            | CSEG   |               |        | END    |               |       |
|            | ł      |               | L      |        |               |       |
|            | BR     | 1 B 1         | < Modu | ule 3> |               |       |
| •          | :      |               | · ·    | NAME   | SAMP 3        |       |
|            | XORI   | CY, C1        |        | PUBLIC | C 1           | ; (3) |
|            | :      |               |        | EXTRN  | A 2           |       |
|            | END    |               | C 1    | EQU    | 0 F E 2 1 H . | 0     |
|            |        |               |        | CSEG   |               |       |
|            |        |               |        | ÷      |               |       |
|            |        |               |        | MOVI   | СҮ, А2        |       |
|            |        |               |        | :      |               |       |
|            |        |               |        |        |               |       |

(1) This directive declares that symbols "A1" and "A2" are to be referenced from other modules.

END

- (2) This directive declares that symbol "B1" is to be referenced from another module.
- (3) This directive declares that symbol "C1" is to be referenced from another module.

NAME

name

Phase-out/Discontinued

#### (4) NAME (name)

#### Description Format

| Symbol<br>field | Mnemonic<br>field | Operand<br>field | Comment<br>field |  |
|-----------------|-------------------|------------------|------------------|--|
| [label:]        | NAME              | module name[,]   | [;comment]       |  |
|                 |                   |                  |                  |  |

#### Function

The NAME directive gives (assigns) the module name described in the Operand field to an object module to be output by the assembler.

#### <u>Use</u>

A module name is required for symbolic debugging of an object module with a debugger.

- o The NAME directive must be described in the module header of a source module. (See Section 2.1, "Basic Configuration of Source program" in Chapter 2.)
- o For the conventions of module name description, see Subsection 2.2.3, "Symbol field" in Chapter 2.
- o No module name can be described as the operand of any directive other than NAME or of any instruction.
- o The NAME directive must be described for each source module. If this directive is omitted, an error will result.

-

## Application Example

÷ ·

.

| NAM | E SAMPLE | ;(1) |
|-----|----------|------|
| DSE | G        |      |
| :   |          |      |
| CSE | G        | ·    |
| :   |          |      |
| END |          |      |

(1) This directive declares module name "SAMPLE".

.

## 3.6 Directive for Automatic Selection of BR Instruction As the unconditional branch instructions of the uCOM-78K/I, which directly describe a branch destination address as their operand, two instructions "BR !addr16(addr13)" and "BR \$addr16(addr13)" are available.

Phase-out/Discontinued

The BR !addr16(addr13) instruction is a three-byte instruction which allows branching to any address, whereas the BR \$addr16 (addr13) instruction is a two-byte instruction which allows branching to an address within the range of -126 to +129 bytes from the current location counter value.

Therefore, to create a program with high memory utilization efficiency, the 2-byte instruction "BR \$addr16(addr13)" must be described according to the address range of the branch destination. However, it is quite troublesome to take this address range into account when you describe the branch instruction. For this reason, there was a need for a directive which directs the assembler to automatically select the two-byte or three-byte branch instruction according to the address range of the branch destination. The BR directive is provided for this purpose. However, note that this directive is valid only when the assembler option "OPTIMIZE" is specified. (For the OPTIMIZE option, see Subsection 4.4.4, "Description of each assembler option" in Chapter 4 of the RA78K/I Assembler Package User's Manual for Operation.)

branch

BR

(1) BR (branch)

| Descri | ption | Format |
|--------|-------|--------|
|        |       |        |

| Symbol   | Mnemonic     | Operand    | Comment      |
|----------|--------------|------------|--------------|
| field    | <u>field</u> | field      | <u>field</u> |
| [label:] | BR           | expression | [;comment]   |
|          |              |            |              |
|          |              |            |              |

## Function

The BR directive causes the assembler to automatically select the 2-byte or 3-byte branch instruction according to the value range of the expression specified in the Operand field and to generate the object code applicable to the selected instruction. This function is referred to as "optimization of branch instructions".

The Optimize function is valid only when the assembler option "OPTIMIZE" is specified.

## <u>Use</u>

o If the branch destination is within the range of -126 to +129 bytes from the current location counter, you can describe the 2-byte branch instruction "BR \$addr16(addr13)". With this instruction, required memory space can be reduced by one byte as compared with that when using the 3-byte branch instruction. To create a program with high memory utilization efficiency, the 2-byte branch instruction should be used positively. However, each time you describe a branch instruction, it is troublesome for you to take into account the address range of the branch destination. So, use the BR directive when you are not sure of whether or not the the 2-byte branch instruction can be described. o If it is definite that you can describe the 2-byte or 3-byte branch instruction, describe the applicable branch instruction. In this case, the assembly time can be shortened as compared with that when the BR directive is described.

- o If the assembler option "OPTIMIZE" is specified, the assembler performs the following processes for the BR directive. In the following explanation, the term "expression" refers to the expression described in the Operand field.
  - (a) When BR directive is described within a relocatable segment
    - If the expression is a label within the same segment, the optimization phase is executed.
    - If the expression is a label within another segment or an externally referenced term, the object code of the 3-byte branch instruction is generated.
    - If the relocation attribute of the expression is an absolute term, the object code of the 3-byte branch instruction is generated.
  - (b) When BR directive is described within an absolute segment
    - If the relocation attribute of the expression is an absolute term, the optimize phase is executed.
    - If the relocation attribute of the expression is a relocatable term or externally referenced term, the object code of the 3-byte branch instruction is generated.

.Table 3-9. Optimization Conditions of BR Directive

| $\sum$             | Jump condition<br>(source)    | Absolute<br>segment |           | Relocat   |           |
|--------------------|-------------------------------|---------------------|-----------|-----------|-----------|
| Jump<br>condit     | Reference<br>ion<br>nation)   | Backward            | Forward   | Backward  | Forward   |
|                    | c value                       | Optimize            | Optimize  | 3-byte BR | 3-byte BR |
|                    | symbol<br>bute: NUMBER)       | Optimize            | Optimize  | 3-byte BR | 3-byte BR |
| Label              | Same_segment                  | Optimize            | Optimize  | Optimize  | Optimize  |
|                    | Same named<br>segment         | Optimize            | Optimize  | Optimize  | Optimize  |
|                    | Other segment<br>(same type)  | Optimize            | Optimize  | -         | -         |
|                    | Other segment<br>(Other type) | 3-byte BR           | 3-byte BR | 3-byte BR | 3-byte BR |
| External reference |                               | 3-byte BR           |           | 3-byte BR | -         |
| Locati             | on counter (\$)               | Optimize            | _         | Optimize  |           |

- NOTE: o "-" in the table indicates that the combination is prohibited.
  - o "Backward" reference denotes the reference of a symbol which has already been defined in the source module.
  - o "Forward" reference denotes the reference of a symbol which is to be defined in a subsequent line.
- o If the assembler option "OPTIMIZE" is omitted, the assembler generates the object code of the 3-byte branch instruction for all BR directives in the source module.
- o "\$" indicating the current location counter cannot be specified as the operand of the BR directive.

## Application Example



- (1) This BR directive will be optimized. If displacement between the line (1) and the "L1:" label definition is within -126 bytes, the object code of the 2-byte branch instruction will be generated.
- (2) This BR directive will be substituted with the 3-byte branch instruction, because it branches to a label in another segment.
- (3) This BR directive will be optimized.
  - If displacement between the line (3) and the "L2:" label definition is within -126 bytes, the object code of the 2-byte branch instruction will generated.
- (4) Because the relocation attribute of "L1" described as the operand of this BR directive is a relocatable term, the object code of the 3-byte branch instruction will be generated.

## 3.7 Macro Directives

When you describe a source program, it is troublesome for you to describe a series of frequently used instruction groups over and over again, and this may cause an increase in the number of description or coding errors.

By using the macro function with macro directives, the need to repeatedly describe the same group of instructions can be eliminated, thereby increasing coding efficiency of the program. The basic function of a macro is the substitution of a series of statements with a name. For details of the macro function, see Chapter 5, Macros.

Macro directives include MACRO, LOCAL, REPT, IRP, EXITM, and ENDM.

In this section, each of these directives is detailed.

macro

Phase-out/Discontinued

(1) MACRO (macro)

## Description Format

| Symbol       | Mnemonic | Operand | • • •                    | Comment        |
|--------------|----------|---------|--------------------------|----------------|
| <u>field</u> | field    | field   |                          | • <u>field</u> |
| macro name   | MACRO    | [formal | <pre>parameter[,]]</pre> | [;comment]     |
|              | 2        |         |                          | · · · ·        |
|              | ENDM     |         |                          |                |
|              |          |         |                          |                |

## Function

The MACRO directive executes a macrodefinition by assigning the macro name specified in the Symbol field to a series of statements (called a macro body) described between this directive and the ENDM directive.

#### <u>Use</u>

Define a series of frequently used statements in the source program with a macro name. After the macrodefinition, you only need to describe the defined macro name (for macro reference) and the macro body corresponding to the macro name will be expanded.

- o For the macro name to be described in the Symbol field, see the conventions of symbol description in Subsection 2.2.3, "Symbol field" in Chapter 2.
- o To reference a macro, describe the defined macro name in the Mnemonic field. (See Application Example.)
- o For the formal parameter(s) to be described in the Operand field, the same rules as the conventions of symbol description will apply.
- o Description of formal parameter(s) within a macro body is limited to the part of the Operand field where constant(s) are to be described.
- o Formal parameters are valid only within a macro body.

- o Because formal parameters are handled as symbols, the same named parameters cannot be described within the same source module.
- o A name or label defined within a macro body must be declared as a local symbol with the LOCAL directive.
- o Nesting of macros (i.e., to refer to other macros within a macro body) is allowed up to eight levels.
- o Up to 10 macros can be defined within a single source module.

## Application Example

|    | :     | NAME  | SAMP                                  |       |            |
|----|-------|-------|---------------------------------------|-------|------------|
|    | ADMAC | MACRO | PARAI, PARA2                          | ; (1) |            |
| Π  |       | MOV   | A, #PARA1                             |       |            |
|    |       | ADD   | A, $\#$ PARA 2                        |       | Macro body |
|    |       | ENDM  | · · · · · · · · · · · · · · · · · · · | ; (2) |            |
|    |       | :     |                                       |       |            |
|    |       | END   |                                       |       |            |
| L. |       |       |                                       |       |            |

- (1) A macro is defined with macro name "ADMAC" and two formal parameters "PARA1" and "PARA2" specified.
- (2) This directive indicates the end of the macrodefinition.

| LOCAL      | 2        | local                                                                              | LOCAL      |
|------------|----------|------------------------------------------------------------------------------------|------------|
| 2) LOCAL   | (local)  | ، بوجن دیرونی میں دی میں دی میں دور دی میں اور |            |
| Descriptio | n Format |                                                                                    |            |
| Symbol     | Mnemonic | Operand                                                                            | Comment    |
| field      | field    | <u>field</u>                                                                       | field      |
| [label:]   | LOCAL    | <pre>symbol name[,]</pre>                                                          | [;comment] |

Blooptinu

## Function

The LOCAL directive declares that the symbol name specified in the Operand field is a local symbol which is valid only within the macro body.

## <u>Use</u>

Use the LOCAL directive if you wish to reference a macro defining symbol(s) within its body more than once.

- o If a symbol is defined within a macro body and the macro is referenced more than once, it means that the symbol would be defined more than once in the source module. For this reason, it is necessary to declare that the symbol is a local symbol which is valid only within the macro.
- o The LOCAL directive can be used only within a macrodefinition.
- o The LOCAL directive must be described before the symbol specified in the Symbol field is defined. (In other words, the directive must be described at the beginning of the macro body.)
- o Symbol names to be defined with the LOCAL directive within a single source module must be all different. (In other words, the same name cannot be used for local symbols to be used in each source module.)
- o Up to 15 symbol names can be specified in the Operand field.

o Symbols defined with the LOCAL directive cannot be called (referenced) from outside the macro.

## Application Example

|    | <source< th=""><th>program&gt;</th><th></th><th><u></u></th><th>-</th></source<> | program> |         | <u></u> | -                   |
|----|----------------------------------------------------------------------------------|----------|---------|---------|---------------------|
| -  |                                                                                  | NAME     | SAMPLE  |         |                     |
| MA | C 1                                                                              | MACRO    |         |         |                     |
|    |                                                                                  | LOCAL    | LLAB    | ;(1)    |                     |
| LL | LAB:                                                                             | :        |         |         | Macrodefinition     |
|    |                                                                                  | BR       | \$ LLAB | ; (2)   |                     |
|    |                                                                                  | ENDM     |         |         |                     |
|    |                                                                                  |          |         |         |                     |
| RE | CF1:                                                                             | MAC1     |         | ; (3)   |                     |
|    |                                                                                  | ÷        |         |         |                     |
|    |                                                                                  | BR       | I LLA B | ; (4)   | This description is |
|    |                                                                                  | ;        |         |         | erroneous.          |
| RE | F2:                                                                              | MAC 1    |         | ; (5)   |                     |
|    |                                                                                  | :        |         |         |                     |
|    |                                                                                  | END      |         |         |                     |

- This directive defines symbol name "LLAB" as a local symbol.
- (2) This instruction references local symbol "LLAB" within macro MAC1.
- (3) This directive references macro MAC1.
- (4) Because local symbol "LLAB" is referenced outside the definition of macro MAC1, this description causes an error.
- (5) This directive references macro MAC1.

If the source program in the above example is assembled, macroexpansion (replacement of a macrocall with the body itself) occurs as shown below.

|       | NAME  | SAMPLE  |                                |
|-------|-------|---------|--------------------------------|
| MAC1  | MACRO |         |                                |
|       | LOCAL | LLAB    |                                |
| LLAB: | :     |         | Macrodefinition                |
|       | BR    | \$ LLAB |                                |
|       | ENDM  |         |                                |
|       | :     |         |                                |
| REF1: | MAC 1 |         |                                |
|       | LOCAL | LLA B   |                                |
| LLAB: | ÷     |         | Macroexpansion                 |
|       | BR    | \$ LLAB |                                |
|       | :     |         |                                |
|       | BR    | ! LLAB  | This description is erroneous. |
|       | :     | . ·     | erroneous.                     |
| REF2: | MAC 1 |         |                                |
|       | LOCAL | LLAB    |                                |
| LLAB: | :     |         | Macroexpansion                 |
|       | BR    | \$LLAB  |                                |
|       | :     |         |                                |
|       | END   |         |                                |

repeat

(3) REPT (repeat)

## Description Format

| Symbol   | Mnemonic     | Operand      | Comment    |
|----------|--------------|--------------|------------|
| field    | field        | <u>field</u> | field      |
| [label:] | REPT<br>ENDM | expression   | [;comment] |
|          |              |              |            |

## Function

The REPT directive causes the assembler to repeatedly expand a series of statements described between this directive and the ENDM directive (called the REPT-ENDM block) the number of times equivalent to the value of the expression specified in the Operand field.

## <u>Use</u>

If a series of statements is to be described repeatedly in a source program, use the REPT and ENDM directives.

- o If a name or label is to be described as the operand of the REPT directive, the name or label must be an absolute term which has already been defined in the source module.
- o In the REPT-ENDM block, none of the MACRO, REPT, IRP, and ENDM directives can be described. In other words, nesting of macros is not allowed within the REPT-ENDM block.
- o If the EXITM directive is described in the REPT-ENDM block, subsequent expansion of the REPT-ENDM block by the assembler will be terminated. (See (5), EXITM directive.)



- (1) This directive instructs the assembler to expand the REPT-ENDM block three consecutive times.
- (2) This directive indicates the end of the REPT-ENDM block.

When the above source program is assembled, the REPT-ENDM block is expanded as shown in the following assembly list:

| <pre></pre> |        |  |
|-------------|--------|--|
| NAME        | SAMP 1 |  |
|             |        |  |
| CSEG.       |        |  |
| <br>:       |        |  |
| INC         | В      |  |
| DEC         | С      |  |
| INC         | В      |  |
| DEC         | с      |  |
| INC         | В      |  |
| DEC         | С      |  |
| :           |        |  |
| END         |        |  |

You can see that the REPT-ENDM block defined by statements (1) and (2) has been expanded three times. On the assembly list, the definition statements (1) and (2) by the REPT directive in the source module will not be displayed.



- (1) This directive instructs the assembler to expand the REPT-ENDM block three consecutive times.
- (2) This directive instructs the expansion of the REPT-ENDM block again within the REPT-ENDM block. This description is incorrect, because nesting of macros is not allowed within the REPT-ENDM block.

## (4) IRP (indefinite repeat)

## Description Format

| Symbol   | Mnemonic         | Operand                                                        | Comment    |
|----------|------------------|----------------------------------------------------------------|------------|
| field    | _field           | field                                                          | field      |
| [label:] | IRP<br>S<br>ENDM | <pre>formal parameter, <actual parameter[,]=""></actual></pre> | [;comment] |

## Function

The IRP directive causes the assembler to repeatedly expand a series of statements described between this directive and the ENDM directive (called the IRP-ENDM block) the number of times equivalent to the number of actual parameters while replacing the formal parameter with the actual parameters specified in the Operand field (in sequence from left to right).

## <u>Use</u>

If a series of statements, only part of which becomes variables is to be described repeatedly in a source program, use the IRP and ENDM directives.

## **Explanation**

- o Up to 13 actual parameters may be described in the Operand field.
- o A numeric value, name, or label can be described as an actual parameter. However, no expression can be described.
- o In the IRP-ENDM block, none of the MACRO, REPT, IRP, and ENDM directives can be described. In other words, nesting of macros is not allowed within the IRP-ENDM block. If the EXITM directive is described within the IRP-ENDM block, the expansion of the IRP-ENDM block subsequent to the EXITM directive will be terminated.

3-70

NOTE 3-4

If a symbol which has the same name as the formal parameter of the IRP directive is described as a name or label within the same IRP-ENDM block, no error will occur. However, its object code will become invalid. Therefore, take care not to define any symbol having the same name as the formal parameter.

## Application Example

|   | <source program=""/> |                     |       |                |
|---|----------------------|---------------------|-------|----------------|
|   | NAME                 | SAMP 1              |       |                |
| ; | CSEG                 |                     |       |                |
|   | :                    |                     |       |                |
|   | IRP                  | PARA, <0AH.0BH.0CH> | ;(1)  |                |
|   | ADD                  | A, #PARA            |       | IRP-ENDM block |
|   | MOV                  | (DE+), A            |       |                |
|   | ENDM                 |                     | ; (2) |                |
|   | :                    |                     |       |                |
|   | END                  |                     |       |                |

- (1) The formal parameter is "PARA" and the actual parameters are the following three: "OAH", "OBH", and "OCH". This directive instructs the assembler to expand the IRP-ENDM block three times (i.e., the number of actual parameters) while replacing the formal parameter "PARA" with the actual parameters "OAH", "OBH" and "OCH".
- (2) This directive indicates the end of the IRP-ENDM block.

When the above source program is assembled, the IRP-ENDM block is expanded as shown in the following assembly list:

<Assembly list>

| NAME | SAMP 1   | -     |
|------|----------|-------|
| CSEG |          |       |
|      |          |       |
| ADD  | A, #PARA | ; (8) |
| моv  | (DE+), A |       |
| ADD  | A, #PARA | ; (4) |
| MOV  | (DE+), A |       |
| ADD  | A, #PARA | ; (5) |
| MOV  | (DE+), A |       |
| :    |          |       |
| END  |          |       |

You can see that the IRP-ENDM block defined by statements (1) and (2) has been expanded three times (equivalent to the number of actual parameters).

On the assembly list in this case, the formal parameters within the IRP-ENDM block are not replaced with the actual parameters. However, in object code generation, the formal parameters are replaced with the actual parameters in sequence from left to right.

(Object code)

(3) ADD A, #PARA  $\rightarrow$  A8<u>OA</u>

- (4) ADD A, # PARA  $\rightarrow$  A80B
- (5) ADD A, # PARA  $\rightarrow$  A8<u>0C</u>

## (5) EXITM (exit from macro)

## Description Format

| Symbol   | Mnemonic | Operand | Comment    |
|----------|----------|---------|------------|
| field    | field    | field   | field      |
| [label:] | EXIT     | None    | [;comment] |
|          |          |         |            |
|          |          |         |            |

#### Function

- o The EXITM directive terminates by force the expansion of the macro body defined by the MACRO directive.
- o If the EXITM directive is described in the REPT-ENDM or IRP-ENDM block, the directive terminates by force the definition (expansion) of the block. (The REPT or IRP directive becomes invalid.)

#### <u>Use</u>

- o This function is mainly used when a conditional assembly function (see Section 4.4, Conditional Assembly Control Instructions) is used in the macro body defined with the MACRO directive.
- o If conditional assembly functions are used in combination within the macro body, part of the source program which must not be assembled is likely to be assembled unless control is returned from the macro by force with the EXITM directive. In such a case, the EXITM directive must be used.

#### **Explanation**

If the EXITM directive is described in a macro body, instructions up to the ENDM directive are stored as the macro body.

The EXITM directive indicates the end of a macro only during the macroexpansion.

## Application Example

o In the example here, conditional assembly control instructions are used. See Section 4.4, Chapter 4 for the conditional assembly control instructions.

Phase-out/Discontinued

• . '

•

o See Chapter 5, Macros for the macro body and macro-

|      | NAME     | SAMP 1    |        |                |
|------|----------|-----------|--------|----------------|
| MAC1 | MACRO    |           | ; (1)  | _              |
|      | NOT 1    | A.1       |        | Macro body     |
| S    | IF(SW1)  |           | ; (2)  |                |
|      | ВТ       | A.1. \$L1 |        | IF block       |
|      | EXITM    | · .       | ; (3)  |                |
| S    | ELSE     |           | ; (4)  |                |
|      | MOV 1    | СҮ. А.1   |        | ELSE block     |
|      | MOV      | A. #0     |        |                |
| \$   | ENDIF    |           | ; (5)  |                |
| \$   | IF(SW2)  |           | ; (6)  | 1              |
|      | MOV      | A,[D]     |        | IF block       |
| \$   | ELȘE     |           | ; (7)  |                |
|      | MOV      | A,[E]     |        | ELSE block     |
| \$   | ENDIF    |           | ; (8)  |                |
|      | ENDM     |           | ; (9)  |                |
|      | CSEG     |           |        |                |
| \$   | SET(SW1) |           | ; 00 - |                |
|      | MAC 1    |           | ; 00   | Macro referenc |
|      | NOP      |           |        |                |
| L1:  | NOP      |           |        |                |
|      | END      | -         |        |                |

<Source program>

- (1) The macro "MAC1" uses conditional assembly functions (2) and (4) through (8) within the macro body.
- (2) This instruction defines an IF block for conditional assembly. If switch name "SW1" is true (OFFH), the IF block will be assembled.



- (3) This directive terminates by force the expansion of the macro body in (4) and thereafter. If this EXITM directive is omitted, the assembler proceeds to the assembly process in (6) and thereafter when the macro is expanded.
- (4) This instruction defines an ELSE block for conditional assembly. If switch name "SW1" is false (00H), the ELSE block will be assembled.
- (5) This instruction indicates the end of the conditional assembly.
- (6) This instruction defines another IF block for conditional assembly. If switch name "SW2" is true (OFFH), the IF block following this will be assembled.
- (7) This instruction defines another ELSE block for conditional assembly. If switch name "SW2" is false (00H), the ELSE block will be assembled.
- (8) This instruction indicates the end of the conditional assembly processes in (6) and (7).
- (9) This directive indicates the end of the macro body.
- (10) This SET control instruction gives true value (OFFH) to switch name "SW1" and sets the condition of the conditional assembly.
- (11) This instruction references macro "MAC1".

When the source program in the above example is assembled, macroexpansion occurs as shown below.



By the macro reference in (11), the macro body of macro "MAC1" has been expanded. Because true value (OFFH) is set in switch name "SW1" in (10), the first IF block in the macro body is assembled. Because the EXITM directive is described at the end of the IF block, the subsequent macroexpansion is not executed. end macro

Phase-out/Discontinued

ENDM

## (6) ENDM (end macro)

| Desci | ript: | ion | Format |
|-------|-------|-----|--------|
|       |       |     |        |

| Symbol<br>field | Mnemonic<br>field | Operand<br><u>field</u> | Comment<br><u>field</u> |
|-----------------|-------------------|-------------------------|-------------------------|
| None            | ENDM              | None                    | [;comment]              |
|                 |                   |                         |                         |

## Function

The ENDM directive instructs the assembler to terminate the execution of a series of statements defined as the functions of the macro.

#### <u>Use</u>

The ENDM directive must always be described at the end of a series of statements following the MACRO, REPT, or IRP directive.

- o A series of statements described between the MACRO directive and ENDM directive becomes a macro body.
- o A series of statements described between the REPT directive and ENDM directive becomes an REPT-ENDM block.
- o A series of statements described between the IRP directive and ENDM directive becomes an IRP-ENDM block.

## Application Examples

Example 1

|       | NAME  | SAMP 1       |
|-------|-------|--------------|
| ADMAC | MACRO | PARA1, PARA2 |
|       | моч   | A, #PARA1    |
|       | ADD   | A, #PARA2    |
|       | ENDM  |              |
|       | :     |              |
|       | END   | ```          |







3.8 Directive for Assembly Termination The assembly termination directive (END) informs the assembler of the end of a source module. This assembly termination directive must always be described at the end of each source module. The assembler processes a series of statements up to the assembly termination directive as a source module. Therefore, if the END directive is described before the ENDM directive in the REPT-ENDM or IRP-ENDM block, the REPT or IRP block becomes invalid.

END

end

(1) END (end)

## Description Format

| Symbol<br>field | Mnemonic<br>field | Operand<br>field | Comment<br>field |
|-----------------|-------------------|------------------|------------------|
| None            | END               | None             | [;comment]       |
| L               |                   |                  |                  |

## Function

The END directive indicates to the assembler the end of a source module.

## <u>Use</u>

The END directive must always be described at the end of each source module.

## **Explanation**

- o The assembler continues to assemble a source module until the END directive appears in the source module. Therefore, the END directive is required at the end of each source module.
- o Always input a carriage return (CR) or line feed code (LF) code immediately after the END directive.

## Application Example

| NAME     | SAMPLE |   |
|----------|--------|---|
| DSEG     |        |   |
| :        |        |   |
| CSEG     |        |   |
| <b>:</b> |        |   |
| END      | ; (1)  |   |
| <br>     |        | _ |

 Always describe the END directive at the end of each source module.



CHAPTER 4. CONTROL INSTRUCTIONS

4.1 Overview of Control Instructions

Control instructions are described in a source program and are used to provide particular instructions on the assembler operation. These instructions are not subject to object code generation.

Control instructions are available in the following three types:

Table 4-1 List of Control Instructions

| No. | Type of control instruction | Control instruction     |
|-----|-----------------------------|-------------------------|
| 1   | Instruction to control      | INCLUDE                 |
|     | INCLUDE file                |                         |
| 2   | Instructions to control     | EJECT, NOLIST, LIST,    |
|     | assembly list               | SUBTITLE                |
| 3   | Instructions to control     | SET, RESET              |
|     | conditional assembly        | IF, ELSEIF, ELSE, ENDIF |

Control instructions are described in a source program just the same as directives. However, "\$" (dollar sign) must be described in the 1st column of the source statement.

\$ [one blank or TAB] Control instruction

1st column

Of the control instructions listed in Table 4-1, the following instructions can also be specified as assembler options in the start-up command line of the assembler:

O NOLIST, LIST, SUBTITLE O SET, RESET

For the method of specifying assembler options in the command line, see Subsection 4.3.1, "Starting up the assembler", Chapter 4 in the RA78K/I Assembler Package User's Manual for Operation.



4.2 INCLUDE control instruction

The INCLUDE control instruction is used to include another module file in a source module.

By making the most of this control instruction, you may save your time and labor in describing a source program.

This control instruction is detailed on the next page.

include

Phase-out/Discontinued

## (1) INCLUDE (include)

## Description Format

\$[△]INCLUDE (filename)
\$[△]IC (filename)

; Abbreviated format

1st column

#### Function

The INCLUDE control instruction inserts the contents of the file specified by "filename" into the source program for assembly.

## <u>Use</u>

A relative large group of statements which may be shared by two or more source modules should be combined into a single file as an INCLUDE file. If the group of statements must be used in each source module, specify the filename of the required INCLUDE file with the INCLUDE control instruction. With this instruction, your time and effort in describing the source modules can be greatly reduced.

- o When describing the INCLUDE control instruction, "\$" must be described in the 1st column of the source statement. If you wish to provide a space between "\$" and "INCLUDE", input only one BLANK or TAB character.
- o When specifying a filename, the drive name or directory name in which the INCLUDE file is stored can be specified. If neither drive name nor directory name is specified, the drive or directory in which the source module file is stored is assumed to have been specified.
- o Nesting of INCLUDE files is allowed only for one level. (The term "nesting" refers to the specification of one or more other INCLUDE files in an INCLUDE file.)

o The END directive need not be described in an INCLUDE file.

## Application Example

| < Sour | ce program> |                  |
|--------|-------------|------------------|
| [      | NAME        | SAMPLE           |
|        | EXTRN       | L1. L2           |
| ]      | PUBLIC      | L 3              |
| \$     | INCLUD      | E(EQU. INC) ;(1) |
|        | CSEG        |                  |
|        | ÷           |                  |
|        | END         |                  |

| file EQ | U.INC>          |
|---------|-----------------|
| EQU     | 1 0 H           |
| EQU     | -20H            |
| :       |                 |
| EQU     | 100H            |
|         | EQU<br>EQU<br>: |

(1) This control instruction specifies "EQU.INC" as the INCLUDE file. When this source program is assembled, the contents of the INCLUDE file will be expanded as follows:

| · · · · |        |             | —i    |
|---------|--------|-------------|-------|
|         | NAME   | SAMPLE      |       |
|         | EXTRN  | L1, L2      |       |
|         | PUBLIĊ | L 3         |       |
| \$      | INCLUD | E(EQU. INC) | ; (1) |
| SYMA    | EQU    | 10H         |       |
| SYMB    | EQU    | 20H         |       |
|         | :      |             |       |
| SYMZ    | EQU    | 100H        |       |
|         |        |             |       |
|         | CSEG   |             |       |
|         | ÷      |             |       |
|         | END    |             |       |
| Li      |        |             |       |

The contents of INCLUDE file "EQU.INC" have been expanded.

4.3 Assembly List Control Instructions

These control instructions are used to control the output format of an assembly list such as page ejection, suppression of list output, and subtitle output.

Assembly list control instructions include EJECT, NOLIST, LIST, and SUBTITLE. Each of these control instructions is explained on the following pages. eject

## (1) EJECT (eject)

## Description Format

\$ [△ ] EJECT \$ [△ ] EJ

; Abbreviated format

1st column

## Function

The EJECT control instruction causes the assembler to execute page ejection of an assembly list.

## <u>Use</u>

Describe the EJECT control instruction in a line of the source module at which the page ejection of the assembly list is required.

## **Explanation**

- o When describing the EJECT control instruction, "\$" must be described in the 1st column of the source statement. If you wish to provide a space between "\$" and "EJECT", input only one BLANK or TAB character.
- o The image (i.e., \$ EJECT) of the EJECT control instruction itself will be printed at the top of the page after the page ejection.
- o If any of the following constructions or assembler options has already been specified, the EJECT control instruction will become invalid.

NOLIST, NOPRINT, NOPAGING

(For the NOPRINT and NOPAGING options, see Subsection 4.4.4, "Description of each assembler option", in Chapter 4 of the RA78K/I Assembler Package User's Manual for Operation.)

## Application Example

| <sour< th=""><th>ce module&gt;</th><th></th><th></th></sour<> | ce module> |          |       |
|---------------------------------------------------------------|------------|----------|-------|
|                                                               | :          |          |       |
|                                                               | MOV        | (DE+), A |       |
|                                                               | BR         | \$ S     |       |
| s                                                             | EJECT      |          | ; (1) |
|                                                               | CSEG       |          |       |
|                                                               | :          |          |       |
|                                                               | END        |          |       |

(1) When page ejection is executed with the EJECT control instruction, the assembly list will look like this.

| :           | ······································ |                     |
|-------------|----------------------------------------|---------------------|
| моv         | (E+),A                                 |                     |
| BR          | \$\$                                   |                     |
| <br>        | · · · · · · · · · · · · · · · · · · ·  | ————↓← Page ejectic |
| \$<br>EJECT | <b>N</b>                               |                     |
| CSEC        |                                        | 4                   |
| ÷           |                                        | · .                 |
| END         |                                        | -                   |
|             |                                        |                     |

NOLIST

Phase-out/Discontinued

## (2) NOLIST (no list)

#### Description Format

| \$[△]NOLIST<br>\$[△]NOLI<br>↑ | ; Abbreviated format |
|-------------------------------|----------------------|
| 1st column                    | · · · ·              |

Function

The NOLIST control instruction indicates to the assembler the line at which assembly list output must be suppressed. All source statements described after the NOLIST control instruction specification until the LIST control instruction appears in the source program will be assembled but will not be output on the assembly list.

#### <u>Use</u>

Use the NOLIST control instruction to merely control the amount of list output.

- o When describing the NOLIST control instruction, "\$" must be described in the 1st column of the source statement. If you wish to provide a space between "\$" and "NOLIST", input only one BLANK or TAB character.
- o The NOLIST control instruction functions to suppress assembly list output and is not intended to stop the assembly process.
- o If the LIST control instruction is specified after the NOLIST control instruction, statements described after the LIST control instruction will be output again on the assembly list.
- o The NOLIST control instruction can also be described as an assembler option in the start-up command line of the assembler.

## Application Example

|        | NAME     | SAMP 1 |       | · · ·                                                                  |
|--------|----------|--------|-------|------------------------------------------------------------------------|
| S      | NOLIST   |        | ; (1) |                                                                        |
| DATAI  | EQU      | 10H    |       |                                                                        |
| DATA 2 | EQU<br>: | 11H    |       | Statements in this part<br>will not be output on the<br>assembly list. |
| DATAX  | EQU      | 20H    |       |                                                                        |
| \$     | LIST     |        | ; (2) |                                                                        |
|        | CSEG     |        |       |                                                                        |
|        | :        |        |       |                                                                        |
|        | END      |        |       |                                                                        |

- (1) Because the NOLIST control instruction is specified here, statements after "\$ NOLIST" and up to the LIST control instruction in (2) will not be output on the assembly list. The image of the NOLIST control instruction itself will not be output on the list too.
- (2) Because the LIST control instruction is specified here, statements after this control instruction will be output again on the assembly list. The image of the LIST control instruction will also be output on the list.

list

## (3) LIST (list)

## Description Format

| \$[_]LIST<br>\$[_]LI | ; Abbreviated format |
|----------------------|----------------------|
| 1st column           |                      |

## Function

The LIST control instruction indicates to the assembler the line at which assembly list output must be started.

#### <u>Use</u>

Use the LIST control instruction to release the suppression of the assembly list output specified by the NOLIST control instruction and to output the assembly list again. By using the LIST control instruction in combination with the NOLIST control instruction in a source program, the output amount or contents of the assembly list can be controlled.

- o When describing the LIST control instruction, "\$" must be described in the 1st column of the source statement. If you wish to provide a space between "\$" and "LIST", input only one BLANK or TAB character.
- o If the LIST control instruction is specified after the NOLIST control instruction, statements described after the LIST control instruction will be output again on the assembly list. The image of the LIST control instruction itself will also be printed on the assembly list.
- o The LIST control instruction can also be described as an assembler option in the start-up command line of the assembler.

## Application Example

. .

See the Application Example of the NOLIST control instruction.

.

SUBTITLE

subtitle

SUBTITLE

## (4) SUBTITLE (subtitle)

## Description Format

\$[△]SUBTITLE('character string')
\$[△]ST('character string')

; Abbreviated format

1st column

#### Function

The SUBTITLE control instruction specifies the character string to be printed on the SUBTITLE section at each page header of an assembly list.

## <u>Use</u>

Use the SUBTITLE control instruction to print a subtitle on each page of an assembly so that the contents of the assembly list can be readily identified. The character string of a subtitle may be changed for each page.

- o When describing the SUBTITLE control instruction, "\$" must be described in the 1st column of the source statement. If you wish to provide a space between "\$" and "SUBTITLE", input only one BLANK or TAB character.
- o Up to 60 characters can be specified as the character string of a subtitle.
- o Description of a character string in excess of 61 characters as a subtitle will result in an error. However, the first 60 characters of the character string will be accepted as valid.
- o The character string specified with the SUBTITLE control instruction will be printed in the SUBTITLE section on the 2nd page of the assembly list.

- . o If the SUBTITLE control instruction is omitted, the SUBTITLE section on each page will be left blank.
  - o This control instruction can also be specified as an assembler option in the start-up command line of the assembler.

### Note

When the SUBTITLE control instruction is to be specified as an assembler option in the start-up command line of the assembler, pay attention to the following points:

- o The character string to be specified as a subtitle need not be enclosed in a pair of single quotation marks. With the MS-DOS or PC-DOS based system, an error will result if the character string is enclosed in a pair of single quotation marks.
- o No Blank characters can be used as the character string.
- o If more than 60 characters are specified as the character string, an error will result and the program execution will be aborted.

### Application Example

```
<Source module>
```

|          | NAME SAMP                                         |
|----------|---------------------------------------------------|
|          | CSEG                                              |
| s<br>5   | SUBTITLE('THIS IS SUBTITLE 1') ;(1)<br>EJECT ;(2) |
|          | CSEG                                              |
| \$<br>\$ | SUBTITLE('THIS IS SUBTITLE 2') ;(3)<br>EJECT ;(4) |
|          | CSEG                                              |
|          | END                                               |
|          |                                                   |
|          |                                                   |

- (1) This control instruction specifies character string "THIS IS SUBTITLE 1".
- (2) This control instruction indicates page ejection.
- (3) This control instruction specifies character string "THIS IS SUBTITLE 2".
- (4) This control instruction indicates page ejection.



When the source program in the above example is assembled, the assembly list will look like this.

| Copyright (C) 1986 NEC Corpo<br>UCOM-78K/1 ASSEMBLER VX. X<br>SOURCE FILE: TEXT. ASM | ration   |                                |      | DATE | PAGE | 1 |                                                                 |
|--------------------------------------------------------------------------------------|----------|--------------------------------|------|------|------|---|-----------------------------------------------------------------|
| OBJECT FILEI TEXT. REL<br>COMMAND I RATEKI TEXT. ASM                                 | PROCE 55 | OR(112)                        |      |      |      |   |                                                                 |
| ASSEMBLE LIST                                                                        |          |                                |      |      |      |   |                                                                 |
| STNÓ ADRS R ÓBJECT M I                                                               | SOURCE   | STATEMENT                      |      |      |      |   |                                                                 |
| 1                                                                                    |          | NAME SAMP                      |      |      |      |   |                                                                 |
| 2                                                                                    |          | CSEG                           |      |      |      |   |                                                                 |
|                                                                                      | \$       | SUBTITLE('THIS IS SUBTITLE I') | 2(1) |      |      |   |                                                                 |
|                                                                                      |          |                                |      |      |      |   |                                                                 |
|                                                                                      |          | •                              |      |      |      |   |                                                                 |
|                                                                                      |          |                                |      |      | • •  |   | ← Page ejection by<br>instruction in (2)                        |
| UCON-76K1 ASSEMBLER VX X<br>THIS IS SUBTITLE 1                                       |          | ••                             |      | DATE | PAGE | 2 |                                                                 |
|                                                                                      | *        | EJECT                          | :(2) |      |      |   | <ul> <li>Subtitle printing by<br/>instruction in (1)</li> </ul> |
| 3                                                                                    |          | CSE0                           |      |      |      |   |                                                                 |
|                                                                                      | 8        | SUBTITLE('THIS IS SUBTITLE 2') | 1(3) |      |      |   |                                                                 |
|                                                                                      |          |                                |      |      |      |   | - Page ejection by                                              |
| UCOM-TOXI ASSEMBLER YX X<br>THIS IS SUBTITLE 2                                       |          |                                |      | DATE | PAGE | 3 | instruction in (4)                                              |
|                                                                                      | \$       | EJECT                          | 1(4) |      |      |   | - Subtitle printing by<br>instruction in (3)                    |
| . 4                                                                                  |          | CSEG                           |      |      |      |   |                                                                 |
| 6                                                                                    |          | END                            |      |      |      |   |                                                                 |
|                                                                                      |          |                                |      |      |      |   |                                                                 |
|                                                                                      |          |                                |      |      |      |   |                                                                 |

4.4 Control Instructions for Conditional Assembly Conditional assembly control instructions select a series of statements in a source module as those subject to assembly or not subject to assembly by setting switches for conditional assembly. Conditional assembly control instructions are available in two groups: one group to set the condition for limiting source statements subject to assembly (IF, ELSEIF, ELSE, and ENDIF) and the other, to give a true or false value to a specified switch name (SET and RESET).

Each group of these control instructions is detailed on the following pages.

By making the best of these control instructions, assembly of a source module by excluding unwanted statements can be executed with little or no change to the source module. IF, ELSEIF, ELSE, ENDIF

IF, ELSEIF, ELSE, ENDIF

(1) IF, ELSEIF, ELSE, ENDIF

Description Format

\$[△]IF(switch name[:switch name[...]])
\$[△]ELSEIF(switch name[:switch name[...]])
\$[△]ELSE
\$[△]ENDIF

1st column

### Function

- o These control instructions set the conditions to limit source statements subject to conditional assembly and those not subject to conditional assembly.
   Source statements described between the IF control instruction and the ENDIF control instruction are subject to
  - conditional assembly.
- o If the value of the switch name specified by the <u>IF control</u> <u>instruction</u> (i.e., IF condition) is true (OFFH), source statements described after this IF control instruction until the appearance of the next conditional assembly control instruction (ELSEIF, ELSE, or ENDIF) in the source program will be assembled. For subsequent assembly processing, the assembler will proceed to the statement next to the ENDIF control instruction.

If the IF condition is false (00H), source statements described after this IF control instruction until the appearance of the next conditional assembly control instruction (ELSEIF, ELSE, or ENDIF) in the source program will be not assembled.

o <u>The ELSEIF control instruction</u> is checked for true/false value of its switch name(s) only when the conditions of the IF control instruction described before this ELSEIF control instruction are not satisfied (i.e., all the switch name values are false).

If the value of the switch name specified by the ELSEIF control instruction (i.e., ELSEIF condition) is true (OFFH), source statements described after this ELSEIF control. instruction until the appearance of the next conditional assembly control instruction (ELSEIF, ELSE, or ENDIF) in the source program will be assembled. For subsequent assembly processing, the assembler will proceed to the statement next to the ENDIF control instruction.

If the ELSEIF condition is false (00H), source statements described after this ELSEIF control instruction until the appearance of the next conditional assembly control instruction (ELSEIF, ELSE, or ENDIF) in the source program will be not assembled.

- o If all the conditions of the IF and ELSEIF control instructions described before the ELSE control instruction are not satisfied (i.e., the switch name values are all false), source statements described after this ELSE control instruction until the appearance of the ENDIF control instruction in the source program will be assembled.
- o The ENDIF control instruction indicates to the assembler the termination of source statements subject to conditional assembly.

#### <u>Use</u>

- o With these conditional assembly control instructions, source statements subject to assembly can be changed without major modifications to the source program.
- o If a statement for debugging necessary only during the program development is described in a source program, whether or not the debugging statement should be assembled (translated into machine language) can be specified by setting switches for conditional assembly.

#### **Explanation**

o When describing any of the IF, ELSEIF, ELSE, and ENDIF control instructions, "\$" must be described in the 1st column of the source statement.

If you wish to provide a space between "\$" and each of these control instructions, input only one BLANK or TAB character.

- o With the IF and ELSEIF control instructions, at least one switch name must be described.
  The rules of describing switch names are the same as the conventions of symbol description, for which see Subsection 2.2.3, "Symbol field" in Chapter 2. However, note that underscore (\_) cannot be used to describe any switch name. Up to five switch names can be used per module.
- o If two or more switch names are to be specified with the IF or ELSEIF control instruction, delimit each switch name with a colon (:).
- o When two or more switch names have been specified with the IF or ELSEIF control instruction, the IF or ELSEIF condition is judged as satisfied if one of the switch name values is true (OFFH).
- o The value of each switch name to be specified with the IF or ELSEIF control instruction must be defined with the SET or RESET control instruction. (See (2), "SET, RESET" in this section.) Therefore, the value of the switch name specified with the IF or ELSEIF control instruction must have been set in the source module with the SET or RESET control instruction.
- o Within an IF-ENDIF block, another IF-ENDIF block cannot be described. (Nesting of IF statements is not allowed.)
- o In conditional assembly, object codes will not be generated for statements not assembled, but these statements will be output as is on the assembly list.

4-19

### Application Example





- (1) If the value of switch name "SW1" is true (OFFH), statements in "text1" will be assembled. If the value of switch name "SW1" is false (00H), statements in "text1" will not be assembled. The value of switch name "SW1" has been set to true (OFFH) or false (00H) with the SET or RESET control instruction described in "text0".
- (2) This instruction indicates the end of the source statement range for conditional assembly.



- (1) The value of switch name "SW1" has been set to true (OFFH) or false (OOH) with the SET or RESET control instruction described in "text0". If the value of switch name "SW1" is true (OFFH), statements in "text1" will be assembled and statements in "text2" will not be assembled.
- (2) If the value of switch name "SW1" is false (00H), statements in "text1" will not be assembled and statements in "text2" will be assembled.
- (3) This instruction indicates the end of the source statement range for conditional assembly.



- (1) The values of switch names "SW1", "SW2", and "SW3" have been set to true (OFFH) or false "OOH" with the SET or RESET control instruction described in "text0". If the value of switch name "SW1" is true, statements in "text1" will be assembled and statements in "text2", "text3", and "text4" will not be assembled. If the value of switch name "SW1" is false, statements in "text1" will not be assembled and conditional assembly of statements in "text2" and thereafter will be executed.
- (2) If the value of switch name "SW1" in (1) is false and the value of switch name "SW2" is true, statements in "text2" will be assembled and statements in "text1", "text3", and "text4" will not be assembled.
- (3) If the values of both switch names "SW1" in (1) and "SW2" in (2) are false and the value of switch name "SW3" is true, statements in "text3" will be assembled and statements in "text1", "text2" and "text4" will not be assembled.
- (4) If the values of switch names "SW1" in (1), "SW2" in (2), and "SW3" in (3) are all false, statements in "text4" will be assembled and statements in "text1", "text2" and "text3" will not be assembled.
- (5) This instruction indicates the end of the source statement range for conditional assembly.



| text0             |       |
|-------------------|-------|
| \$<br>IF(SWA:SWB) | ;(1)  |
| text1             |       |
| \$<br>ENDIF       | ; (2) |
| ÷                 |       |
| END               |       |

- (1) The values of switch names "SWA" and "SWB" have been set to true (OFFH) or false "OOH" with the SET or RESET control instruction described in "text0". If the value of switch name "SWA" or "SWB" is true (OFFH), statements in "text1" will be assembled. If the values of both switch names "SWA" and "SWB" are false, statements in "text1" will not be assembled.
- (2) This instruction indicates the end of the source statement range for conditional assembly.

set, reset

Phase-out/Discontinued

```
(2) SET, RESET (set, reset)
```

Description Format

\$[△]SET(switch name[:switch name[...]])
\$[△]RESET(switch name[:switch name[...]])

1st column

#### Function

- o The SET and RESET control instructions give a value (true or
- false) to each switch name to be specified with the IF or ELSE control instruction.
- o The SET control instruction gives a true value (OFFH) to the switch name specified in the operand.
- o The RESET control instruction gives a false value (00H) to the switch name(s) specified in the operand.

#### <u>Use</u>

- o Describe the SET control instruction to give a true value (OFFH) to a switch name to be specified with the IF or ELSEIF control instruction.
- o Describe the RESET control instruction to give a false value (00H) to a switch name to be specified with the IF or ELSEIF control instruction.

### Explanation

- o When describing the SET and RESET control instructions, "\$" must be described in the 1st column of the source statement. If you wish to provide a space between "\$" and each of these control instructions, input only one BLANK or TAB character.
- o With the SET and RESET control instructions, at least one switch name must be described.

Phase-out/Discontinued

The rules of describing switch names are the same as the conventions of symbol description, for which see Subsection 2.2.3, "Symbol field" in Chapter 2. However, note that underscore (\_) cannot be used to describe any switch name. Up to five switch names can be used per module.

- o If two or more switch names are to be specified with the SET or RESET control instruction, delimit each switch name with a colon (:).
- o The switch name once set to "true" with the SET control instruction can be changed to "false" with the RESET control instruction, and vice versa.
- o A switch name to be specified with the IF or ELSEIF control instruction must be defined at least once with the SET or RESET control instruction in the source module before describing the IF or ELSEIF control instruction.
- o The SET and RESET control instructions can also be specified as assembler options in the start-up command line of the assembler.





- (1) This instruction gives a true value (OFFH) to switch name "SW1".
- (2) Because the true value has been given to switch name "SW1" in (1) above, statements in "text1" will be assembled.
- (3) This instruction indicates the end of the source statement range for conditional assembly, which starts from (2).
- (4) This instruction gives a false value (00H) to switch names "SW1" and "SW2".
- (5) Because the false value has been given to switch name "SW1" in (4) above, statements in "text2" will not be assembled.

- (6) Because the false value has also been given to switch name "SW2" in (4) above, statements in "text3" will not be assembled.
- (7) Because both switch names "SW1" and "SW2" are false in (5) and (6) above, statements in "text4" will be assembled.
- (8) This instruction indicates the end of the source statement range for conditional assembly, which starts from (5).

5.1 Overview of Macro

When you must describe a series of instruction groups over and over again in a source program, use of a macro function is very useful for program description.

The macro function refers to the expansion of a series of instruction groups defined as a macro body with MACRO and ENDM directives into the location where the macro name is referenced.

A macro is used to increase coding efficiency of a source program and is different from a subroutine.

A macro and a subroutine each have the following features and should be used selectively according to the specific purpose.

(1) Subroutine

- o Describe a process (or the same sequence of instructions) which has to be repeated over and over again in a program as a subroutine. The subroutine will be converted into machine language just once by the assembler.
- o To call the subroutine, you only need to describe a subroutine call instruction. (Generally, instructions to set arguments are also described before and after the subroutine.)

Therefore, by making the best of subroutines, the program memory can be used with high efficiency.

- o By coding a series of processes in a program as subroutines, the program can be structurized. (By this structurization, the programmer can easily understand the overall structure of the program, thus making the program design easy.)
- (2) Macro
  - o The basic function of a macro is the replacement of a group of instructions with a name.

A series of instruction groups defined as a macro body with MACRO and ENDM directives will be expanded into the location where the macro name is referenced.

o When the assembler detects a macro reference, the assembler expands the macro body and converts the group of instructions into machine language while replacing the formal parameter(s) of the macro body with the actual parameters at the time of the macro reference.



o Parameters can be described for a macro. For example, if there are instruction groups which are the same in processing procedure but are different in data to be described in the operand, define a macro by assigning formal parameter(s) to the data. By describing the macro name and the actual parameter(s) at macro reference time, the assembler can cope with various instruction groups which differ only in part of the statement description.

The programming technique with subroutines is mainly used for memory size reduction and program structurization, whereas macros are used to increase coding efficiency of the program.

5.2 Utilization of Macros

### 5.2.1 Macrodefinition

A macro is defined with the MACRO and ENDM directives.

### Description Format

| Symbol     | Mnemonic | Operand               | Comment    |
|------------|----------|-----------------------|------------|
| field      | field    | field                 | field      |
| macro name | MACRO    | [formal parameter[,]] | [;comment] |
|            | S        |                       |            |
|            | ENDM     |                       |            |
|            |          |                       |            |

### Function

The MACRO directive executes a macrodefinition by assigning the macro name specified in the Symbol field to a series of statements (called a macro body) described between this directive and the ENDM directive.

### Application Example

| _ |       | the second s |              |
|---|-------|----------------------------------------------------------------------------------------------------------------|--------------|
| I | ADMAC | MACRO                                                                                                          | PARA1, PARA2 |
|   |       | MOV                                                                                                            | A, #PARA1    |
|   |       | AÐD                                                                                                            | A, #PARA2    |
|   |       | ENDM                                                                                                           |              |
|   |       |                                                                                                                |              |

The above example shows a simple macrodefinition which specifies the addition of two values PARA1 and PARA2 and the storage of the result in register A. The macro is given a name "ADMAC" and "PARA1" and "PARA2" are formal parameters. For details, see (1) MACRO in Section 3.7, Macro Directives, Chapter 3.

### 5.2.2 Macro reference

To call a macro, the already defined macro name must be described in the Mnemonic field of the source program.

### Description Format

| Symbol   | Mnemonic   | Operand               | Comment    |
|----------|------------|-----------------------|------------|
| field    | field      | field                 | field      |
| [label:] | macro name | [actual parameter[,]] | [;comment] |

#### Function

This directive calls the macro body assigned to the macro name specified in the Mnemonic field.

#### <u>Use</u>

Use this directive description to call a macro body.

#### Explanation

- o The macro name to be specified in the Mnemonic field must have been defined before the macro reference.
- o A constant, expression, name, or label can be described as the operand of this directive.
- o Formal parameters are replaced with their corresponding actual parameters in sequence from left to right.
- o An error will result if the number of formal parameters is not equal to the number of actual parameters.

|       | NAME    | SAMPLE       |
|-------|---------|--------------|
| ADMAC | MACRO   | PARA1, PARA2 |
|       |         |              |
|       | моv     | A, #PARA1    |
|       | ADD     | A, #PARA2    |
|       |         |              |
|       | ENDM    |              |
|       |         |              |
|       | CSEG    |              |
|       |         |              |
|       | ADMAC   | 10H,20H      |
|       | :       |              |
|       | END     |              |
|       | <u></u> |              |

This directive calls the already defined macro name "ADMAC". 10H and 20H are actual parameters.

### 5.2.3 Macroexpansion

The assembler processes a macro as follows:

- o Stores the macro body of the defined macro name in the symbol table area (an area within the assembler).
- o Searches the macro body corresponding to the referenced macro name from the symbol table area and expands it to the location where the macro name is referenced.
- o Assembles statements in the expanded macro body just the same as other statements.

Application Example

When the macro referenced in Subsection 5.2.2, "Macro reference" is assembled, the macro body will be expanded as shown below.

|   |       |       | · ·             |         |                 |
|---|-------|-------|-----------------|---------|-----------------|
|   |       | NAME  | SAMPLE          |         |                 |
|   | ADMAC | MACRO | PARA1.PARA2     |         |                 |
|   |       | моч   | A,#PARA1        |         | Macrodefinition |
|   |       | ADD   | A, #PARA2       |         | ·               |
|   |       | ENDM  |                 |         |                 |
| - |       |       |                 |         | _               |
|   |       | CSEG  |                 |         |                 |
|   |       | ÷     |                 |         |                 |
|   |       | ADMAC | 10H,20H         | . ; (1) | _               |
|   |       | MOV   | A.#PARA1        |         |                 |
|   |       | ADD   | A , = P A R A 2 |         | Macroexpansion  |
|   |       | ÷     |                 |         |                 |
|   |       | END   |                 |         | ·               |
|   | L.e   |       |                 |         |                 |

By the macro reference in (1), the macro body will be expanded. On the assembly list in this case, the formal parameters within the macro body are not replaced with the actual parameters. However, in object code generation, the formal parameters will be replaced with the actual parameters as shown below.

(Object code) MOV A, #PARA1  $\rightarrow$  B9<u>10</u> ADD A, #PARA2  $\rightarrow$  A8<u>20</u>

• •



### 5.3 Symbols within Macro

Symbols that can be defined in a macro are divided into two types: global symbols and local symbols.

- (1) Global symbols
  - A global symbol is a symbol that can be referenced from any statement within a source program.
    Therefore, if a series of statements are expanded by referencing a macro in which the global symbol has been defined, the symbol will cause a double definition error.
    Symbols not defined with the LOCAL directive are global.

#### (2) Local symbols

- o A local symbol is a symbol defined with the LOCAL directive. (See (2) LOCAL in Section 3.7, "Macro directives".)
- A local symbol is valid within the macro in which the local symbol has been defined.
  Therefore, if a series of statements are expanded by referencing a macro in which the local symbol has been defined, the symbol will not cause a double definition error.
- o No local symbol can be referenced from outside the macro.

### Application Example

|       | NAME  | SAMPLE |         |                 |
|-------|-------|--------|---------|-----------------|
| MAC1  | MACRO |        |         |                 |
| •••   | LOCAL | LLAB   | ; (1)   |                 |
| LLAB: | ÷     |        |         | Macrodefinition |
| GLAB: | BR    | \$LLAB | ; (2)   |                 |
|       | BR    | \$GLAB | ; (3)   |                 |
|       | ENDM  |        | ·- ···  |                 |
|       | :     |        |         |                 |
| REF1: | MACI  |        | ;(4)    | Macro reference |
|       | :     |        |         |                 |
|       | BR    | ILLAB  | ; (5)   |                 |
|       | BR    | ! GLAB | ; (6)   |                 |
|       | ÷     |        |         |                 |
| REF2: | MAC1  |        | ; (7) - | Macro reference |
|       | . :   |        |         |                 |
|       | END   |        |         |                 |

<Source program>

- (1) This directive defines label "LLAB" as a local symbol.
- (2) This instruction references local symbol "LLAB" in macro MAC1.
- (3) This instruction references global symbol "GLAB" in macro MAC1.
- (4) This directive references macro MAC1.
- (5) This instruction references local symbol "LLAB" from outside the definition of macro MAC1. This description cause an error when the source program is assembled.
- (6) This instruction references global symbol "GLAB" from outside the definition of macro MAC1.
- (7) This directive references macro MAC1. The same macro is referenced twice.

When the source program in the above program is assembled, the macro body will be expanded as shown below.



Global symbol "GLAB" has been defined in macro MAC1. Because macro MAC1 is referenced twice, global symbol "GLAB" causes a double definition error as a result of expanding a series of statements in the macro body.



CHAPTER 6. PRODUCT UTILIZATION

There are several ways to effective use this package for assembly of source modules. Only a few of these techniques are introduced in this section.

(1) Specification of assembler options

It is better to specify assembler options you always use at the beginning of each source module. Especially, the PROCESSOR option which cannot be omitted from specification should be specified in the module header. Then, you do not need to specify the option in the command line each time you start up the assembler program. An error will result if you forget to specify this option in the command line and you must start up the assembler again from the beginning with the correct assembler options.

The DEBUG and XREF options should also be specified in the module header.

Example



(2) Definition of short direct addressing area The short direct addressing area (addresses OFE20H to OFF1FH with uPD78122/78124 or OFE40H to OFF1FH with uPD78112) is an area which can be accessed with instructions of short byte length as compared with other data memory areas. Therefore, by making the best of this area, a program with high memory utilization efficiency can be developed. So, you must determine the memory map of this short direct addressing area before you start developing any program. Then, describe the data definition of the short direct addressing area with absolute addresses at the beginning of each source module.

| Example | ſ      |            |             |                                           |
|---------|--------|------------|-------------|-------------------------------------------|
|         |        | NAME       | TEST        |                                           |
|         | WORK 1 | EQU        | 0 F E 2 0 H | Describe the data<br>definition of each   |
|         | WORK 2 | EQU        | 0 F E 2 1 H | work area with absolute address(es)       |
|         |        | <b>i</b> . |             | at the beginning of<br>the source module. |
|         | WORKX  | EQU        | OFEFFH      |                                           |
|         |        | CSEG       |             | _                                         |
|         |        | :          |             | · · ·                                     |
|         |        | MOV        | WORK1, #00H |                                           |
|         |        | :          |             |                                           |
|         |        | END        |             |                                           |
|         | L      | ·          |             |                                           |

Phase-out/Discontinued

### APPENDIX A. LIST OF RESERVED WORDS

Reserved words are available in five types: machine language instructions, directives, operators, register names, and sfr symbols.

A reserved word is a word or sequence of letters and/or symbols (a character string) which has unique meaning. These words have been reserved beforehand by the assembler and cannot be used for other than the intended purposes.

Types of reserved words that can be described in each field of a source program and a list of reserved words are shown in Tables A-1 and A-2, respectively.

Table A-1. Types of Reserved Words That Can Be Described in Respective Fields of Source Program

| Symbol field   | All reserved words cannot be described in this field.                             |
|----------------|-----------------------------------------------------------------------------------|
| Mnemonic field | Only machine language instructions and directives can be described in this field. |
| Operand field  | Only operators, sfr symbols, and register names can be described in this field.   |
| Comment field  | All reserved words can be described in this field.                                |

Table A-2. List of Reserved Words

| r            |        |          |        |       |       | · · · · · · · · · · · · · · · · · · · |
|--------------|--------|----------|--------|-------|-------|---------------------------------------|
| Instructions | ADD    | ADDC     | ADJBA  | ADJBS | AND   | AND1                                  |
|              | ADDW   | ₿C       | BE     | BF    | BL .  | BNC                                   |
|              | BNE    | BNL      | BNZ    | BR    | вт    | BTCLR                                 |
|              | BZ     | CALL     | CALLF  | CALLT | CLR1  | CMP                                   |
|              | CMPW   | DBNZ     | DEC    | DECW  | DI    | DIVUW                                 |
| . •          | EI     | INC      | INCW   | MOV   | MOVW  | MOV1                                  |
|              | MULUW  | NOP      | NOT1   | OR    | OR1   | POP                                   |
|              | PUSH   | RET      | RETI   | ROL   | ROLC  | ROR                                   |
|              | RORC   | ROL4     | ROR4   | SEL   | SET1  | SHL                                   |
|              | SHR    | SHLW     | SHRW   | SUB   | SUBC  | SUBW                                  |
|              | ХСН    | XOR      | XOR1   |       |       |                                       |
|              |        | <b>-</b> |        | *     |       |                                       |
| Operators    | AND    | EQ       | GE     | GT    | HIGH  | LE                                    |
|              | LOW    | LT       | MOD    | NE    | NOT   | OR                                    |
|              | SHL    | SHR      | XOR    |       |       |                                       |
| Special      | \$     | STKBEG   | STKEND |       |       |                                       |
| reserved     |        |          |        |       |       |                                       |
| words        |        |          |        |       |       |                                       |
| Directives   | BR     | CSEG     | DB .   | DBIT  | DS    | DSEG                                  |
|              | DW     | END      | ENDM   | EQU   | EXITM | EXTBIT                                |
|              | EXTRN  | IRP      | LOCAL  | MACRO | NAME  | ORG                                   |
|              | PUBLIC | REPT     | SET    | SFR   | SFRP  |                                       |

Table A-2. List of Reserved Words (contd)

| · · · · · · · · · · · · · · · · · · · |        |       |      |       |         |      |
|---------------------------------------|--------|-------|------|-------|---------|------|
| sfr symbols                           | ADM    | CLOM  | CPT0 | CPT1  | CPT2    | CPT3 |
|                                       | Сртм   | CR00  | CR01 | CR02  | CR10    | CR11 |
|                                       | CR12   | CR20  | CR21 | CR22  | CR30    | CRC0 |
|                                       | CRC1   | CRC2  | CSIM | EDVC  | FRC     | ICR  |
|                                       | IFO    | IFOL  | IFOH | INTM0 | INTM1   | ISM0 |
|                                       | ISM0H  | ISM0L | ISOH | IST   | MK0     | MKOL |
|                                       | мкд0н  | ММ    | PO   | POH   | POL     | P1   |
|                                       | P2     | Р3    | P4   | P5    | P6      | PM0  |
|                                       | PM1    | PM3   | PM5  | PM6   | PMC3    | PR0  |
|                                       | PROL   | PROH  | PRM0 | PRM1  | PU0     | PWM0 |
|                                       | PWM1   | PWMC  | RTPC | SA    | SI0     | STBC |
|                                       | TMO    | TM1   | TM2  | тмз   | тмс0    | TMC1 |
|                                       | TOC    |       | *    |       |         |      |
| Register                              | А      | AX    | В    | С     | СҮ      | D    |
| names                                 | Е      | Н     | HL   | L     | PSW     | R0   |
|                                       | R1     | R2    | R3   | R4    | R5      | R6   |
|                                       | R7     | RP0   | RP1  | RP2   | RP3     | RB0  |
|                                       | RB1    | RB2   | RB3  | RB4   | RB5     | RB6  |
|                                       | RB7    | SP    | STBC |       | <u></u> |      |
| Segment                               | CALLT0 | FIXED |      |       |         |      |
| attributes                            |        |       |      |       | ····    |      |

### Table B-1. List of Directives

| No. | Directive |          |          | Function/  |                    |
|-----|-----------|----------|----------|------------|--------------------|
|     | Symbol    | Mnemonic | Operand  | Comment    | classification     |
|     | field     | field    | field    | field      |                    |
| 1   | [segment  | CSEG     | [reloc.  | [;comment] | Declares the start |
|     | name]     |          | attr.]   |            | of a code segment. |
| 2   | [segment  | DSEG     | None     | [;comment] | Declares the start |
| [   | name]     |          |          |            | of a data segment. |
| 3   | [segment  | BSEG     | None     | [;comment] | Declares the start |
|     | name]     |          |          |            | of a bit segment.  |
| 4   | [segment  | ORG      | expres-  | [;comment] | Declares the start |
|     | name]     |          | sion     |            | of an absolute     |
|     |           |          |          |            | segment. (See Note |
| L   | L         |          |          |            | 1.)                |
| 5   | None      | ENDS     | None     | [;comment] | Indicates the end  |
|     |           |          |          |            | of the segment.    |
| 6   | name      | EQU      | expres-  | [;comment] | Defines a name.    |
|     |           |          | sion     |            | (See Note 2.)      |
| ļ   |           |          |          |            | name:symbol        |
| 7   | name      | SET      | expres-  | [;comment] | Defines a relocat- |
|     |           |          | sion     |            | able name. (See    |
|     |           |          |          |            | Note 1.)           |
|     |           |          |          |            | name:symbol        |
| 8   | [label:]  | DB       | [(size)] | [;comment] | Initializes or     |
|     |           |          | [initial |            | reserves a byte    |
|     |           |          | value    |            | data area.         |
|     | ;         |          | [,]]     |            | (See Note 3.)      |
|     |           |          |          |            | label:symbol       |
| 9   | [label:]  | DW       | [(size)] | [;comment] | Initializes or     |
|     |           |          | [initial |            | reserves a word    |
|     |           |          | value    |            | data area.         |
|     |           |          | [,]]     |            | label:symbol       |
| 10  | [label:]  | DS       | expres-  | [;comment] | Reserves a byte    |
|     |           |          | sion     |            | data area. (See    |
|     |           |          |          |            | Note 1.)           |
|     | <u>i</u>  |          |          |            | label:symbol       |

Table B-1. List of Directives (contd)

| No. | Directive       |                   |                              | Function/        |                                                                                                           |  |
|-----|-----------------|-------------------|------------------------------|------------------|-----------------------------------------------------------------------------------------------------------|--|
|     | Symbol<br>field | Mnemonic<br>field | Operand<br>field             | Comment<br>field | classification                                                                                            |  |
| 11  | [name]          | DBIT              | None                         | [;comment]       | Reserves a bit<br>data area. (See<br>Note 1.)<br>name:symbol                                              |  |
| 12  | [label:]        | PUBLIC            | symbol<br>name<br>[,]        | [;comment]       | Declares an<br>external defini-<br>tion name.                                                             |  |
| 13  | [label:]        | EXTRN             | symbol<br>name<br>[,]        | [;comment]       | Declares an<br>external reference<br>name.                                                                |  |
| 14  | [label:]        | EXTBIT            | symbol<br>name<br>[,]        | [;comment]       | Declares an<br>external reference<br>name. Symbol names<br>are limited to<br>those having a bit<br>value. |  |
| 15  | [label:]        | NAME              | module<br>name<br>[,]        | [;comment]       | Defines a module<br>name.<br>module name:symbol                                                           |  |
| 16  | [label:]        | BR                | expres-<br>sion<br>[,]       | [;comment]       | Automatically<br>selects a Branch<br>instruction.<br>label:symbol                                         |  |
| 17  | macro<br>name   | MACRO             | [formal<br>parameter<br>[,]} | [;comment]       | Defines a macro.<br>macro name:symbol                                                                     |  |
| 18  | [label:]        | LOCAL             | symbol<br>name<br>[,]        | [;comment]       | Defines a symbol<br>valid only within<br>the macro. (See<br>Note 4.)<br>label: symbol                     |  |

.

.

Table B-1. List of Directives (contd)

| No. |          | Directive | ······································                       |            | Function/           |
|-----|----------|-----------|--------------------------------------------------------------|------------|---------------------|
|     | Symbol   | Mnemonic  | Operand                                                      | Comment    | classification      |
|     | field    | field     | field                                                        | field      |                     |
| 19  | [label:] | REPT      | expres-                                                      | [;comment] | Defines the repeat  |
|     |          |           | sion                                                         | , ,        | count in macro-     |
|     |          |           |                                                              |            | expansion.          |
|     |          |           |                                                              |            | label: symbol       |
| 20  | [label:] | IRP       | formal                                                       | [;comment] | Expands the macro   |
|     |          |           | parameter,                                                   |            | body by replacing   |
|     |          |           | <actual< td=""><td></td><td>formal parameters</td></actual<> |            | formal parameters   |
|     |          |           | parameter                                                    |            | with actual para-   |
| ·   |          |           | [,]>                                                         |            | meters.             |
|     |          |           |                                                              |            | label:symbol        |
| 21  | None     | EXITM     | None                                                         | [;comment] | Interrupts, the     |
|     |          |           |                                                              |            | macroexpansion.     |
|     |          |           |                                                              |            | (See Note 4.)       |
| 22  | None     | ENDM      | None                                                         | [;comment] | Indicates the end   |
|     |          |           |                                                              |            | of macrodefinition. |
|     |          |           |                                                              |            | (See Note 4.)       |
| 23  | None     | END       | None                                                         | [;comment] | Indicates the end   |
| 1   |          |           |                                                              |            | of th source        |
|     |          |           |                                                              |            | module              |

- NOTE: 1. Forward reference of a symbol is not allowed in the expression described in the Operand field.
  - Neither forward reference of a symbol nor reference of an external reference name is allowed in the expression described in the Operand field.
  - 3. A character string may be described in place of an initial value.
  - 4. This directive can be used only in the macrodefinition.



APPENDIX C. INSTRUCTION SET OF uCOM-78K/I

APP C-1. Instruction Set and Its Operation

- (1) Representation formats and description methods of operands Describe an operand in the Operand field of each instruction according to the description method for the operand representation format of the instruction. (For details, see the assembler specifications.) If two or more elements exist in the description method, select one of the elements. Elements written in uppercase letters and symbols +, -, #, \$, !, and [ ] are keywords and must be described as is in the Operand field. The meanings of these symbols are as follows:
  - + : Autoincrement
    - # : Immediate data
    - ! : Address by an immediate addressing method
    - \$ : Address by a relative addressing method
    - / : Bit inversion
    - [ ]: Indirect addressing

With an immediate data, describe an appropriate numeric value or label as the data. When describing it with a label, symbol #, \$, !, or [] must also be described.

,

# Table C-1. Representation Formats and Description Methods of Operands

| Representation       Description method         format       X(R0),A(R1),C(R2),B(R3),E(R4),D(R5),L(R6),H(R7)         r1       A,B         r2       B,C         r3       D,E,E+         r4       D,E         rp       AX(RP0),BC(RP1),DE(RP2),HL(RP3)         sfr       Special function register symbol (see Table C-2.)         sfrp       Special function register symbol (register         capable of 16-bit manipulation; see Table C-2.)         saddr       FE40H-FF1FH Immediate data or label (with         uPD78112)         FE20H-FF1FH Immediate data or label (with         uPD78122/78124)         saddrp       FE40H-FF1EH Immediate data (with bit 0 = 0) or         label (in 16-bit manipulation)         (with uPD78122/78124)         laddr13       0000H-1FFFH Immediate data or label (with         uPD78122/78124)       Immediate         iaddr16       0000H-3FFFH Immediate data or label (with         uPD78122/78124)       Immediate         saddr13       0000H-3FFFH Immediate data or label (with         uPD78122/78124)       Immediate         saddr16       0000H-3FFFH Immediate data or label (with         uPD78122/78124)       Relative         addressing       address |          |                                                        | -7 |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------|----|--|--|
| <pre>r X(R0),A(R1),C(R2),B(R3),E(R4),D(R5),L(R6),H(R7) r1 A,B r2 B,C r3 D,E,E+ r4 D,E rp AX(RP0),BC(RP1),DE(RP2),HL(RP3) sfr Special function register symbol (see Table C-2.) sfrp Special function register symbol (register capable of 16-bit manipulation; see Table C-2.) saddr FE40H-FF1FH Immediate data or label (with uPD78112) FE20H-FF1FH Immediate data or label (with uPD78122/78124) saddrp FE40H-FF1EH Immediate data (with bit 0 = 0) or label (in 16-bit manipulation) (with uPD78122/78124) Iaddr13 0000H-1FFFH Immediate data or label (with uPD78122/78124) Iaddr13 0000H-1FFFH Immediate data or label (with uPD78122/78124) Immediate addressing \$addr13 0000H-1FFFH Immediate data or label (with uPD78122/78124) Relative addressing \$addr16 000H-3FFFH Immediate data or label (with uPD78122/78124) Relative addressing addr16 000H-3FFFH Immediate data or label (with uPD78122/78124) Relative addressing </pre>                                                                                                                                                                                                                                                                    | -        | Description method                                     |    |  |  |
| <pre>r1 A,B<br/>r2 B,C<br/>r3 D,E,E+<br/>r4 D,E<br/>rp AX(RPO),BC(RP1),DE(RP2),HL(RP3)<br/>sfr Special function register symbol (see Table C-2.)<br/>sfrp Special function register symbol (register<br/>capable of 16-bit manipulation; see Table C-2.)<br/>saddr FE40H-FF1FH Immediate data or label (with<br/>uPD78112)<br/>FE20H-FF1FH Immediate data or label (with<br/>uPD78122/78124)<br/>saddrp FE40H-FF1EH Immediate data (with bit 0 = 0) or<br/>label (in 16-bit manipulation)<br/>(with uPD78112)<br/>FE20H-FF1EH Immediate data (with bit 0 = 0) or<br/>label (in 16-bit manipulation)<br/>(with uPD78122/78124)<br/>iaddr13 0000H-1FFFH Immediate data or label (with<br/>uPD78122/78124)<br/>iaddr16 000H-1FFFH Immediate data or label (with<br/>uPD78122/78124) Immediate<br/>addressing<br/>\$addr13 0000H-1FFFH Immediate data or label (with<br/>uPD78122/78124) Immediate<br/>addressing<br/>\$addr13 000H-1FFFH Immediate data or label (with<br/>uPD78112) Relative addressing<br/>\$addr16 000H-3FFFH Immediate data or label (with<br/>uPD78122/78124) Relative<br/>addressing</pre>                                                                                                     | format   |                                                        |    |  |  |
| r2B,Cr3D,E,E+r4D,ErpAX(RPO),BC(RP1),DE(RP2),HL(RP3)sfrSpecial function register symbol (see Table C-2.)sfrpSpecial function register symbol (register<br>capable of 16-bit manipulation; see Table C-2.)saddrFE40H-FF1FH Immediate data or label (with<br>uPD78112)FE20H-FF1FH Immediate data or label (with<br>uPD78122/78124)saddrpFE40H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78112)FE20H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78122/78124)laddr130000H-1FFFH Immediate data or label (with<br>uPD78122/78124) Immediate<br>addressingladdr140000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Immediate<br>addressing\$addr130000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Relative addressing\$addr160000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                        | r        | X(R0), A(R1), C(R2), B(R3), E(R4), D(R5), L(R6), H(R7) |    |  |  |
| r3 D,E,E+<br>r4 D,E<br>rp AX(RPO),BC(RP1),DE(RP2),HL(RP3)<br>sfr Special function register symbol (see Table C-2.)<br>sfrp Special function register symbol (register<br>capable of 16-bit manipulation; see Table C-2.)<br>saddr FE40H-FF1FH Immediate data or label (with<br>uPD78112)<br>FE20H-FF1FH Immediate data or label (with<br>uPD78122/78124)<br>saddrp FE40H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78112)<br>FE20H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78122/78124)<br>laddr13 0000H-1FFFH Immediate data or label (with<br>uPD78122/78124) Immediate<br>addressing<br>\$addr13 0000H-1FFFH Immediate data or label (with<br>uPD78122/78124) Immediate<br>addressing<br>\$addr13 0000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Immediate<br>addressing<br>\$addr16 000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Relative addressing<br>\$addr16 000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                  | r1       | А,В                                                    |    |  |  |
| r4 D,E<br>rp AX(RPO),BC(RP1),DE(RP2),HL(RP3)<br>sfr Special function register symbol (see Table C-2.)<br>sfrp Special function register symbol (register<br>capable of 16-bit manipulation; see Table C-2.)<br>saddr FE40H-FF1FH Immediate data or label (with<br>uPD78112)<br>FE20H-FF1FH Immediate data or label (with<br>uPD78122/78124)<br>saddrp FE40H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78112)<br>FE20H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78122/78124)<br>laddr13 0000H-1FFFH Immediate data or label (with<br>uPD78112) Immediate addressing<br>laddr16 000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Immediate<br>addressing<br>\$addr13 000H-1FFFH Immediate data or label (with<br>uPD78112) Relative addressing<br>\$addr16 000H-3FFFH Immediate data or label (with<br>uPD78112) Relative addressing<br>\$addr16 000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                           | r2       | B,C                                                    |    |  |  |
| rpAX(RP0), BC(RP1), DE(RP2), HL(RP3)sfrSpecial function register symbol (see Table C-2.)sfrpSpecial function register symbol (register<br>capable of 16-bit manipulation; see Table C-2.)saddrFE40H-FF1FH Immediate data or label (with<br>uPD78112)FE20H-FF1FH Immediate data or label (with<br>uPD78122/78124)saddrpFE40H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78112)FE20H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78122/78124)Iaddr130000H-1FFFH Immediate data or label (with<br>uPD78122/78124)Iaddr16000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Immediate<br>addressing\$addr130000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Relative addressing\$addr16000H-3FFFH Immediate data or label (with<br>uPD78112) Relative addressing\$addr16000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                | r3       | D,E,E+                                                 |    |  |  |
| sfrSpecial function register symbol (see Table C-2.)sfrpSpecial function register symbol (register<br>capable of 16-bit manipulation; see Table C-2.)saddrFE40H-FF1FH Immediate data or label (with<br>uPD78112)FE20H-FF1FH Immediate data or label (with<br>uPD78122/78124)FE40H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78112)FE20H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78122/78124)Iaddr130000H-1FFFH Immediate data or label (with<br>uPD78122/78124)Iaddr160000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Immediate<br>addressing\$addr130000H-3FFFH Immediate data or label (with<br>uPD78112) Relative addressing\$addr160000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                                                                                                               | r4 .     | D,E                                                    |    |  |  |
| sfrpSpecial function register symbol (register<br>capable of 16-bit manipulation; see Table C-2.)saddrFE40H-FF1FH Immediate data or label (with<br>uPD78112)FE20H-FF1FHImmediate data or label (with<br>uPD78122/78124)saddrpFE40H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78112)FE20H-FF1EHImmediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78122/78124)!addr130000H-1FFFHIaddr160000H-3FFFH0000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Immediate<br>addressing\$addr130000H-3FFFH\$addr160000H-3FFFH0000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Relative addressing\$addr160000H-3FFFH0000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                                                                                                                                                         | rp       | AX(RP0), BC(RP1), DE(RP2), HL(RP3)                     |    |  |  |
| sfrpSpecial function register symbol (register<br>capable of 16-bit manipulation; see Table C-2.)saddrFE40H-FF1FH Immediate data or label (with<br>uPD78112)FE20H-FF1FHImmediate data or label (with<br>uPD78122/78124)saddrpFE40H-FF1EH Immediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78112)FE20H-FF1EHImmediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78122/78124)!addr130000H-1FFFHIaddr160000H-3FFFH0000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Immediate<br>addressing\$addr130000H-3FFFH\$addr160000H-3FFFH0000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Relative addressing\$addr160000H-3FFFH0000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                                                                                                                                                         |          |                                                        |    |  |  |
| capable of 16-bit manipulation; see Table C-2.)saddrFE40H-FF1FHImmediate data or label (with<br>uPD78112)FE20H-FF1FHImmediate data or label (with<br>uPD78122/78124)saddrpFE40H-FF1EHImmediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78112)FE20H-FF1EHImmediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78112)Iaddr130000H-1FFFHImmediate data or label (with<br>uPD78112) Immediate addressing!addr160000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Immediate<br>addressing\$addr130000H-1FFFHImmediate data or label (with<br>uPD78122/78124) Relative addressing\$addr160000H-3FFFHImmediate data or label (with<br>uPD78112) Relative<br>addressing\$addr160000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                                                                                                                    | sfr      | Special function register symbol (see Table C-2        | .) |  |  |
| <pre>saddr FE40H-FF1FH Immediate data or label (with</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | sfrp     | Special function register symbol (register             |    |  |  |
| <ul> <li>uPD78112)</li> <li>FE20H-FF1FH Immediate data or label (with uPD78122/78124)</li> <li>saddrp FE40H-FF1EH Immediate data (with bit 0 = 0) or label (in 16-bit manipulation) (with uPD78112)</li> <li>FE20H-FF1EH Immediate data (with bit 0 = 0) or label (in 16-bit manipulation) (with uPD78122/78124)</li> <li>!addr13 0000H-1FFFH Immediate data or label (with uPD78112) Immediate addressing</li> <li>!addr16 0000H-3FFFH Immediate data or label (with uPD78122/78124) Immediate addressing</li> <li>\$addr13 0000H-1FFFH Immediate data or label (with uPD78122/78124) Immediate addressing</li> <li>\$addr16 0000H-3FFFH Immediate data or label (with uPD78112) Relative addressing</li> <li>\$addr16 0000H-3FFFH Immediate data or label (with uPD78122/78124) Relative addressing</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                  |          | capable of 16-bit manipulation; see Table C-2.)        |    |  |  |
| <pre>FE20H-FF1FH Immediate data or label (with</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | saddr    | FE40H-FF1FH Immediate data or label (with              |    |  |  |
| <pre>uPD78122/78124) saddrp FE40H-FF1EH Immediate data (with bit 0 = 0) or label (in 16-bit manipulation) (with uPD78112) FE20H-FF1EH Immediate data (with bit 0 = 0) or label (in 16-bit manipulation) (with uPD78122/78124) !addr13 0000H-1FFFH Immediate data or label (with uPD78112) Immediate addressing !addr16 0000H-3FFFH Immediate data or label (with uPD78122/78124) Immediate addressing \$addr13 0000H-1FFFH Immediate data or label (with uPD78112) Relative addressing \$addr16 0000H-3FFFH Immediate data or label (with uPD78122/78124) Relative addressing</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          | uPD78112)                                              | 1  |  |  |
| <pre>saddrp FE40H-FF1EH Immediate data (with bit 0 = 0) or label (in 16-bit manipulation) (with uPD78112) FE20H-FF1EH Immediate data (with bit 0 = 0) or label (in 16-bit manipulation) (with uPD78122/78124) laddr13 0000H-1FFFH Immediate data or label (with uPD78112) Immediate addressing laddr16 0000H-3FFFH Immediate data or label (with uPD78122/78124) Immediate addressing \$addr13 0000H-1FFFH Immediate data or label (with uPD78112) Relative addressing addr16 0000H-3FFFH Immediate data or label (with uPD78122/78124) Relative addressing </pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          | FE20H-FF1FH Immediate data or label (with              |    |  |  |
| label (in 16-bit manipulation)<br>(with uPD78112)FE20H-FF1EHImmediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78122/78124)!addr130000H-1FFFHImmediate data or label (with<br>uPD78112) Immediate addressing!addr160000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Immediate<br>addressing\$addr130000H-1FFFH\$addr130000H-1FFFH\$addr140000H-3FFFHImmediate data or label (with<br>uPD78112) Relative addressing\$addr160000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Relative addressing\$addr160000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ,        | uPD78122/78124)                                        |    |  |  |
| <pre>(with uPD78112) FE20H-FF1EH Immediate data (with bit 0 = 0) or label (in 16-bit manipulation)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | saddrp   | FE40H-FF1EH Immediate data (with bit 0 = 0) or         | ·  |  |  |
| FE20H-FF1EHImmediate data (with bit 0 = 0) or<br>label (in 16-bit manipulation)<br>(with uPD78122/78124)!addr130000H-1FFFHImmediate data or label (with<br>uPD78112) Immediate addressing!addr160000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Immediate<br>addressing\$addr130000H-1FFFHImmediate data or label (with<br>uPD78112) Relative addressing\$addr160000H-3FFFHImmediate data or label (with<br>uPD78112) Relative addressing\$addr160000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          | label (in 16-bit manipulation)                         |    |  |  |
| label (in 16-bit manipulation)<br>(with uPD78122/78124)laddr130000H-1FFFHImmediate data or label (with<br>uPD78112) Immediate addressingladdr160000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Immediate<br>addressing\$addr130000H-1FFFHImmediate data or label (with<br>uPD78112) Relative addressing\$addr160000H-3FFFHImmediate data or label (with<br>uPD78112) Relative addressingaddressingaddr160000H-3FFFHImmediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          | (with uPD78112)                                        |    |  |  |
| (with uPD78122/78124)<br>!addr13 0000H-1FFFH Immediate data or label (with<br>uPD78112) Immediate addressing<br>!addr16 0000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Immediate<br>addressing<br>\$addr13 0000H-1FFFH Immediate data or label (with<br>uPD78112) Relative addressing<br>\$addr16 0000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          | FE20H-FF1EH Immediate data (with bit 0 = 0) or         |    |  |  |
| <pre>!addr13 0000H-1FFFH Immediate data or label (with</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          | label (in 16-bit manipulation)                         |    |  |  |
| <ul> <li>uPD78112) Immediate addressing</li> <li>laddr16</li> <li>0000H-3FFFH Immediate data or label (with<br/>uPD78122/78124) Immediate<br/>addressing</li> <li>\$addr13</li> <li>0000H-1FFFH Immediate data or label (with<br/>uPD78112) Relative addressing</li> <li>\$addr16</li> <li>0000H-3FFFH Immediate data or label (with<br/>uPD78122/78124) Relative<br/>addressing</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          | (with uPD78122/78124)                                  |    |  |  |
| <pre>!addr16 0000H-3FFFH Immediate data or label (with</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | laddr13  | 0000H-1FFFH Immediate data or label (with              |    |  |  |
| <pre>\$addr13 uPD78122/78124) Immediate<br/>addressing<br/>\$addr13 0000H-1FFFH Immediate data or label (with<br/>uPD78112) Relative addressing<br/>\$addr16 0000H-3FFFH Immediate data or label (with<br/>uPD78122/78124) Relative<br/>addressing</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          | uPD78112) Immediate addressing                         |    |  |  |
| <pre>addressing \$addr13 0000H-1FFFH Immediate data or label (with</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | !addr16  | 0000H-3FFFH Immediate data or label (with              |    |  |  |
| <pre>\$addr13 0000H-1FFFH Immediate data or label (with</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          | uPD78122/78124) Immediate                              |    |  |  |
| uPD78112) Relative addressing<br>\$addr16 0000H-3FFFH Immediate data or label (with<br>uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          | addressing                                             |    |  |  |
| <pre>\$addr16 0000H-3FFFH Immediate data or label (with<br/>uPD78122/78124) Relative<br/>addressing</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | \$addr13 | 0000H-1FFFH Immediate data or label (with              |    |  |  |
| <pre>\$addr16 0000H-3FFFH Immediate data or label (with<br/>uPD78122/78124) Relative<br/>addressing</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          | uPD78112) Relative addressing                          |    |  |  |
| uPD78122/78124) Relative<br>addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | \$addr16 |                                                        |    |  |  |
| addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | •        |                                                        |    |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                                                        |    |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | addr11   |                                                        |    |  |  |
| addr5 40H-7EH Immediate data (with bit 0 = 0) or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |                                                        |    |  |  |
| label                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |                                                        |    |  |  |

Table C-1. Representation Formats and Description Methods of Operands (contd)

| Representation format | Description method             |
|-----------------------|--------------------------------|
| word                  | 16-bit immediate data or label |
| byte                  | 8-bit immediate data or label  |
| ·bit                  | 3-bit immediate data or label  |
| n                     | 3-bit immediate data (0 - 7)   |
| RBn                   | RB0 - RB3                      |

- NOTE: 1. In register representation formats "r" and "rp", registers may also be described with absolute names (R0 to R7, RP0 to RP3) in addition to absolute names (X, A, C, B, E, D, L, H, AX, BC, DE, HL).
  - 2. In the immediate addressing method, the operand(s) of an instruction can be addressed to any memory space, whereas in the relative addressing method, the operand(s) of an instruction can be addressed only within the range of -128 to +127 bytes from the first address of the next instruction.

| А         | : A register; 8-bit accumulator                  |
|-----------|--------------------------------------------------|
| X         | : X register                                     |
| В         | : B register                                     |
| С         | : C register                                     |
| D         | : D register                                     |
| Е         | : E register                                     |
| Н         | : H register                                     |
| L         | : L register                                     |
| R0-R7     | : Register 0 to register 7 (absolute names)      |
| AX        | : Register pair AX; 16-bit accumulator           |
| BC        | : Register pair BC                               |
| DE        | : Register pair DE                               |
| HL        | : Register pair HL                               |
| RP0-RP3   | : Register pair 0 to register pair 3 (absolute   |
|           | names)                                           |
| PC        | : Program counter                                |
| SP        | : Stack pointer                                  |
| PSW       | : Program status word                            |
| СҮ        | : Carry flag                                     |
| AC        | : Auxiliary carry flag                           |
| Z         | : Zero flag                                      |
| RBS0-RBS1 | : Register bank select flags                     |
| IE        | : Interrupt enable flag                          |
| STBC      | : Standby control register                       |
| ()        | : Refers to the memory contents indicated by the |
|           | address or register in parentheses ( ).          |
| ххH       | : Hexadecimal number                             |
| хH        | : High-order 8 bits of 16-bit register           |
| хL        | : Low-order 8 bits of 16-bit register            |

- (3) Symbols in "Clocks" column
  - (a) If "n" is indicated in the "Clocks" column for a Shift or Rotate instruction, the value of "n" refers to the number of bits to be shifted.
  - (b) The number indicated in ( ) in the "Clocks" column for a conditional branch instruction indicates the number of clocks of the instruction when branching is not executed.
  - (c) When accessing an SFR by register deferred addressing
     ([HL]) or indexed addressing (word[r1]), the latter of the
     two values separated by a slash in the "Clocks" column
     becomes the number of clocks for the instruction.
  - (d) In indexed addressing, if an overflow occurs in the result of "word + r1", the number of clocks of the instruction increases to the number indicated in () in the "Clocks" column for the instruction.

(4) Legend of symbols in "Flag" column

| They contents will remain unchanged        |
|--------------------------------------------|
| Flag contents will remain unchanged.       |
| Flag contents are cleared to 0.            |
| Flag contents are set to 1.                |
| Flag contents are set or cleared according |
| to the result.                             |
| Previously saved contents are restored.    |
|                                            |

(5) Special function registers (SFR) The SFR refers to a group of registers to which special functions have been assigned, such as mode registers for various peripheral devices and control register. The special function register group is mapped to an 256byte area (addresses FF00H to FFFFH). These SFR registers can be manipulated in various ways with arithmetic operation instructions, move (transfer) instructions, and bit manipulation instructions. Table C-1 shows a list of special function registers (SFR) with the uPD78112 and Table C-2 shows the same list with the uPD78122/78124. The meanings of the symbols used in these tables are as follows: o sfr symbol .... Symbol indicating the address of the built-in special function register. This SFR symbol can be described in the Operand field of an instruction. o R/W ..... Indicates whether the special function register is readable or writable. R/W: Read/Write .R: Read only W: Write only o Manipulatable.. Indicates the unit of bits that can be bit units handled when manipulating the contents of each SFR register. If an SFR is capable of manipulation in units of 16 bits, the register can be described as operand "sfrp". If an SFR is capable of 1-bit manipulation, the register can be described in the operand field of a bit manipulation instruction. o At RESET ..... Indicates the status of each register when **RESET** input is applied.

NOTE: In Tables C-1 and C-2, an address to which no special function register is assigned cannot be accessed.

A-12



| Address | Special function<br>register (SFR) | sfr<br>symbol | R/W |                | pulat<br>units | able     | At<br>RESET |
|---------|------------------------------------|---------------|-----|----------------|----------------|----------|-------------|
|         | name                               |               |     | 1              | 8              | 16       |             |
|         | Iname                              |               |     | bit            |                | bits     |             |
| FF01H   | Port 1                             | P1            | R/W | 0              | 0              | _        |             |
| FF02H   | Port 2                             | P2            | R   | 0              | 0              |          |             |
| FF03H   | Port 3                             | P3            |     | 0              | 0              |          |             |
| FF04H   | Port 4                             | P4            | 1   | 0              | 0              | _        |             |
| FF05H   | Port 5                             | P5            | 1   | 0              | 0              |          |             |
| FF06H   | Port 6                             | P6            | 7   | 0              | 0              |          |             |
| FF08H   | 16-bit timer 0/                    | CR00          |     | _              | -              | 0        |             |
| FF09H   | compare register 0                 |               |     | _              | -              |          |             |
| FFOAH   | 16-bit timer 0/                    | CR01          | R/W | _              | _              | 0        |             |
| FFOBH   | compare register 1                 |               |     | _              | _              |          |             |
| FFOCH   | 16-bit timer 0/                    | CR02          |     | _              | -              | 0        |             |
| FFODH   | compare register 2                 |               |     |                | -              |          |             |
| FFOEH   | 16-bit timer 1/                    | CR10          |     | -              | -              | 0        | Un-         |
| FFOFH   | compare register 0                 |               |     | _              | -              |          | known       |
| FF10H   | 16-bit timer 1/                    | CR11          | 1   | -              | _              | 0        | 1           |
| FF11H   | compare register 1                 |               |     | -              |                |          |             |
| FF12H   | 16-bit timer 1/                    | CR12          | 1   | -              | -              | 0        | ]           |
| FF13H   | capture register 2                 |               |     |                | -              |          |             |
| FF14H   | 16-bit FRC                         | CPT0          |     | -              |                | 0        |             |
| FF15H   | capture register 0                 |               |     |                | -              |          |             |
| FF16H   | 16-bit FRC                         | CPT1          | R   |                |                | 0        |             |
| FF17H   | capture register 1                 |               |     |                |                | İ        |             |
| FF18H   | 16-bit FRC                         | CPT2          |     |                |                | 0        |             |
| FF19H   | capture register 2                 |               |     |                |                |          |             |
| FF1AH   | 16-bit FRC                         | CPT3          |     |                | -              | 0        | 1           |
| FF1BH   | capture register 3                 |               |     |                | -              |          |             |
| FF1EH   | 16-bit timer 2/                    | CR20          | R/W |                |                | 0        |             |
| FF1FH   | compare register 0                 |               |     |                | -              |          |             |
| FF21H   | Port 1 mode register               | PM1           |     | <u> </u>       | <u> </u>       |          | <u>3FH</u>  |
| FF23H   | Port 3 mode register               | PM3           | W   | -              | 0              | -        |             |
| FF25H   | Port 5 mode register               | PM5           | 4   | <u> </u>       | 0              |          | FFH         |
| FF26H   | Port 6 mode register               | PM6           |     | _ <del>_</del> | 0              |          |             |
| FF30H   | 16-bit timer/                      | TMO           |     |                | -              | 0        |             |
| FF31H   | register 0                         |               |     | <u> </u>       |                |          |             |
| FF32H   | 16-bit timer/                      | TM1           |     | -              | -              | 0        | 1 77-       |
| FF33H   | register 1                         |               | R   | -              |                |          | Un-         |
| FF34H   | 16-bit free-running                | FRC           |     |                |                | 0        | known       |
| FF35H   | counter                            |               | -   |                |                |          | 4           |
| FF36H   | 16-bit timer/                      | TM2           |     |                | -              | 0        |             |
| FF37H   | register 2                         |               | T.7 | <u> </u>       | <u> </u>       | <u> </u> | <b>+</b>    |
| FF38H   | Timer control                      | TMCO          | W   | -              | 0              |          |             |
|         | register 0                         |               | R/W | <u> </u>       | 0              | -        | 00H         |
| FF39H   | Timer control                      | TMC1          | R/W | -              | 0              |          | 00n         |
|         | register 1                         | <u> </u>      |     | ļ              | <u> </u>       | <u> </u> |             |



Table C-1. List of Special Function Registers (SFR) with uPD78112 (contd)

| Address | Special function                                 | sfr        | R/W | Mani | pulat | able | At               |
|---------|--------------------------------------------------|------------|-----|------|-------|------|------------------|
|         | register (SFR)                                   | symbol     |     |      | units |      | RESET            |
|         | name                                             |            |     | 1    | 8     | 16   |                  |
|         |                                                  |            |     | bit  | bits  | bits |                  |
| FF3AH   | Capture mode register                            | CPTM       |     | -    | 0     | -    |                  |
| FF43H   | Port 3 mode control register                     | PMC3       | W   | -    | 0     | -    | 30н              |
| FF50H   | Input control<br>register                        | ICR        |     | -    | 0     |      |                  |
| FF53H   | Event divider<br>control register                | EDVC       |     | -    | 0     | -    | Un-<br>known     |
| FF68H   | A/D conversion<br>mode register                  | ADM        | R/W |      | 0     | -    | 01H              |
| FF6AH   | A/D conversion<br>sequential compare<br>register | SA         | R   | -    | 0     | -    | Un-<br>known     |
| FF70H   | PWM control register                             | PWMC       |     |      | 0     | _    | 05H <sup>-</sup> |
| FF72H   | PWM modulo register 0                            | PWM0       |     |      | ~     | 0    |                  |
| FF73H   |                                                  |            | W   |      | -     |      | Un-              |
| FF74H   | PWM modulo register 1                            | PWM1       |     | -    | -     | 0    | known            |
| FF75H   |                                                  |            | ļ   |      | -     |      |                  |
| FF80H   | Serial interface mode register                   | CSIM       |     | _    | 0     | _    | 10H              |
| -FF86H  |                                                  | SIO        | R/W | -    | 0     | -    | Un-<br>known     |
| FFCOH   | Standby control<br>register                      | STBC       |     | -    | 0     | -    | 00H              |
| FFC4H   | Memory mapping<br>register                       | ММ         | W   | -    | 0     | -    | 00H              |
| FFEOH   | Interrupt request                                | IFOL IFO   |     | 0    | 0     | 0    | 00H              |
| FFE1H   | flag register                                    | IFOH       |     | 0    | 0     |      | 00H              |
| FFE4H   | Interrupt mask                                   | MKOL MKO   | R/W | 0    | 0     | 0    | FFH              |
| FFE5H   | register                                         | МКОН       | ļ   | 0    | 0     |      | FFH              |
| FFECH   | Interrupt service                                | ISMOL ISMO |     | 0    | 0     | 0    | 00н              |
| FFEDH   | mode register                                    | ISMOH      |     | 0    | 0     |      | 00H              |
| FFF4H   | External interrupt                               | INTMO      | [   | -    | 0     |      | 50H              |
|         | mode register                                    | l          | W   |      |       | _    |                  |
| FFF5H   | External capture<br>input mode register          | INTM1      |     | -    | 0     |      |                  |

.



Table C-2. List of Special Function Registers (SFR) with uPD78122/uPD78124

| Address | Special function<br>register (SFR)     | sfr<br>symbol | R/W |          | pulat<br>units | able       | At<br>RESET |
|---------|----------------------------------------|---------------|-----|----------|----------------|------------|-------------|
|         | -                                      | SYMDOT        | ļ   | 1<br>1   |                | 16         | RESET       |
|         | name                                   |               |     | )<br>bit | 1 - 1          | l6<br>bits |             |
| FF00H   | Port 0                                 | P0            | R/W | 0        | 0              | -          |             |
| FF01H   | Port 1                                 | P1            |     | 0        | 0              |            |             |
| FF02H   | Port 2                                 | P2            | R   | 0        | 0              | _          |             |
| FF03H   | Port 3                                 | P3            |     | 0        | 0              |            |             |
| FF04H   | Port 4                                 | P4            | 1   | 0        | 0              | _          | Un-         |
| FF05H   | Port 5                                 | P5            |     | 0        | 0              |            | known       |
| FF06H   | Port 6                                 | P6            | •   | 0        | 0              |            |             |
| FFOAH   | Port 0                                 | POL           |     | 0        | 0              | <u></u>    |             |
|         | buffer<br>register                     |               |     | Ū        |                | -          |             |
| FFOBH   | Port 0<br>buffer                       | РОН           |     | 0        | 0              |            |             |
|         | register                               |               |     |          |                |            |             |
| FF0CH   | Real-time output port control register | RTPC          |     | 0        | 0              | -          | 00н         |
| FF10H   | 16-bit compare                         | CR00          | R/W | -        | _              | 0          |             |
| FF11H   | register 0                             |               |     |          |                | -          |             |
| FF12H   | 16-bit compare                         | CR01          | •   | _        | -              | 0          |             |
| FF13H   | register 1                             |               |     |          |                | -          |             |
| FF14H   | 8-bit compare                          | CR10          |     |          | 0              |            |             |
|         | register (CH1-0)                       |               |     |          | i              | _          |             |
| FF15H   | 8-bit compare<br>register (CH2-0)      | CR20          |     |          | 0              |            |             |
| FF16H   | 8-bit compare<br>register (CH2-1)      | CR21          |     |          | 0              |            | Un-         |
| FF17H   | 8-bit compare<br>register              | CR30          |     |          | 0              |            | known       |
| FF18H   | 16-bit capture                         | CR02          |     | _        |                | 0          | 1           |
| FF19H   | register                               |               | R   |          | _              | Ŭ          |             |
| FF1AH   | 8-bit capture                          | CR22          |     |          | 0              |            | <b> </b>    |
| TTIAN   | register                               | 01(22         |     |          |                |            |             |
| FF1CH   | 8-bit capture/compare                  | CR11          | R/W |          | 0              |            | 1           |
| 111011  | register (CH1-1)                       | ORT           |     |          | Ŭ              |            |             |
| FF20H   | Port 0 mode register                   | PM0           |     |          | 0              | -          |             |
| FF21H   | Port 1 mode register                   | PM1           |     | _        | 0              |            | FFH         |
| FF23H   | Port 3 mode register                   | PM3           | ]   |          | 0              |            |             |
| FF25H   | Port 5 mode register                   | PM5           |     | -        | 0              |            | FFH         |
| FF26H   | Port 6 mode register                   | PM6           | ]   |          | 0              |            | FFH         |
| FF30H   | Capture/compare                        | CRC0          |     | -        | 0              |            | 10н         |
|         | control register 0                     |               | W   |          |                | -          |             |
| FF31H   | Timer output control<br>register       | TOC           |     | _        | 0              |            |             |
| FF32H   | Capture/compare<br>control register 1  | CRC1          |     | -        | 0              | _          | 00н         |
| FF34H   | Capture/compare<br>control register 2  | CRC2          |     | -        | 0              | _ `        |             |
| FF40H   | Pull-up resistor<br>option register    | PUO           | R/W | 0        | 0              | _          |             |
| FF43H   | Port 3 mode control<br>register        | РМС3          | R/W | 0        | 0              | -          |             |
|         |                                        | [             |     |          |                |            |             |



Table C-2. List of Special Function Registers (SFR) with uPD78122/uPD78124 (contd)

| Address | Special function<br>register (SFR) | sfr<br>symbol | R/W |          | pulat<br>units |            | At<br>RESET |
|---------|------------------------------------|---------------|-----|----------|----------------|------------|-------------|
|         | name                               | _             |     | 1<br>bit | 8<br>bits      | 16<br>bits |             |
| FF50H   | 16-bit timer/                      | TMO           | 1   | -        | -              | 0          |             |
| FF51H   | register 0                         |               |     | -        | +              |            |             |
| FF52H   | 8-bit timer/                       | TM1           | -   | _        | 0              | _          |             |
|         | register: CH-1                     | -             |     |          |                |            | Un-         |
| FF54H   | 8-bit timer/                       | TM2           | R   | -        | 0              |            | known       |
|         | register: CH-2                     |               |     |          |                |            |             |
| FF56H   | 8-bit timer/register               | тмз           |     |          | 0              | -          |             |
|         | for BRG                            |               |     |          |                |            |             |
| FF5CH   | Prescaler mode                     | PRM0          | W   | -        | 0              |            |             |
|         | register 0                         |               |     |          |                | -          |             |
| FF5DH   | Timer control                      | TMCO          | R/W | _        | 0              |            |             |
|         | register O                         |               |     |          |                |            |             |
| FF5EH   | Prescaler mode                     | PRM1          | W   | -        | · 0            |            |             |
|         | register 1                         |               |     |          |                | -          | 00H         |
| FF5FH   | Timer control                      | TMC1          |     | -        | 0              |            |             |
|         | register 1                         |               | R/W |          |                |            |             |
| FF7FH   | Clock output mode                  | CLOM          | 1   | 0        | 0              | -          |             |
|         | register                           |               |     |          |                |            |             |
| FF80H   | Clock-synchronized                 | CSIM          | T   | 0        | 0              |            |             |
|         | serial interface mode              |               |     |          |                |            |             |
|         | register                           |               |     |          |                |            | 00н         |
| FF82H   | Serial bus interface               | SBIC          | 1   | 0        | 0              | _          |             |
|         | control register                   |               |     |          |                |            |             |
| FF86H   | Serial shift register              | SIO           |     | _        | 0              | _          | Un-         |
|         | 3                                  |               |     |          |                |            | known       |
| FFC0H   | Standby control                    | STBC          |     | -        | 0              | _          |             |
|         | register                           |               |     | 1        |                |            |             |
| FFC4H   | Memory expansion                   | MM            |     | 0        | 0              |            | 00н         |
|         | mode register                      |               |     |          |                |            |             |
| FFEOH   | Interrupt request                  | IFOL          | 1   | 0        | 0              |            |             |
|         | flag register L                    |               | R/W |          |                | 0          | 00н         |
| FFE1H   | Interrupt request                  | IFOH          |     | 0        | 0              |            |             |
|         | flag register H                    |               |     | _        |                |            |             |
| FFE4H   | Interrupt mask                     | MKOL          | 1   | 0        | 0              |            |             |
|         | flag register L                    | III.0 L       | 1   | Ŭ        | Ũ              | 0          |             |
| FFE5H   | Interrupt mask                     | мкон          | 1   | 0        | 0              | Ŭ          |             |
|         | flag register H                    | -             |     | _        |                |            | FFH         |
| FFE8H   | Priority                           | PROL          | 1   | 0        | 0              |            |             |
|         | specification                      |               |     | -        |                |            |             |
|         | flag register L                    |               |     |          |                | о          |             |
| FFE9H   | Priority                           | PROH          | 1   | 0        | 0              |            |             |
|         | specification                      | 1 11011       |     | Ĭ        |                |            |             |
|         | flag_register H                    |               |     |          |                |            | -           |
| ι.      | TTAY TEYTOLEL D                    |               |     |          | 1 1            |            |             |



Table C-2. List of Special Function Registers (SFR) Phase-out/Discontinued with uPD78122/uPD78124 (contd)

| Address | Special function<br>register (SFR)<br>name                  | sfr<br>symbol | R/W | - | pulata<br>units<br>8<br>bits | able<br>16<br>bits | At<br>RESET |
|---------|-------------------------------------------------------------|---------------|-----|---|------------------------------|--------------------|-------------|
| FFECH   | Interrupt handling<br>mode specification<br>flag register L | ISMOL         |     | 0 | 0                            | 0                  |             |
| FFEDH   | Interrupt handling<br>mode specification<br>flag register H | ISMOH         |     | 0 | 0                            |                    |             |
| FFF4H   | External interrupt<br>mode register 0                       | INTMO         | R/W | 0 | 0                            | _                  | 00H         |
| FFF5H   | External interrupt<br>mode register 1                       | INTM1         | ]   | 0 | 0                            |                    |             |
| FFF8H   | Interrupt status<br>register                                | IST           |     | 0 | 0                            | -                  |             |

.

Table C-3. Operation of Each uCOM-78K/I Instruction (1/8)

In the table, description "addr13" in the Operand column applies to the uPD78112. For the uPD78122 or uPD78124, change this to read as "addr16".

| Group                   | Mnemonic              | Operand          | tes                                                                                                                | Clocks        | Operation                 |   | lac |    |
|-------------------------|-----------------------|------------------|--------------------------------------------------------------------------------------------------------------------|---------------|---------------------------|---|-----|----|
| čĽ                      |                       |                  | By                                                                                                                 |               |                           | Z | AC  | CY |
|                         |                       | r,#byte          | 2                                                                                                                  | 2             | r ← byte                  |   |     |    |
|                         |                       | saddr,#byte      | 3                                                                                                                  | З             | (saddr) - byte            |   |     |    |
|                         |                       | sir,#byte(Note1) |                                                                                                                    | 5             | sfr byte                  |   |     |    |
|                         |                       | r , r            |                                                                                                                    | 2             | r <del>·</del> · ·        |   |     |    |
|                         |                       | A , r            | 1                                                                                                                  | 2             | A + 7                     |   |     |    |
|                         |                       | A, saddr         | 2                                                                                                                  | 2             | A ← (saddr)               |   |     |    |
|                         |                       | saddr , A        | 2                                                                                                                  | 3             | (saddr) — A               |   |     |    |
| }                       |                       | A, sír           | 2                                                                                                                  | 4             | A — sír                   |   |     |    |
| н<br>Ф                  | it Data Transfer      | sfr.A.           | 2                                                                                                                  | 5             | sfr - A                   |   |     |    |
| ansf                    |                       | A,[r3] (Note2)   | 1                                                                                                                  | 5/6           | A (FE00H+r3) r3-40H-FFH   |   |     |    |
|                         |                       | [r3],A (Note 2)  | 1                                                                                                                  | 5/6           | (FE00H+r3) - A r3-40H-FFH |   |     |    |
| 8-bit Data Transfe<br>X |                       | A.[HL]           | 1                                                                                                                  | 5/7           | A - (HL)                  |   |     |    |
|                         |                       | [HL],A           | An       2       3       3       2       1       2       2       2       2       2       1       1       1       4 | 5/7           | (HL) - A                  |   |     |    |
| Data                    | 8-bit Data            | A,word[r1]       | 4                                                                                                                  | 7(8)<br>/900  | $A \leftarrow (word+r1)$  |   |     |    |
|                         |                       | word[r1],A       | 4                                                                                                                  | 7 (8)<br>/900 | (word+r1) - A             |   |     |    |
|                         |                       | PSW,#byte        | 3                                                                                                                  | 5             | PSW - byte                | × | ×   | ×  |
|                         |                       | PSW, A           | 2                                                                                                                  | 5             | PSW - A                   | × | ×   | x  |
|                         |                       | A, PSW           | 2                                                                                                                  | 4             | A - PSW                   |   |     |    |
|                         |                       | A,r              | 1                                                                                                                  | 4             | A 7                       |   |     |    |
|                         |                       | A, saddr         | 2                                                                                                                  | 4             | A 🕶 (sæddr)               |   |     |    |
|                         | хсн                   | A, 3 Í T         | 3                                                                                                                  | 10            | A 🕶 sír                   |   |     |    |
|                         | -                     | A.[r4]           | 1                                                                                                                  | 8             | A (FE00H+r4) r4-40H-FFH   |   |     |    |
|                         |                       | rp,#word         | 3                                                                                                                  | 3             | rp ← word                 |   |     |    |
| er                      |                       | saddrp,#word     | 4                                                                                                                  | 4             | (saddrp+1)(saddrp) ↔ word |   |     |    |
| ansi                    |                       | sirp,#word       | 4                                                                                                                  | 8             | sfrp ← word               | Z |     |    |
|                         |                       | rp, rp           | 2                                                                                                                  | 4             | rp rp                     |   |     |    |
| Data                    | Data Transf<br>M<br>M | AX.saddrp        | 2                                                                                                                  | 6             | AX (saddrp+1)(saddrp)     |   |     |    |
|                         | ľ                     | saddrp,AX        | 2                                                                                                                  | 5 ·           | (saddrp+1)(saddrp) - AX   |   |     |    |
| 16-bit                  |                       | AX.sfrp          | 2                                                                                                                  | 10            | AX — sírp                 |   |     |    |
|                         |                       | sfrp,AX          | 2                                                                                                                  | 9             | sfrp - AX                 |   |     |    |

- NOTE: 1. If the STBC register is described as the operand "sfr" of a MOV instruction, this instruction becomes a dedicated instruction which differs from that shown in this table in the number of bytes and the number of clocks. (See CPU control instructions.)
  - 2. If "E+" is described in the operand "r3" of a MOV instruction, the contents of the E register are incremented by 1 after the execution of the MOV instruction and the number of clocks becomes 6.

.

Table C-3. Operation of Each uCOM-78K/I Instruction (2/8)

| Group     | Mnemonic | Operand     | Bytes | Clocks | Operation                                  |   | Fla | ag  |
|-----------|----------|-------------|-------|--------|--------------------------------------------|---|-----|-----|
| Ĕ         |          |             | B     |        |                                            | z | ٨   | :03 |
|           |          | A,#byte     | 2     | 2      | A,CY - A+byte                              | × | ×   | ×   |
|           |          | saddr,#byte | 3     | 3      | (saddr),CY ← (saddr)+byte                  | × | ×   | ×   |
|           |          | sfr,#byte   | 4     | 9      | sir,CY - sir+byte                          | × | ×   | ×   |
|           | ADD      | r , r       | 2     | 3      | $r,CY \leftarrow r + r$                    | × | ×   | ×   |
|           | ADD      | A, saddr    | 2     | 3      | $A,CY \leftarrow A+(saddr)$                | × | ×   | ×   |
|           |          | A, sfr      | 3     | 7      | A,CY - A+sfr                               | × | ×   | ×   |
|           |          | A,[r4]      | 2     | 7      | $A, CY \leftarrow A+(FE00H+r4)$ r4-40H-FFH | × | x   | ×   |
|           |          | A,[HL]      | 2     | 8/10   | $A,CY \leftarrow A+(HL)$                   | × | x   | ×   |
|           |          | A,#byte     | 2     | 2      | A,CY - A+byte+CY                           | × | ×   | ×   |
|           |          | aaddr,#byte | 3     | З      | (saddr),CY (saddr)+byte+CY                 | × | ×   | ×   |
|           |          | sfr,#byte   | 4     | 9      | sfr,CY + sfr+byte+CY                       | × | ×   | ×   |
|           |          | r , r       | 2     | 3      | r,CY + r+r+CY                              | × | x   | ×   |
| operation | ADDC     | A, saddr    | 2     | з      | A,CY - A+(saddr)+CY                        | × | ×   | ×   |
| 1<br>1    |          | A,sír       | 3     | 7      | A,CY - A+sir+CY                            | × | ×   | ×   |
|           |          | А,[т4]      | 2     | 7      | A.CY-A+(FE00H+r4)+CY r4-40H-FFH            | × | x   | x   |
|           |          | A.[HL]      | 2     | 8/10   | A,CY A+(HL)+CY                             | × | x   | ×   |
|           |          | A,#byte     | 2     | 2      | A,CY - A-byte                              | x | x   | ×   |
|           |          | saddr,#byte | 3     | 3      | (saddr),CY - (saddr)-byte                  | × | ×   | ×   |
|           | }•<br>   | sír,#byte   | 4     | 9      | afr,CY - sfr-byte                          | × | ×   | ×   |
| 5         | SUB      | г., г       | 2     | 3      | r,CY + r-r                                 | × | x   | ×   |
|           |          | A, saddr    | 2     | 3      | A,CY - A-(saddr)                           | × | x   | x   |
|           | ŀ        | A, sír      | 3     | 7      | A,CY - A-afr                               | × | ×   | ×   |
|           | -        | A,[r4]      | 2     | 7      | A,CY - A-(FE00H+r4) r4-40H-FFH             | × | ×   | ×   |
|           |          | A,[HL]      | 2     | 8/10   | A,CY - A-(HL)                              | × | x   | x   |
|           |          | A,#byle     | 2     | 2      | A,CY - A-byte-CY                           | × | ×   | ×   |
|           |          | addr,#byte  | 3     | 3      | (saddr),CY + (saddr)-byte-CY               | × | x   | ×   |
|           |          | sfr,#byte   | 4     | 9      | sfr,CY + sfr-byte-CY                       | × | ×   | ×   |
|           |          | r , r       | 2     | 3      | r, CY - r - r - CY                         | × | ×   | ×   |
|           | SUBC     | A, saddr    | 2     | 3      | $A,CY \leftarrow A-(saddr)-CY$             | × | ×   | x   |
|           | 7        | A sfr       | 3     | 7      | A,CY - A-sfr-CY                            | × | ×   | ×   |
|           | 7        | .[r4]       | 2     | 7      | A,CY+-A-(FE00H+r4)-CY r4-40H-FFH           | × | ×   | ×   |
|           | 5        | .[HL]       | 2     |        | $A, CY \leftarrow A-(HL)-CY$               | × | ×   | ×   |

Table C-3. Operation of Each uCOM-78K/I Instruction (3/8)

| dno.  |            |             | es    |               | Operation                                               | Flag | 3  |
|-------|------------|-------------|-------|---------------|---------------------------------------------------------|------|----|
| Grou  | Mnemonic   | Operand     | Bytes | Clocks        | operation                                               | Z AC | CY |
|       |            | A,#byte     | 2     | 2             | A - AAbyte                                              | ×    |    |
|       |            | saddr,#byte | 3     | 3             | (saddr) - (aaddr) Abyte                                 | ×    |    |
|       |            | sír,#byte   | 4     | 9             | sfr ← sfr∧byte                                          | ×    |    |
|       |            | г. г        | 2     | 3             | r ← r∧r                                                 | ×    |    |
|       | AND        | A, saddr    | 2     | 3             | A ← A∧(saddr)                                           | ×    |    |
|       |            | A,sfr       | 3.    | 7             | A ← A∧sír                                               | ×    |    |
|       |            | A.[r4]      | 2     | 7             | $A \leftarrow A \land (FE00H+r4)$ r4-40H-FFH            | ×    |    |
|       |            | A,[HL]      | 2     | 8/10          | $\mathbf{A} \leftarrow \mathbf{A} \wedge (\mathbf{HL})$ | ×    |    |
|       |            | A,#byle     | 2     | 2             | A - AVbyte                                              | ×    |    |
|       |            | saddr,#byte | 3     | 3             | (saddr) - (saddr)Vbyte                                  | ×    |    |
| ñ     |            | sír,#byte   | 4     | 9             | sfr - sfr V byte                                        | ×    |    |
| atic  |            | r , r       | 2     | 3             | r ← r∨r                                                 | ×    |    |
|       | A, aaddr   | 2           | 3     | A - AV(saddr) | ×                                                       |      |    |
|       |            | A,sfr       | 3     | 7             | A - AVsir                                               | ×    |    |
| met   | Arithmetic | A.[:4]      | 2     | 7             | $A \leftarrow A \lor (FE00H+r4)$ r4-40H-FFH             | ×    |    |
| ith   |            | A,[HL]      | 2     | 8/10          | $A - A \vee (HL)$                                       | ×    |    |
|       |            | A,#byte     | 2     | 2             | A ← A∀byte                                              | ×    |    |
| 8-bit |            | aaddr,#byte | 3 .   | 3             | (saddr) ← (saddr)∀byte                                  | ×    |    |
| 8     |            | sfr,#byte   | 4     | 9             | sír ← sír∀byte                                          | ×    |    |
|       |            | r.r         | 2     | 3             | r ← r∀r                                                 | ×    |    |
|       | XOR        | A, saddr    | 2     | 3             | $A \leftarrow A \forall (saddr)$                        | ×    |    |
|       |            | A,sír       | 3     | 7             | A ← A∀sir                                               | ×    |    |
|       |            | A,[14]      | 2     | 7             | $A \leftarrow A \forall (FE00H+r4)$ r4-40H-FFH          | ×    |    |
|       |            | A,[HL]      | 2     | 8/10          | $A \leftarrow A \forall (HL)$                           | ×    |    |
|       |            | A,#byte     | 2     | 2             | A - byte                                                | ××   | ×  |
|       |            | saddr,#byte | 3     | 3             | (saddr) - byte                                          | ××   | ×  |
|       |            | sír,#byte   | 4     | 7             | sfr — byte                                              | ××   | ×  |
|       |            | r , r       | 2     | 3             | r – r                                                   | ××   | ×  |
|       | СМР        | A.saddr     | 2     | 3             | A - (saddr)                                             | ××   | ×  |
|       | СМР        | A,sfr       | 3     | 7             | A — sfr                                                 | ××   | ×  |
|       |            | A.[r4]      | 2     | 7             | A - (FE00H+r4) r4-40H-FFH                               | ××   | ×  |
|       |            | A.[HL]      | 2     | 8/10          | A - (HL)                                                | × ×  | ×  |

•

.

Table C-3. Operation of Each uCOM-78K/I Instruction (4/8)

| Group               | Mnemonio | Operand    | Bytes | Clocks | Operation                                                                                                                  | 7        | "     |
|---------------------|----------|------------|-------|--------|----------------------------------------------------------------------------------------------------------------------------|----------|-------|
| Gro                 | Miemonic | operand    | Ву    |        |                                                                                                                            | Z        | лс сү |
|                     |          | AX.#word   | 3     | 4      | AX,CY - AX+word                                                                                                            | ×        | ××    |
| с                   |          | AX, 1 p    | 2     | 6      | AX,CY - AX+rp                                                                                                              | ×        | ××    |
| Operation           | ADDW     | AX, saddrp | 2     | 7      | AX,CY ← AX+(saddrp+1)(saddrp)                                                                                              | ×        | хх    |
| ега                 |          | AX, sfr    | 3     | 13     | AX,CY ← AX+sirp                                                                                                            | ×        | x x   |
|                     |          | AX,#word   | 3     | 4      | AX.CY - AX-word                                                                                                            | ×        | x x   |
| Arithmetic          |          | АХ,тр -    | 2     | 6      | AX,CY ← AX-rp                                                                                                              | ×        | х×    |
| thm                 | SUBW     | AX, saddrp | 2     | 7      | AX,CY - AX-(saddrp+1)(saddrp)                                                                                              | ×        | x x   |
|                     |          | AX,sirp    | 3     | 13     | $AX, CY \leftarrow AX - a frp$                                                                                             | ×        | хх    |
| 6-bit               |          | AX,#word   | 3     | 3      | AX - word                                                                                                                  | x        | хх    |
| 16-                 |          | АХ, тр     | 2     | 5      | AX — rp                                                                                                                    | ×        | x x   |
|                     | CMPW     | AX, saddrp | 2     | 6      | AX - (saddrp+1)(saddrp)                                                                                                    | x        | x x   |
|                     |          | AX,sfrp    | 3     | 12     | AX — sfrp                                                                                                                  | x        | × ×   |
|                     | MULUW    | r          | 2     | 43     | AX(low 16 bits), r(high 16 bits) - AX × r                                                                                  |          |       |
| Divide              | DIVUW    | т          | 2     | 71     | $AX(quo), r(rem) \rightarrow AX \div r$                                                                                    |          |       |
| ,<br>ut             |          | г          | 1     | 2      | r ← r+1                                                                                                                    | ×        | x     |
| eme<br>Leme         | INC      | saddr      | 2     | 2      | (saddr) - (saddr)+1                                                                                                        | ×        | ×     |
| Increment/Decrement |          | r          | 1     | 2      | r + r - 1                                                                                                                  | ×        | ×     |
| "nt/                | DEC      | saddr      | 2     | 2      | (sæddr) ← (sæddr)-1                                                                                                        | ×        | ×     |
| reme                | INCW     | гр         | 1     | 3      | rp ← rp+1                                                                                                                  | <u> </u> |       |
| U<br>U<br>U<br>U    | DECW     | гр         | 1     | 3      | rp + rp - 1                                                                                                                |          |       |
|                     | ROR      | r, n       | 2     | 3+2 n  | $(CY, r_7 - r_0, r_{m-1} - r_m) \times nT$ n=0-7                                                                           |          | ×     |
|                     | ROL      | r , n      | 2     | 3+2 n  | $(CY, r_0 - r_7, r_{m+1} - r_m) \times nT$ n=0-7                                                                           |          | ×     |
|                     | RORC     | r, n       | 2     | 3+2 n  | $(CY - r_0, r_7 - CY, r_{m-1} - r_m) \times nT = n - 0 - 7$                                                                |          | ×     |
|                     | ROLC     | r , n      | 2     | 3+2 n  | $(CY+r_{7}, r_{0}+CY, r_{m+1}+r_{m}) \times nT = n=0-7$                                                                    |          | ×     |
| ני                  | SHR      | r , n      | 2     | 3+2 n  | $(CY - r_0, r_7 - 0, r_{m-1} - r_m) \times nT$ n=0-?                                                                       | x        | 0 X   |
| CC C                | SHL      | r , n      | 2     | 3+2л   | $(CY \leftarrow r_7, r_0 \leftarrow 0, r_{m+1} \leftarrow r_m) \times nT$ $n=0-7$                                          | ×        | 0 X   |
| SNITT/KOTATE        | Shrw     | rp,n       | 2     | 3+3 n  | (CYrp0, rp15-0, rpm-1rpm)× nT n-0-7                                                                                        | ×        | 0 ×   |
| IUS                 | Shlw     | rp, n      | 2     | 3+3 n  | (CY-rp15, rp0-0, rpm+1-rpm)×nT n=0-7                                                                                       | ×        | 0 X   |
|                     | ROR4     | [r4]       | 2     | 22     | $A_{3-0} \leftarrow (FE00+r4)_{3-0},$<br>(FE00+r4)_{7-4} \leftarrow A_{3-0}.<br>(FE00+r4)_{3-0} \leftarrow (FE00+r4)_{7-4} |          |       |
|                     | ROL4     | [74]       | 2     | 23     | $A_{3-0} \leftarrow (FE00+r4)_{7-4},$<br>(FE00+r4)_{3-0} \leftarrow A_{3-0},<br>(FE00+r4)_{7-4} \leftarrow (FE00+r4)_{3-0} |          |       |

\* quo: quotient rem: remainder nT : n times

Table C-3. Operation of Each uCOM-78K/I Instruction (5/8)

| dno          | <u> </u> |               | es    |        | Operation                                    | Fla  | 1g |
|--------------|----------|---------------|-------|--------|----------------------------------------------|------|----|
| Grou         | Mnemoni  | Operand       | Bytes | Clocks |                                              | 2 AC | CY |
| Ľt.          | ADJBA    |               | 1     | 3      | Decimal Adjust Accumulator<br>after Addition | хx   | ×  |
| BCD<br>Adjus | ADJBS    |               | 1     | 3      | Decimal Adjust Accumulator<br>after Subtract | × ×  | ×  |
| <u>ш~</u>    |          | CY, saddr.bit | 3     | 5      | CY - (saddr.bit)                             |      | ×  |
|              |          | CY,sfr.bit    | 3     | 7      | CY + sir.bit                                 |      | ×  |
|              |          | CY,A.bit      | 2     | 5      | CY + A.bit                                   |      | ×  |
|              |          | CY,X.bit      | 2     | . 5    | CY - X.bit                                   |      | ×  |
|              |          | CY, PSW. bit  | 2     | 5      | CY - PSW.bit                                 |      | ×  |
|              | MOV1     | saddr.bit.CY  | 3     | 8      | (saddr.bit) ← CY                             |      |    |
|              |          | sfr.bit,CY    | 3     | 12     | sfr.bit - CY                                 |      |    |
|              |          | A.bit,CY      | 2     | 8      | A.bit - CY                                   |      |    |
|              |          | X.bit,CY      | 2     | 8      | $X.bit \leftarrow CY$                        |      |    |
|              |          | PSW.bit,CY    | 2     | 7      | PSW.bit - CY                                 | хx   |    |
|              |          | CY,saddr.bit  | 3     | 5      | CY + CY A (saddr.bit)                        |      | ×  |
| Manipulation |          | CY,/saddr.bit | 3     | 5      | $CY \leftarrow CY \land (saddr.bit)$         |      | ×  |
|              |          | CY,sfr.bit    | 3     | 7      | $CY \leftarrow CY \land sir.bit$             |      | x  |
| [ndi         |          | CY,/sfr.bit   | 3     | 7      | $CY \leftarrow CY \land \overline{sir.bit}$  |      | x  |
| Man          |          | CY, A. bit    | 2     | 5      | CY - CY A A.bit                              |      | ×  |
| Bit          | AND1.    | CY,/A.bit     | 2     | 5      | CY - CY A A. bit                             |      | x  |
| I            |          | CY,X.bit      | 2     | 5      | CY - CY A X. bit                             |      | ×  |
|              |          | CY,/X.bit     | 2     | 5      | $CY - CY \wedge \overline{X.bit}$            |      | ×  |
|              |          | CY,PSW.bit    | 2     | 5      | CY - CY A PSW. bit                           |      | ×  |
|              |          | CY /PSW. bit  | 2     | 5      | CY - CY A PSW. bit                           |      | ×  |
|              |          | CY,saddr.bit  | 3     | 5      | CY ← CY ∨ (saddr.bit)                        |      | ×  |
|              |          | CY./saddr.bit | 3     | 5      | $CY \leftarrow CY \lor (saddr.bit)$          |      | ×  |
|              |          | CY,sfr.bit    | 3     | 7      | $CY - CY \vee sir.bit$                       |      | ×  |
|              |          | CY,/sfr.bit   | 3     | 7      | CY - CY V sfr.bit                            |      | x  |
|              |          | CY,A.bit      | 2     | 5      | CY - CY V A. bit                             |      | ×  |
|              | OR1      | CY,/A.bit     | 2     | 5      | $CY - CY \vee \overline{A.bit}$              |      | ×  |
| ĺ            | ĺ        | СУ,Х.Ьіц      | 2     | 5      | $CY \leftarrow CY \lor X.bit$                |      | ×  |
|              |          | CY./X.bit     | 2     | 5      | $CY - CY \vee \overline{X.bit}$              |      | ×  |
|              |          | CY, PSW. bit  | 2     | 5      | CY - CY V PSW.bit                            |      | ×  |
|              |          | CY,/PSW.bit   | 2     | 5      | $CY - CY \vee \overline{PSW.bit}$            |      | ×  |

.

÷

Table C-3. Operation of Each uCOM-78K/I Instruction (6/8)

| dn           |          | 0              | es    |        | Operation                                                                                                                         | Fl                  | ag   | 1  |
|--------------|----------|----------------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------|---------------------|------|----|
| Group        | Mnemonic | Operand        | Bytes | Clocks | operación                                                                                                                         | ΖA                  | .C.( | СҮ |
|              |          | CY, saddr; bit | 3     | 5      | CY ← CY ♀ (saddr,bit)                                                                                                             |                     |      | x  |
|              |          | CY, afr. bit   | 3     | 7      | CY - CY ¥ sfr.bit                                                                                                                 | -                   |      | x  |
|              | XOR1     | CY,A.bit       | 2     | 5      | CY - CY V A. bit                                                                                                                  |                     |      | x  |
|              |          | CY.X. b1 t     | 2     | 5      | CY - CY V X.bit                                                                                                                   |                     |      | x  |
|              |          | CY, PSW. bit   | 2     | 5      | CY - CY + PSW. bit                                                                                                                |                     | -    | x  |
|              |          | saddr.bit      | 2     | 3      | (saddr.bit) - 1                                                                                                                   | -                   |      |    |
|              |          | afr,bit        | 3     | 10     | sfr.bit - 1                                                                                                                       | 1                   |      |    |
|              | SET1     | A, bit         | 2     | 6      | A.bit - 1                                                                                                                         |                     |      |    |
| Ë            |          | X.bit          | 2     | 6      | X.bit 1                                                                                                                           |                     |      |    |
| atic         |          | PSW.bit        | 2     | 5      | PSW.bit - 1                                                                                                                       | ×                   | ×    | ×  |
| Manipulation | CLR1     | saddr.bit      | 2     | 3      | (saddr.bit) - 0                                                                                                                   |                     |      |    |
| inst         |          | sfr.bit        | 3     | 10     | sfr.bit + 0                                                                                                                       |                     |      |    |
| Bit 1        |          | A,bit          | 2     | 6      | A.bit - 0                                                                                                                         |                     |      |    |
| μΩ           |          | X.bit          | 2     | 6      | X.bit - 0                                                                                                                         |                     |      |    |
|              |          | PSW.bit        | 2     | 5      | PSW.bit ← 0                                                                                                                       | <b>x</b> · <b>x</b> | ĸ    | ×  |
|              | · · · •  | saddr.bit      | 3     | 6      | (saddr.bit) ← (saddr.bit)                                                                                                         |                     |      |    |
|              |          | sfr.bit        | 3     | 10     | sfr.bit - sfr.bit                                                                                                                 |                     |      |    |
|              | NOTI     | A. bit         | 2     | 6      | A.bit - A.bit                                                                                                                     |                     |      |    |
|              |          | X.bit          | 2     | 6      | $X.bit \leftarrow \overline{X.bit}$                                                                                               |                     |      |    |
|              |          | PSW.bit        | 2     | 5      | PSW.bit + PSW.bit                                                                                                                 | ×                   | ×    | ×  |
|              | SET1     | CY             | 1     | 2      | CY - 1                                                                                                                            |                     |      | 1  |
|              | CLR1     | СҮ             | 1     | 2      | CY - 0                                                                                                                            |                     |      | 0  |
|              | NOTI     | СҮ             | 1     | 2      | $CY \leftarrow \overline{CY}$                                                                                                     |                     |      | ×  |
|              | CALL     | laddr 13       | 3     | 9      | $(SP-1)(SP-2) \leftarrow PC+3, PC \leftarrow laddr13,$<br>SP $\leftarrow$ SP-2                                                    |                     |      |    |
| urn          | CALLF    | laddr11        | 2     | 9      | $(SP-i)(SP-2) \leftarrow PC+2, PC_{12-11} \leftarrow 01,$<br>$PC_{10-0} \leftarrow laddr11, SP \leftarrow SP-2$                   |                     |      |    |
| Call/Return  | CALLT    | [addr5]        | 1     | 12     | $(SP-1)(SP-2) \leftarrow PC+1, PC_{H} \leftrightarrow$<br>(addr 5+1), PC <sub>L</sub> $\leftarrow$ (addr 5), SP $\leftarrow$ SP-2 |                     |      |    |
| Call         | RET      |                | 1     | 8      | $PC_{L} \leftarrow (SP), PC_{H} \leftarrow (SP+1), SP \leftarrow SP+2$                                                            |                     |      |    |
|              | RET I    |                | 1     | 10     | $PC_{L} \leftarrow (SP), PC_{H} \leftarrow (SP+1), PSW \leftarrow (SP+2), SP \leftarrow SP+3$                                     | RI                  | R,   | R  |

Table C-3. Operation of Each uCOM-78K/I Instruction (7/8)

| dno                         | Mnemoni | Operand                              | Bytes | Clocks | Operation                                                                | F       | la    | g      |
|-----------------------------|---------|--------------------------------------|-------|--------|--------------------------------------------------------------------------|---------|-------|--------|
| СĽ                          |         |                                      | B     |        |                                                                          | 2       | ٨C    | сy     |
|                             | PUSH    | rp                                   | 1     | 7      | $(SP-1) \leftarrow r_{PH}, (SP-2) \leftarrow r_{PL}, SP \leftarrow SP-2$ |         |       |        |
| ion                         | 100     | PSW                                  | 1     | 3      | (SP-1) - PSW, SP - SP-1                                                  |         |       |        |
| Manipulation                | POP     | rp                                   | 1     | 8      | rpL + (SP), rpH + (SP+1), SP + SP+2                                      |         |       |        |
| nip                         | ror     | PSW                                  | 1     | 4      | PSW (SP), SP SP+1                                                        | R       | R     | R      |
|                             |         | SP,#byte                             | З     | 5      | SP - byte                                                                |         |       |        |
| Stack                       | моч     | SP,A                                 | 2.    | 5      | SP - A                                                                   |         |       |        |
| st                          |         | A.SP                                 | 2     | · 4    | A - SP                                                                   |         |       |        |
| <u>.</u>                    |         | !addr13                              | 3     | 5      | PC - laddr13                                                             |         |       |        |
| ond<br>na l                 | BR.     | гр                                   | 2     | 5      | $PC_{H} \leftarrow r_{PH}, PC_{L} \leftarrow r_{PL}$                     |         |       |        |
| Uncondi<br>tional<br>Branch |         | \$addr13                             | . 2   | 4      | PC - Saddr13                                                             |         |       |        |
|                             | BC      |                                      |       |        |                                                                          |         |       |        |
|                             | BL      | Saddr13                              | 2     | 4(2)   | PC \$addr13 if CY-1                                                      |         |       |        |
|                             | BNC     |                                      | 2     | 4(2)   |                                                                          |         | ····  |        |
|                             | BNL     | Saddr13                              |       |        | PC ← \$addr13 if CY-0                                                    |         |       |        |
|                             | BZ      |                                      |       |        |                                                                          |         |       |        |
|                             | BE      | \$addr13 2 4(2) PC ← \$addr13 if 2-1 |       |        |                                                                          |         |       |        |
| ے ا                         | BNZ     | ·····                                |       |        |                                                                          |         |       | -      |
| Branch                      | BNE     | \$addr13                             | 2     | 4(2)   | PC - Saddrl3 if Z-0                                                      |         |       |        |
|                             |         | saddr.bit,Saddr13                    | 3     | 6(4)   | PC - Saddr13 if (saddr.bit)-1                                            |         |       |        |
| Conditional                 |         | sfr.bit,\$addr13                     | 4     | 9(7)   | PC - \$addr13 if sfr.bit-1                                               | -       |       |        |
| liti                        | BT      | A.bit,Saddr13                        | 3     | 7(5)   | PC - \$=ddr13 if A.bit-1                                                 |         |       |        |
| Cond                        | -       | X.bit,\$addr13                       | 3     | 7(5)   | PC - \$addr13 if X.bit-1                                                 | <b></b> |       | -      |
| -                           | ŀ       | PSW.bit,\$addr13                     | 3     | 7(5)   | PC - Saddr13 if PSW.bit-1                                                |         |       | $\neg$ |
| ľ                           |         | saddr.bit,\$addr13                   | 4     | 7(5)   | PC - \$addr13 if (saddr.bit)-0                                           |         |       |        |
|                             | ŀ       | sīr.bit,Saddr13                      |       |        | PC \$addr13 if sfr.bit=0                                                 | ·       |       |        |
|                             | BF      | A.bit,\$addr13.                      | 3     |        | PC ← Saddr13 if A.bit=0                                                  |         | ····- |        |
|                             | -       | X.bit.\$addr13                       | 3     |        | PC ← \$sddr13 if X.bit-0                                                 |         | ·     | $\neg$ |
|                             | ŀ       | PSW.bit,\$addr13                     | 3     |        | PC ← \$addr13 if PSW.bit=0                                               |         |       | -      |

Table C-3. Operation of Each uCOM-78K/I Instruction (8/8)

| d'n      | Mnemonic |                                       | es    |        | Operation                                                        | Flag  |
|----------|----------|---------------------------------------|-------|--------|------------------------------------------------------------------|-------|
| Group    |          | Operand                               | Byte: | Clocks |                                                                  | ZACCY |
| 4        |          | saddr.bit,\$addr13                    | 4     | 9(5)   | PC - Saddr13 if (saddr.bit)-1<br>then reset (saddr.bit)          |       |
| ranch    |          | sfr.blt,\$addr13                      | 4     | 13(7)  | PC Saddr13 if sfr.bit-1<br>then reset sfr.bit                    |       |
| tional B | BTCLR    | A.bit,\$addr13                        | 3     | 9(5)   | PC ← \$addr13 if A.bit=1<br>then reset A.bit                     |       |
|          |          | X.bit,\$sddr13                        | Э     | 9(5)   | PC - Saddr13 if X, bit=1<br>then reset X, bit                    |       |
|          |          | PSW.bit.Saddr13                       | 3     | 8(5)   | PC \$addr13 if PSW. bit=1<br>then reset PSW. bit                 | x     |
| Condi    | DBNZ     | r 2 , \$ a d d r 1 3                  | 2     | 5(3)   | $r2 \leftarrow r2-1$ , then PC \leftarrow \$addr13 if $r2\neq 0$ |       |
|          |          | saddr, Saddr13                        | 3     | 6(4)   | saddr — saddr — 1,<br>then PC ← Saddr13 if saddr ≠ 0             |       |
|          | моч      | STBC,#byte                            | 4     | 12     | STBC - byte                                                      |       |
| Control  | SEL      | RBn                                   | 2     | 2      | RBS1-0 - n n-0-3                                                 |       |
| Cont     | NOP      |                                       | 1     | 2      | No Operation                                                     |       |
| CPU      | EI       | · · · · · · · · · · · · · · · · · · · | 1     | 2      | 1E ←1 (Enable Interrupt)                                         |       |
|          | DI       |                                       | 1     | 2      | IE -0 (Disable Interrupt)                                        |       |

٢

### (1) Legend of symbols in "Instruction Code" column

| R, | R <sub>1</sub> | R. |     |   |
|----|----------------|----|-----|---|
| R. | R,             | R. | reg |   |
| 0  | 0              | 0  | RO  | x |
| 0  | 0              | 1  | R1  | A |
| 0  | 1              | 0  | R2  | С |
| 0  | 1              | 1  | RЭ  | B |
| 1  | 0              | 0  | R4  | Е |
| 1  | 0              | 1  | R5  | Ð |
| 1  | 1              | 0  | R6  | L |
| 1  | 1              | 1  | R7  | Н |

| r 1 |     |
|-----|-----|
| R : | reg |
| 0   | A   |
| 1   | В   |
|     |     |

| reg |
|-----|
| С   |
| В   |
|     |

| г З |     |     |
|-----|-----|-----|
| R i | R.  | reg |
| 0   | 0   | E   |
| 0   | 1   | E+  |
| 1   | 0   | D   |
|     | • • |     |

| r 4 |     |
|-----|-----|
| R,  |     |
| R,  | reg |
| R4  |     |
| 0   | E   |
| 1   | D   |

|   | rp |     |          |    |  |  |
|---|----|-----|----------|----|--|--|
| Ì | P1 | P۰  |          |    |  |  |
|   | Ρ, | P۱  | reg-pair |    |  |  |
| ĺ | P. | P 5 |          |    |  |  |
|   | 0  | 0   | RP0      | AX |  |  |
|   | 0  | 1   | RP1      | вс |  |  |
| · | 1  | · 0 | RP2      | DE |  |  |
|   | 1  | 1   | RP3      | HL |  |  |

: Immediate data corresponding to "bit" Bn : Immediate data corresponding to "n" Nn : 8-bit immediate data corresponding to "byte" Data : 16-bit immediate data corresponding to "word" Low/High Byte : Low-order 8-bit offset data of the 16-bit Saddr-offset address corresponding to "saddr" : Low-order 8-bit offset data of the 16-bit Sfr-offset address corresponding to "sfr" (special function register) Low/High offset: 16-bit offset data corresponding to "word" in indexed addressing Low/High Addr. : 16-bit immediate data corresponding to "addr13"

|       | Phase-our biocon                                                        |
|-------|-------------------------------------------------------------------------|
| jdisp | : Signed twos complement data (8 bits) of                               |
|       | relative address distance between the first                             |
|       | address of the next instruction and the                                 |
|       | branch destination address                                              |
| fa    | : Low-order 11 bits of the immediate data                               |
|       | corresponding to "addr11"                                               |
| ta    | : Low-order 5 bits of the immediate data corresponding to "addr5 x 1/2" |
|       |                                                                         |

Note: If the 1st and 2nd operands in the Operand field of an instruction are both registers or register pairs, the instruction code becomes as follows: Of the byte specifying registers, the high-order 4 bits of the byte become a code specifying the 2nd operand and the low-order 4 bits becomes a code specifying the 1st operand.

Example: MOV r,r

Instruction code

0 0 1 0 0 1 0 0 0 R.R.R. 0 R.R.R.

To specify A register as the 1st operand and L register as the 2nd operand, describe the MOV instruction as follows:

MOV A, L

The instruction code for this instruction becomes as follows:

Instruction code

00100100010010001

Code specifying A register

Discontinu

Code specifying L register

# Table C-4. uCOM-78K/I Instruction Codes (1/7)

| ि क्ष    | 1        |              |                                                        | Instruction (                         | Code       |             |
|----------|----------|--------------|--------------------------------------------------------|---------------------------------------|------------|-------------|
| Group    | Mnemonic | Operand      | B 1                                                    | B 2                                   | В 3        | B 4         |
| <u> </u> |          | r,#byte      | 1011 1 R <sub>1</sub> R <sub>1</sub> R <sub>0</sub>    | Data                                  |            |             |
|          |          | saddr,#byte  | 00111010                                               | - Saddr-offset -                      | Data       |             |
|          |          | sfr,#byte    | 00101011                                               | - Sir-offset -                        | Data       |             |
|          |          | r , r        | 00100100                                               | 0 R. R. R. 0 R. R. R. R.              |            |             |
|          |          | A,r          | 1 1 0 1 0 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> |                                       |            |             |
|          |          | A, saddr     | 0010 0000                                              | - Saddr-offset -                      |            |             |
|          |          | saddr.A      | 00100010                                               | - Sæddr-offset -                      |            |             |
|          |          | A, sfr       | 0001 0000                                              | - Sfr-offset -                        |            |             |
| fer      | MON      | sfr,A        | 0 0 0 1 0 0 1 0                                        | + Sir-offset +                        |            |             |
| Transfer | ΜΟΥ      | A,[r3]       | 0 1 1 1 1 1 R, Ro                                      |                                       |            |             |
|          |          | [r3],A       | 0 1 1 1 1 0 R <sub>1</sub> R <sub>0</sub>              |                                       |            |             |
| Data     |          | A,[HL]       | 01011101                                               |                                       |            |             |
| 8-bit    |          | [HL],A       | 01010101                                               | · · · · · · · · · · · · · · · · · · · |            |             |
| 8-1      |          | A,word[r1]   | 0000 1010                                              | 00Rs10000                             | Low offset | High offset |
|          |          | word[r1],A   | 0 0 0 0 1 0 1 0                                        | 10R <sub>5</sub> 10000                | Low offset | High offset |
|          |          | PSW,#byte    | 0010 1011                                              | 1 1 1 1 1 1 1 0                       | Data       |             |
|          |          | PSW, A       | 00010010                                               | 1 1 1 1 1 1 1 0                       |            |             |
|          |          | A, PSW       | 0 0 0 1 0 0 0 0                                        | 1 1 1 1 1 1 1 0                       |            |             |
|          | ·        | А, г         | 1 1 0 1 1 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> |                                       |            |             |
|          | хсн      | Aisaddr      | 0010 0001                                              | - Saddr-offset -                      |            |             |
|          | ACH.     | A,sfr        | 0 0 0 0 0 0 0 1                                        | 00100001                              | Sfr-offset |             |
|          |          | A,[:4]       | 0 1 1 1 1 R <sub>2</sub> 1 1                           |                                       |            |             |
|          |          | rp,#word     | 0 1 1 0 0 P <sub>2</sub> P <sub>1</sub> 0              | - Low Byte -                          | High Byte  |             |
| fer      | [        | saddrp,#word | 00001100                                               | - Saddr-offset -                      | Low Byte   | High Byte   |
| Transfe  |          | sír.p,#word  | 0 0 0 0 1 0 1 1                                        | - Sir-offset -                        | Low Byte   | High Byte   |
|          | мо∨₩     | r p , r p    | 0010 0100                                              | 0 P.P.0 1 P.P.0                       |            |             |
| Data     |          | AX, saddrp   | 0 0 0 1 1 1 0 0                                        | - Saddr-offset -                      |            | •           |
|          |          | saddrp, AX   | 00011010                                               | - Saddr-offset                        |            |             |
| 16-bit   | [        | AX,sfrp      | 0 0 0 1 0 0 0 1                                        | - Sir-offset -                        |            |             |
|          | [        | sfrp,AX      | 0 0 0 1 0 0 1 1                                        | ← Sfr-offset →                        |            |             |

Table C-4. uCOM-78K/I Instruction Codes (2/7)

| dr               |          |             | Instruction Code |                             |                                       |           |
|------------------|----------|-------------|------------------|-----------------------------|---------------------------------------|-----------|
| Group            | Млетоліс | Operand     | В 1              | B 2                         | вэ                                    | B 4       |
|                  |          | A,#byte     | 1010 1000        | - Data                      |                                       |           |
|                  |          | maddr,#byte | 0110 1000        | - Saddr-offaet -            | Data                                  |           |
|                  |          | sfr,#byte   | 000000001        | 0110 1000                   | Sir-offset                            | Data      |
|                  |          | r , r       | 10001000         | 0 R.R.R.R. 0 R.R. R.        |                                       |           |
|                  | ADD      | A, s.addr   | 1001 1000        | - Saddr-offset -            |                                       | •         |
|                  |          | A,sír       | 0000 0001        | 1001 1000                   | Sir-offset                            |           |
|                  |          | A.[r4]      | 00010110         | 011R41000                   |                                       |           |
|                  |          | *'[Hr]      | 00010110         | 0 1 0 1 1 0 0 0             |                                       |           |
|                  |          | A,#byte     | 1010 1001        | + Data ++                   |                                       |           |
|                  |          | saddr,#byte | 01101001         | - Saddr-offset -            | Data                                  |           |
|                  |          | sír,#byte   | 0000 0001        | 0 1 1 0 1 0 0 1             | Sir-offset                            | Data      |
| ion              |          | r, r        | 10001001         | 0 R. R. R. R. 0 R. R. R.    |                                       | <u> </u>  |
| Operation        | ADDC     | A, saddr    | 10011001         | - Saddr-offset -            |                                       |           |
| ō                |          | A,sír       | 00000001         | 10011001                    | Sir-offset                            |           |
| etic             |          | A,[r4]      | 0 0 0 1 0 1 1 0  | 011R41001                   | · ·                                   |           |
| thme             |          | A,[HL]      | 0 0 0 1 0 1 1 0  | 0101-1001                   |                                       |           |
| Ari              |          | A,#byte     | 1010 1010        | - Data -                    | ~                                     |           |
| 8-bit Arithmetic |          | saddr,#byte | 01101010         | - Saddr-offset -+           | Data                                  |           |
| 8-]              |          | sfr,#byte   | 0 0 0 0 0 0 0 1  | 01101010                    | Sir-ofiset                            | Data      |
|                  |          | r.,r        | 10001010         | 0 R. R. R. Q R. R. R. R.    |                                       |           |
|                  | SUB      | A, saddr    | 10011010         | - saddr-offset -            |                                       |           |
|                  |          | A,sfr       | 00000001         | 10011010                    | Sfr-ofiset                            |           |
|                  |          | A,[r4]      | 0 0 0 1 0 1 1 0  | 0 1 1 R4 1 0 1 0            |                                       |           |
|                  |          | A,[HL]      | 0 0 0 1 0 1 1 0  | 01011010                    |                                       |           |
|                  |          | A,#byte     | 10101011         | Data                        |                                       |           |
|                  |          | saddr,#byte | 01101011         | - saddr-offset -            | Data                                  |           |
|                  |          | sir,#byte   | 000000001        | 01101011                    | Sfr-offset                            | Data      |
|                  |          | r, r        | 10001011         | 0 R. R. R. R. 0 R. R. R. R. | · · · · · · · · · · · · · · · · · · · |           |
|                  | SUBC     | A, saddr    | 10011011         | - saddr-offset              |                                       |           |
|                  |          | A,sír       | 0000 0001        | 10011011                    | Sir-ciiset                            |           |
|                  |          | A,[r4]      | 00010110         | 011R41011                   |                                       | · · · · · |
|                  |          | A;[HL]      | 00010110         | 01011011                    |                                       |           |

Table C-4. uCOM-78K/I Instruction Codes (3/7)

| dı         |          |             |                 | Instructión C               | ode        |                                              |
|------------|----------|-------------|-----------------|-----------------------------|------------|----------------------------------------------|
| Group      | Mnemonic | Operand     | B 1             | B 2                         | В 3        | B 4                                          |
|            |          | A.#byte     | 1010 1100       | - Data -                    |            |                                              |
|            |          | saddr,#byte | 0110 1100       | - Saddr-offset -            | Data       |                                              |
|            |          | sfr,#byte   | 0000 000 1      | 01101100                    | Sir-offact | Data                                         |
|            |          | r., r       | 10001100        | 0 R. R. R. R. 0 R. R. R. R. |            |                                              |
|            | AND      | A.saddr     | 10011100        | ↔.Saddr-offset →            |            |                                              |
|            |          | Aistr       | 000000001       | 10011100                    | Sfr-offset |                                              |
|            |          | A.[r4]      | 0001.0110       | 01-1R, 1100                 |            |                                              |
|            |          | A,[HL]      | 0 0 0 1 0 1 1 0 | 0 1 0 1 1 1 0 0             |            |                                              |
| 1          |          | A,#byte     | 1010 1110       | - Data -                    |            |                                              |
|            |          | saddr,#byte | 01101110        | - Saddr-offset -            | Data       |                                              |
|            |          | sfr,#byte   | 00000001        | 0110 1110                   | Sir-offset | Data                                         |
| ы          | OR       | r., r       | 10001110        | 0 R. R. R. R. 0 R. R. R. R. |            |                                              |
| Operation  |          | A, saddr    | 10011110        | ← Saddr-offset →            |            |                                              |
| oper       |          | A,#fr       | 0 0 0 0 0 0 0 1 | 1.0011110                   | Sir-offset |                                              |
|            |          | A,[r4]      | 0 0 0 1 0 1 1 0 | 0 1 1 R4 1 1 1 0            |            |                                              |
| Arithmetic |          | A.[HL]      | 0 0 0 1 0 1 1 0 | 01011110                    |            |                                              |
| riti.      |          | A,#byle     | 1010 1101       | - Data -                    |            |                                              |
|            |          | saddr,#byte | 01101101        | ← Saddr-offset →            | Data       |                                              |
| 8-bit      |          | •fr,#byt+   | 0 0 0 0 0 0 0 1 | 01101101                    | Sfr-offset | Data                                         |
|            | XOR      | r., r.      | 1000 1101       | 0 RoR3 R4 0 R2 R1 R0        |            |                                              |
|            | NOR      | A, saddr    | 10011101        | ↔ Saddr-offset →            |            |                                              |
|            |          | A, sfr      | 0000 000 1      | 10011101                    | Sfr-offset |                                              |
|            |          | A,[r4]      | 00010110        | 011R,1101                   |            |                                              |
|            |          | A,[HL]      | 00010110        | 0101 110 1                  |            |                                              |
|            |          | A,#byte     | 10101111        | ← Data →                    |            |                                              |
|            |          | saddr,#byte | 01101111        | - Saddr-offsel -            | Data       | <u>.                                    </u> |
|            |          | sfr,#byte   | 000000001       | 01101111                    | Sir-offset | Data                                         |
|            | СМР      | r , r       | 1000 1111       | 0 RoRsR4 0. R2R1R0          |            | ·                                            |
|            | CINT.    | A, saddr    | 10011111        | ← Saddr-offset →            |            |                                              |
|            |          | A,sfr       | 000000001       | 10011111                    | Sfr-offset |                                              |
|            |          | A.[:4]      | 00010110        | 011R41111                   |            |                                              |
|            |          | A,[HL]      | 00010110        | 0101 1111                   |            |                                              |

Table C-4. uCOM-78K/I Instruction Codes (4/7)

| <u>a</u>            | T             |             | Instruction Code                                       |                                                                                               |            | ······ |
|---------------------|---------------|-------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------|------------|--------|
| Group               | Mnemonic      | Operand     | B 1                                                    | B 2                                                                                           | B 3        | B 4    |
|                     |               | AX,#word    | 0010 1101                                              | ← Low Byte →                                                                                  | High Byte  | · .    |
| E                   |               | AX,rp       | 10001000                                               | 00001PrPr0                                                                                    |            | -      |
| tio                 | ADDW          | AX, saddrp  | 0001 1101                                              | ← Saddr-offset →                                                                              |            |        |
| Operation           |               | AX, sfrp    | 00000001                                               | 0 0 0 1 1 1 0 1                                                                               | Sfr-offset |        |
|                     |               | AX,#word    | 00101110                                               | - Low Byte                                                                                    | High Byte  | ,      |
| Arithmetic          | รบยพ          | AX, r p .   | 1.0001010                                              | 0 0 0 0 1 P, P, 0                                                                             |            |        |
| thm                 | 30 <i>5</i> W |             | - Saddr-offact -                                       |                                                                                               |            |        |
|                     |               | AX,sirp     | 0000 0001                                              | 0 0 0 1 1 1 1 0                                                                               | Sfr-offset |        |
| 6-bit               |               | AX,#word    | 00101111                                               | ← Low Byte →                                                                                  | High Byte  | -      |
| 16-                 | CMPW          | AX , r p    | 10001111                                               | 0000 1 P <sub>2</sub> P <sub>1</sub> 0                                                        |            | -      |
|                     | CBIPW         | AX, saddrp  | 00011111                                               | ← Saddr-offset →                                                                              |            |        |
|                     |               | AX,sirp     | 0 0 0 0 0 0 0 1                                        | 00011111                                                                                      | Sfr-offset |        |
| ρ1y/                | MULUW         | r           | 0 0 0 0 0 1 0 1                                        | 0000.0R <sub>7</sub> R <sub>1</sub> R <sub>0</sub>                                            |            |        |
| Multiply/<br>Divide | DIVUW         | T           | 00000101                                               | 0001 1 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub>                                           |            | -      |
| Increment/Decrement | INC           | r .         | 1 1 0 0 0 R <sub>z</sub> R <sub>i</sub> R <sub>o</sub> |                                                                                               |            |        |
| цета                | INC           | a add r     | 00100110                                               | + Saddr-offset +                                                                              |            |        |
| /Dec                | DEC           | r           | 1 1 0 0 1 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> |                                                                                               |            |        |
| lent                |               | saddr       | 00100111                                               | + Saddr-offset -+                                                                             |            |        |
| cren                | I NCW         | rp          | 010001P <sub>i</sub> P <sub>0</sub>                    |                                                                                               |            |        |
| ŭ                   | DECW          | rp          | 010011P <sub>1</sub> P <sub>0</sub>                    |                                                                                               |            |        |
|                     | ROR           | т, <b>л</b> | 00110000                                               | $0 1 N_2 N_1 N_0 R_2 R_1 R_0$                                                                 |            |        |
|                     | ROL           | r , n       | 0 0 0 1                                                | 0 1 N2N1 No R2 R1 R0                                                                          |            |        |
|                     | RORC          | r , n       | 0000                                                   | 0 0 N2N1 NoR2R1 Ro                                                                            |            |        |
| te                  | ROLC          | r,h         | 0 0 0 1                                                | $0  0  N_2 N_1  N_0 R_2 R_1 R_0$                                                              |            |        |
| Rota                | SHR           | r , n       | 0 0 0 0                                                | 1 0 N2N1 No R2 R1 R0                                                                          |            | ·      |
| Shift/Rotate        | SHL           | .r.n        | 0001                                                   | 1 0 N <sub>2</sub> N <sub>1</sub> N <sub>0</sub> R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> |            |        |
| Shi                 | Shrw          | rp,n        | 0000                                                   | $1 1 N_2 N_1 N_0 P_2 P_1 0$                                                                   |            |        |
|                     | SHLW          | rp,n        | 0001                                                   | $1 1 N_2 N_1 N_0 P_2 P_1 0$                                                                   |            |        |
|                     | ROR4          | [r4]        | 00000101                                               | 1000'10R <sub>i</sub> 1                                                                       |            |        |
|                     | ROL4          | [r4]        | 00000101                                               | 1001 10 R <sub>1</sub> 1                                                                      |            |        |
| Adj                 | ADJBA         |             | 00001110                                               |                                                                                               |            |        |
| E<br>B              | ADJBS         |             | 00001111                                               |                                                                                               |            |        |

Table C-4. uCOM-78K/I Instruction Codes (5/7)

| ц<br>Ц       |          |                | Instruction Code |                                                                     |                                        |
|--------------|----------|----------------|------------------|---------------------------------------------------------------------|----------------------------------------|
| Group        | Mnemonic | c Operand      | B 1              | B 2 B 3                                                             | B 4                                    |
|              |          | CY.saddr.bit   | 0 0 0 0 1 0 0 0  | 00000 B2B1B0Saddr-offset                                            |                                        |
|              |          | CY,sfr.bit     | 1000             | 1 B2B1Bo Sir-offset                                                 |                                        |
|              |          | CY.A.bit       | 0011             | 1 B <sub>2</sub> B <sub>1</sub> Bo                                  |                                        |
|              |          | CY,X.bit       | 0011             | 0 B; B, B,                                                          |                                        |
|              |          | CY, PSW. bit   | 0010             | 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                      | ······································ |
|              | MOV1     | aaddr, bit, CY | 1000             | 0 0 0 1 0 BrB, BoSaddr-offset                                       |                                        |
|              |          | afr,bit,CY     | 1000             | 1 B2B1Bo Sir-offset                                                 |                                        |
|              |          | A.bit,CY       | 0011             | 1 B <sub>2</sub> B <sub>1</sub> Bo                                  |                                        |
|              |          | X.bit,CY       | 0 0 1 1          | 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                      |                                        |
|              |          | PSW.bit,CY     | 0 0 1 0          | 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                      |                                        |
|              |          | CY, saddr. bit | 0000 1000        | 00100B2B1BoSaddr-offset                                             |                                        |
|              |          | CY,/saddr.bit  |                  | 0 0 1 1 0 B2B1B0Saddr-offset                                        |                                        |
|              |          | CY,sfr.bit     |                  | 00101B2B1Bo Sir-offset                                              |                                        |
|              |          | CY./sfr.bit    | ·                | 0 0 1 1 1 BzB1B0 Sir-ofiset                                         |                                        |
|              | ANDI     | CY,A.bit       | 0011             | 0 0 1 0 1 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>              |                                        |
|              |          | CY,/A.bit      |                  | 0 0 1 1 1 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>              |                                        |
| ion          |          | CY,X.bit       |                  | 0 0 1 0 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>              |                                        |
| Manipulation |          | CY. X. bit     |                  | 0 0 1 1 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>              |                                        |
| nipu         |          | CY, PSW. bit   | 0010             | 00100B2B,B0                                                         |                                        |
|              |          | CY,/PSW.bit    | 0010             | 0 0 1 1 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>              |                                        |
| Bit          |          | CY, saddr.bit  | 0 0 0 0 1 0 0 0  | 0 1 0 0 0 B2B1Bo Saddr-offset                                       |                                        |
|              |          | CY,/saddr.bit  |                  | 0 1 0 1 0 B2B1B0Saddr-offset                                        |                                        |
|              |          | CY, sfr. bit   |                  | 0 1 0 0 1 B; B; Bo Sfr-offset                                       |                                        |
|              |          | CY,/sfr.bit    |                  | 0 1 0 1 1 B2B1B0 Sir-offset                                         |                                        |
|              |          | CY,A.bit       | 0011             | 0 1 0 0 1 B <sub>2</sub> B <sub>3</sub> B <sub>6</sub>              |                                        |
|              | OR1      | CY./A.bit      |                  | 0 1 0 1 1 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>              |                                        |
|              |          | CY,X.bit       |                  | 0100 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                 |                                        |
|              |          | CY,/X.bit      |                  | 0 1 0 1 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>              |                                        |
|              |          | CY, PSW. bit   | 0010             | 0 1 0 0 0 Br B1 Bo                                                  |                                        |
|              |          | CY,/PSW.bit    | 0010             | 0 1 0 1 0 Br Br Bo                                                  |                                        |
|              |          | CY, saddr.bit  | 0000 1000        | 0 1 1 0 0 B <sub>2</sub> B <sub>2</sub> B <sub>0</sub> Saddr-offset |                                        |
|              | · ·      | CY, sfr. bit   | 1000             | .1 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub> Sir-ofiset          |                                        |
|              | XOR1     | CY,A.bit       | 0011             | 1 B, B, Bo                                                          |                                        |
|              |          | CY,X.bit       | 0011             | 0 B2 B1 B0                                                          |                                        |
|              |          | CY,PSW.bit     | 0010             | 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                      |                                        |

## Table C-4. uCOM-78K/I Instruction Codes (6/7)

| d'                 |          |           | Instruction Code                                                      | <u></u> |
|--------------------|----------|-----------|-----------------------------------------------------------------------|---------|
| Group              | Mnemonic | c Operand | B1 B2 B3                                                              | B 4     |
| <u> </u>           | SET1     | saddr.bit | 1 0 1 1 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub> - Saddr-offset |         |
|                    |          | sfr.bit   | 00001000 1000 1000 1 B2B1B0 Sfr-offset                                |         |
|                    |          | A.bit     | 0 0 1 1 1.B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                |         |
|                    | 1        | X.bit     | 0 0 1 1 0 B,B,Bo                                                      | •       |
|                    |          | PSW. bit  | 0 0 1 0 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                |         |
|                    |          | saddr.bit | 1 0 1 0 0 B2B1B0 - Saddr-offset                                       |         |
|                    |          | sfr.bit   | 0 0 0 0 1 0 0 0 1 0 0 1 1 B2B1Be Sir-offset                           |         |
| ion                | CLRI     | A.bil     | 0 0 1 1 1 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                |         |
| ulat               |          | Х. Ьі L   | 0 0 1 1 .0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>               |         |
| Manipulation       |          | PSW.bit   | 0010 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                   |         |
|                    |          | saddr.bit | 0 0 0 0 1 0 0 0 0 1 1 1 0 B2B1B0 Saddr-offset                         |         |
| Bit                | NOTI     | sír, bit  | 1000 I B <sub>2</sub> B <sub>1</sub> B <sub>0</sub> Sir-ofiset        |         |
|                    |          | A.bit     | 0 0 1 1 / 1 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>              |         |
|                    |          | X.bit     | 0 0 1 1 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                |         |
|                    |          | PSW.bit   | 0 0 1 0 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>                |         |
| :                  | SET1     | CY .      | 01000001                                                              |         |
|                    | CLR1     | CY        | 0 1 0 0 0 0 0 0                                                       |         |
|                    | NOT 1    | CY        | 0 1 0 0 0 0 1 0                                                       |         |
|                    | CALL     | !sddr13   | 0 0 1 0 1 0 0 0 - Low Addr High Addr.                                 |         |
| urn                | CALLF    | !addr11   | $1 0 0 1 0 \leftarrow fa \rightarrow$                                 |         |
| Call/Return        | CALLT    | [addr5]   | $111 \leftrightarrow ta \rightarrow$                                  |         |
| all/               | RET      |           | 0 1 0 1 0 1 1 0                                                       |         |
| Ű                  | RETI     |           | 0 1 0 1 0 1 1 1                                                       |         |
| · _                | DIIGH    | гр        | 0 0 1 1 1 1 P <sub>1</sub> P <sub>0</sub>                             |         |
| tior               | PUSH     | PSW       | 0 1 0 0 1 0 0 1                                                       |         |
| ulai               | DOD      | гр        | 0 0 1 1 0 1 P <sub>1</sub> P <sub>0</sub>                             |         |
| u i p              | POP      | PSW       | 0 1 0 0 1 0 0 0                                                       |         |
| Stack Manipulation |          | SP,#byte  | 00101011 1111100 Data                                                 |         |
| tac                | моч      | SP.A      | 0 0 0 1 0 0 1 0 1 1 1 1 1 0 0                                         |         |
| ഗ                  |          | A, SP     | 0 0 0 1 0 0 0 0 1 1 1 1 1 1 0 0                                       |         |

# Table C-4. uCOM-78K/I Instruction Codes (7/7)

| đ                        |          |                    |              |                                                        | on Code      |       |  |
|--------------------------|----------|--------------------|--------------|--------------------------------------------------------|--------------|-------|--|
| Group                    | Mnemoņic | Operand            | B 1          | B 2                                                    | В 3          | B 4   |  |
|                          |          | laddr13            | 00101100     | ← Law Addr. →                                          | High Addr.   |       |  |
| ibudi                    | BR       | rp                 | 00000101     | 0 1 0 0 1 Pr Pi 0                                      |              |       |  |
| Uncondi-<br>tional<br>BR |          | \$addr13           | 00010100     | - jdisp                                                |              |       |  |
|                          | вс       | Saddr13            | 1000 0011    | jdisp                                                  |              |       |  |
|                          | BL       | \$\$00713          |              | ,,                                                     |              |       |  |
|                          | BNC      | - \$addr13         | 0010         | jdisp                                                  |              |       |  |
|                          | BNL      |                    |              |                                                        |              | -     |  |
|                          | BZ       | \$addr13           | 0 0 0 1      | ← jdisp                                                |              |       |  |
|                          | BE       |                    |              |                                                        |              |       |  |
|                          | BNZ      | Saddr13            | 0000         |                                                        |              |       |  |
|                          | BNE      |                    |              |                                                        |              |       |  |
|                          |          | saddr.bit,\$addr13 | 01110B;B;Bo  | ← Saddr-offset →                                       | jdisp        |       |  |
|                          | BT       | sfr.bit,\$addr13   | 0000 1000    | 10111B2B1B0                                            | Sfr-offset   | jdisp |  |
| Branch                   |          | A.bit,\$addr13     | 0011         | 1 B <sub>2</sub> B <sub>1</sub> Bo                     | jdisp        |       |  |
|                          |          | X.bit,Saddr13      | 0011         | 0 B; B; Bo                                             | jdisp        |       |  |
| nal                      |          | PSW.bit,\$*ddr13   | 0010         | 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>         | jdisp        |       |  |
| Conditional              |          | saddr.bit,\$addr13 | 0000 1000    | 10100B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>      | Saddr-offset | jdisp |  |
| ibnc                     |          | afr.bit,\$addr13   | 1000         | 1 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>         | Sir-ofiset   | jdisp |  |
| ŭ                        | BF .     | A.bit,\$addr13     | 0011         | 1 B <sub>7</sub> B <sub>1</sub> B <sub>0</sub>         | jdisp        |       |  |
|                          |          | X.bit,Saddr13      | 0011         | 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>         | jdisp        |       |  |
|                          |          | PSW, bit,\$addr13  | 0010         | 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>         |              |       |  |
|                          |          | saddr.bit,Saddr13  | 0000 1000    | 1 1 0 1 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub> |              | jdisp |  |
|                          |          | sfr.bit,\$sddr13   | 1000         | 1 B2 B1 B0                                             |              | jdisp |  |
|                          | BTCLR    | A.bit,Saddr13      | 0011         | 1 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>         | jdisp        |       |  |
|                          |          | X.bit,Saddr13      | 0011         | 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>         |              |       |  |
|                          |          | PSW.bit,\$addr13   | 0010         | 0 B <sub>2</sub> B <sub>1</sub> B <sub>0</sub>         | jdisp        | ,     |  |
|                          | DBNZ     | r2,\$addr13        | 0,011 001 Ro | jdisp                                                  |              |       |  |
| ÷.                       |          | saddr.Saddr13      | 0011 1011    | ← Saddr-offset →                                       | jdisp        |       |  |
|                          | MOV      | STBC,#byte         | 00001001     | · · · · · · · · · · · · · · · · · · ·                  | Data         | Data  |  |
| Control                  | SEL .    | RBn                | 00000101     | 101010N1N0                                             |              |       |  |
|                          | NOP      | ·                  | 0000 0000    |                                                        |              |       |  |
| сРО                      | EI       |                    | 01001011     | · · · · · · · · · · · · · · · · · · ·                  |              |       |  |
| 5                        | DI       |                    | 0100 1010    |                                                        |              |       |  |

.

APPENDIX D. MAXIMUM PERFORMANCE CHARACTERISTICS

(1) Maximum performance characteristics of Assembler

| Item                             | Limit          |
|----------------------------------|----------------|
| Effective symbol length          | 6 characters   |
| Number of characters per line    | 99 characters  |
| Number of code segments per type | 1 segment      |
| Number of absolute segments      | 10 segments    |
| Number of macrodefinitions       | 10 definitions |

(2) Maximum performance characteristics of Linker

| Item                              | Limit        |
|-----------------------------------|--------------|
| Number of input modules files     | 100 files    |
| Number of different segment names | 255 segments |
| Number of absolute segments       | 100 segments |

(3) Maximum performance characteristics of Locater

| Item                           | Limit        |
|--------------------------------|--------------|
| Number of relocatable segments | 256 segments |
| per input module               |              |

(4) Restrictions on number of symbols

|           | No. of local symbols  | No. of PUBLIC symbols |
|-----------|-----------------------|-----------------------|
| Assembler | Approx. 1,800 symbols | 256 symbols           |
| Linker    | 1,800 symbols         | Approx. 2,000 symbols |
|           | x No. of modules      |                       |
| Locater   | 1,800 symbols         | Approx. 2,000 symbols |
|           | x No. of modules      |                       |

INDEX

absolute assembler 1-6 absolute segment 2-3 absolute term 2-43 actual parameter 3-70, 5-4 ADDRESS (symbol attribute) 2 - 15ADDRESS term 2-46 alphabetic characters 2-10 area reservation directives 3-1, 3-36 arithmetic operators 2-26 assembler 1-1 assembler option(s) 2-2, 6-1 1-1 assembly language assembly list control instructions 4-5 assemly list file 1-11 assembly termination directive 3-1, 3-79 automatic branch instruction selection directive 3-1, 3-56 backward reference 2-51, 3-59 binary constant 2-18 binary number 2-18 BIT (symbol attribute) 2 - 15bit address 3-32 bit address map 3-33 bit segment 2-3 BIT term 2-46 BR directive 3-57 BSEG directive 3-16 Byte separating operators 2-40 CALLTO (relocation attribute) 3-6 character constants 2 - 18character set 2-10 code segment 2-3 Comment field 2-22 conditional assembly control instructions 4-16 conditional assembly function 1-16 conditions for size of operand value 2-50 conditions for address range of operand value 2-51 constants 2-17 control instructions 2-2, 4-1 conventions of symbol description 2-14 CSEG directive 3-5 data segment 2-3 DB directive 3-37 DBIT directive 3-44 decimal constant 2-18 decimal number 2-18 3-7, 3-12, 3-17, 3-21 default segment name directives 3-1 DS directive 3-42 DSEG directive 3-11 DW directive 3-39

Phase-out/Discontinued

EJECT control instruction 4 - 6ELSE control instruction 4-17 ELSEIF control instruction 4-17 END directive 3-80 ENDIF control instruction 4-17 ENDM directive 3-77 ENDS directive 3-24 EQU directive 2-2, 3-27 EXITM directive 3-73 expressions 2-21, 2-24 EXTBIT directive 2-2, 3-50 external definition declaration 3-46 external reference declaration 3 - 46external reference term 2-44 EXTRN directive 3-48 FIXED (relocation attributes) 3 - 6formal parameter 3-62, 5-4 forward reference 2-51, 3-59 general-purpose register pairs 2-19 general-purpose registers 2-19 global symbols 5-7 hexadecimal constant 2-18 hexadecimal number 2-18 HEX-format object module file 1-13 HIGH operator 2-40 IF control instruction 4-17 INCLUDE control instruction 4-2 instruction codes A-27 instruction set (uCOM-78K/I) A-7 IRP directive 3-70 IRP-ENDM block 3-70 label(s) 2-13, 2-21 line 2-9 linkage directives 3-1, 3-46 linker 1-12 link list file 1-12 link module file 1-12 LIST control instruction 4-10 list of directives A-4 list of reserved words A-1 LOCAL directive 3-64 local symbols 1-14, 5-3 locater 1-13 locate list file 1-13 logical operators 2-30 lowerercase letter 2-10 LOW operator 2-40 machine language 1-1 macro 5-1 macro body 5-3 macro directives 3-1, 3-61 macro function 1-16

```
Phase-out/Discontinued
```

```
macro name 2-13, 5-4
macro reference 5-4
macrodefinition 5-3
MACRO directive 3-62
macroexpansion 5-5
main routine 2-7
maximum performance characteristics
 (assembler package) 1-15, A-34
memory allocation to segments 3-4
memory initialization directives 3-1, 3-36
Mnemonic field 2-15
mnemonic instruction 2-15
modular programming 1-6
module 1-6
module body 2-3
module header 2-2
module name 2-13
module tail 2-3
name(s) 2-13, 2-21
NAME directive 2-2, 3-54
NOLIST control instruction 4-8
NUMBER (symbol attribute) 2-15
NUMBER term 2-46
numeric characters 2-10
numeric constants 2-17
numeric constant types 2-18
object module file 1-10
octal constant 2-18
octal number 2-18
operand attributes of instructions 2-53
operand attributes of directives 2-55
operands 2-21
Operand field
             2-16
Operand representation formats 3-28, A-8
operators 2-24
optimization 3-57
optimization conditions of BR directive 3-59
optimize function 1-16
order of precedence of operators 2-24
ORG directive 3-20
other operands 2-41
PUBLIC directive 2-2, 3-52
PUBLIC symbols 1-14
register names 2-19
relatioal operators 2-32
relocatable assembler 1-6
relocatable term 2-43
relocation attributes 2-43
relocation of absolute segment
                               3-20
relocation of bit segment 3-16
REPT directive 3-67
REPT-ENDM block 3-67
RESET control instruction 4-24
restriction on number of symbols 1-14, A-36
```

Phase-out/Discontinued

same named segment 3-7, 3-13 segment 2-3 segment definition directives 3-1, 3-3 segment name 2-3 SET control instruction 4-24 SET directive 3-34 shift operators 2-38 short direct addressing area 3-12, 3-17, 6-2 size of source module file 1-14 source module 1-10, 2-1 source module file 1-10 source program 2-1 special characters 2-11, 2-20 special function registers 2-19, A-12 stack segment 3-3 statement 2-9 subroutine 2-8, 5-1 SUBTITLE control instruction 4-12 SUBTITLE section 4-12 switch name 4-17, 4-24 symbol attributes 2-15 symbol definition directives 3-1, 3-26 Symbol field 2-12 symbol table file 1-13 symbol types 2-13 Types of operators 2-24 Types of relocation attributes 2-43 Types of symbol attributes 2-46



EEU-1204 August 1988 P Printed in Japan

S. Ander