PERKIN-ELMER

# COMMON ASSEMBLY LANGUAGE/32 (CAL/32)

**Reference Manual** 

48-050 F00 R00

The information in this document is subject to change without notice and should not be construed as a commitment by The Perkin-Elmer Corporation. The Perkin-Elmer Corporation assumes no responsibility for any errors that may appear in this document.

The software described in this document is furnished under a license, and it can be used or copied only in a manner permitted by that license. Any copy of the described software must include the Perkin-Elmer copyright notice. Title to and ownership of the described software and any copies thereof shall remain in The Perkin-Elmer Corporation.

The Perkin-Elmer Corporation assumes no responsibility for the use or reliability of its software on equipment that is not supplied by Perkin-Elmer.

The Perkin-Elmer Corporation, Computer Systems Division 2 Crescent Place, Oceanport, New Jersey 07757

C 1981 by The Perkin-Elmer Corporation

Printed in the United States of America

## SPECIAL NOTICE TO CAL/32 USERS

The CAL/32 assembler is not compatible with the CAL assembler in the handling of unreferenced externals. In order to support weak externals, object code will be generated for unreferenced externals. Programs assembled by CAL/32 and containing unreferenced externals to nonexistent modules will receive an error message at Link time. For compatibility with CAL, the NUREX start option/assembler instruction has been introduced in CAL/32.

alas da antialas da antialas da anti•

# TABLE OF CONTENTS

vii

1

1

# CHAPTERS

| 1 | BASIC CONCEPTS |                                          |                         |  |  |  |
|---|----------------|------------------------------------------|-------------------------|--|--|--|
|   | 1.1            | INTRODUCTION                             | 1 - 1                   |  |  |  |
|   | 1.2            | THE PROCESSOR                            | 1-1                     |  |  |  |
|   | 1.2.1          | Central Processing Unit (CPU)            | 1-1                     |  |  |  |
|   | 1.2.1.1        | Local Memory (Registers)                 | 1-2                     |  |  |  |
|   | 1.2.2          | Program Status Word (PSW)                | <b>1</b> <del>-</del> 2 |  |  |  |
|   | 1.2.3          | I/O Interface                            | 1-3                     |  |  |  |
|   | 1.2.3.1        | Main Memory                              | 1-3                     |  |  |  |
|   | 1.2.4          | Software Relocation                      | 1-4                     |  |  |  |
|   | 1.2.5          | Hardware Relocation                      | 1-4                     |  |  |  |
|   | 1.3            | INSTRUCTION FORMATS (16-BIT)             | <b>1-</b> 5             |  |  |  |
|   | 1.3.1          | Register-to-Register (RR) Instructions   | 1-5                     |  |  |  |
|   | 1.3.2          | Register and Indexed Storage (RX)        |                         |  |  |  |
|   |                | Instructions                             | 1-6                     |  |  |  |
|   | 1.3.3          | Register and Immediate (RI) Instructions | 1-6                     |  |  |  |
|   | 1.3.4          | Short Form (SF) Instructions             | 1-7                     |  |  |  |
|   | 1.4            | INSTRUCTION FORMATS (32-BIT)             | 1-7                     |  |  |  |
|   | 1.4.1          | Register-to-Register (RR) Instructions   | 1-8                     |  |  |  |
|   | 1.4.2          | Register and Indexed Storage One (RX1)   |                         |  |  |  |
|   |                | Instructions                             | 1-8                     |  |  |  |
|   | 1.4.3          | Register and Indexed Storage Two (RX2)   |                         |  |  |  |
|   |                | Instructions                             | 1-9                     |  |  |  |
|   | 1.4.4          | Register and Indexed Storage Three (RX3) |                         |  |  |  |
|   |                | Instructions                             | 1-10                    |  |  |  |
|   | 1.4.5          | Register and Immediate One (RI1)         |                         |  |  |  |
|   |                | Instructions                             | 1-10                    |  |  |  |
|   | 1.4.6          | Register and Immediate Two (RI2)         |                         |  |  |  |
|   |                | Instructions                             | 1-11                    |  |  |  |
|   | 1.4.7          | Short Form (SF) Instructions             | 1-12                    |  |  |  |
|   | 1.4.8          | Register and Indexed Storage/Register    |                         |  |  |  |
|   |                | and Indexed Storage (RXRX) Instructions  | 1-12                    |  |  |  |
|   | 1.5            | VARIATIONS ON INSTRUCTION FORMATS        | 1-15                    |  |  |  |
|   | 1.5.1          | Conditional Branch Instructions          | 1-15                    |  |  |  |
|   | 1.5.2          | Branch and Link Instructions             | 1-15                    |  |  |  |
|   | 1.5.3          | Other Variations                         | 1-15                    |  |  |  |

# CHAPTERS (Continued)

| 2 | SYMBOLIC | REPRESENTATION                                                               |              |
|---|----------|------------------------------------------------------------------------------|--------------|
|   | 2.1      | INTRODUCTION                                                                 | 2-1          |
|   | 2.2      | SYMBOLS AND EXPRESSIONS                                                      | 2-1          |
|   | 2.3      | SYMBOLS AND THEIR VALUES                                                     | 2-3          |
|   | 2.3.1    | Implicit Symbols                                                             | 2-3          |
|   | 2.3.2    | Global Symbols                                                               | 2-5          |
| 3 | THE SOUR | CE PROGRAM                                                                   |              |
|   | 3.1      | INTRODUCTION                                                                 | 3-1          |
|   | 3.2      | COMMENT STATEMENTS                                                           | 3-1          |
|   | 3.3      | INSTRUCTION STATEMENTS                                                       | 3-2          |
|   | 3.4`     | NAME FIELD                                                                   | 3-3          |
|   | 3.5      | OPERATION FIELD                                                              | 3-4          |
|   | 3.6      | OPERAND FIELD                                                                | 3-5          |
|   | 3.6.1    | Register-to-Register Instructions                                            | 3-5          |
|   | 3.6.2    | Register and Indexed Storage Instructions                                    | 3-6          |
|   | 3.6.3    | Register and Immediate Instructions                                          | 3-7          |
|   | 3.6.4    | Register and Indexed Storage/Register                                        |              |
|   |          | and Indexed Storage (RXRX) Instructions                                      | 3-8          |
|   | 3.7      | MACHINE INSTRUCTIONS                                                         | 3-10         |
|   | 3.8      | ASSEMBLER INSTRUCTIONS                                                       | 3-21         |
|   | 381      | Symbol Definition Instructions                                               | 3-21         |
|   | 3.8.1.1  | Equate (EQU) Instruction                                                     | 3-22         |
|   | 3.8.1.2  | External, Entry, weak External, weak<br>Entry, and Data Entry (EXTRN, ENTRY, |              |
|   |          | WXTRN, WNTRY, and DNTRY) Instructions                                        | 3-25         |
|   | 3.8.1.3  | Include (INCLD) Instruction                                                  | 3-27         |
|   | 3.8.2    | Data Definition Instructions                                                 | 3-28         |
|   | 3.8.2.1  | Define Storage (DS, DSH, DSF) Instruction                                    | 3-28         |
|   | 3.8.2.2  | Define Constant (DC, DCF) Instruction                                        | 3-30         |
|   | 3.8.2.3  | Hexadecimal Constants                                                        | 3-31         |
|   | 3.8.2.4  | Integer Constants                                                            | 3-33         |
|   | 3.8.2.5  | Address Constants                                                            | 3-35         |
|   | 3.8.2.6  | Floating Point Constants                                                     | 3-37         |
|   | 3.8.2.7  | Character Constants                                                          | 3-38         |
|   | 3.8.2.8  | Decimal String Constants                                                     | 3-38         |
|   | 3.8.3    | Define Byte (DB) Instruction                                                 | 3-4 <b>1</b> |
|   | 3.8.4    | Define List (DLIST) Instruction                                              | 3-42         |
|   | 3.8.5    | Define Command (DCMD) Instruction                                            | 3-43         |

ł

1

1

| 3.8.6                                                       | Location Counter Instructions                                | 3-43  |
|-------------------------------------------------------------|--------------------------------------------------------------|-------|
| 3.8.6.1                                                     | Pure (PURE) Instruction                                      | 3-43  |
| 3.8.6.2                                                     | Impure (IMPUR) Instruction                                   | 3-44  |
| 3.8.6.3                                                     | Origin (ORG) Instruction                                     | 3-44  |
| 3.8.6.4                                                     | Absolute (ABS) Instruction                                   | 3-45  |
| 3.8.6.5                                                     | Align (ALTGN) Instruction                                    | 3-45  |
| 3.8.6.6                                                     | Conditional No Operation (CNOP)                              | 5 45  |
| 5.0.0.0                                                     | Instruction                                                  | 3-45  |
| 3.8.7                                                       | Assembler Control Instructions                               | 3-46  |
| 3.8.7.1                                                     | Target (TARGT) Instruction                                   | 3-40  |
| 3.8.7.2                                                     | Fnd (FND) Instruction                                        | 3-47  |
| 3.8.7.3                                                     | Conv Library (CLIB) Instruction                              | 3-48  |
| 3.8.7.4                                                     | Copy (COPY) Instruction                                      | 3-48  |
| 3.8.7.5                                                     | File Copy (FCOPY) Instruction                                | 3-49  |
| 3.8.7.6                                                     | Dause (DAUSE) Instruction                                    | 3-49  |
| 3.8.7.7                                                     | Saugeze (SOUF7) Instruction                                  | 3-50  |
| 3.8.7.8                                                     | Squeeze (Sydda) instruction $Squeeze$ (Sydda) instruction    | 5 50  |
| 2.0.1.0                                                     | Instructions                                                 | 3-53  |
| 2070                                                        | Instructions<br>Sequence Checking (SOCUK NOSED) Instructions | 3-54  |
| $3 \cdot 0 \cdot 7 \cdot 3$<br>$3 \cdot 0 \cdot 7 \cdot 10$ | Service Checking (Sychk, NOSE) Instructions                  | 3-54  |
| $3 \cdot 0 \cdot 7 \cdot 10$                                | Deca Dauga (DDNUS) Instruction                               | 3-54  |
| $3 \cdot 0 \cdot 7 \cdot 11$                                | Maggage (MCC) Instruction                                    | 3-54  |
| 3.0.7.12                                                    | Message (MSG) INSTRUCTION                                    | 3-35  |
| 3.8.7.13                                                    | Batch Assembly (BATCH, BEND) Instructions                    | 3-55  |
| 3.8.1.14                                                    | Unreierenced Externals (UREX, NUREX)                         | 2 5 6 |
|                                                             | Instructions                                                 | 3-50  |
| 3.8.8                                                       | Conditional Assembly Instructions                            | 3-55  |
| 3.8.8.1                                                     | Compound Conditional (IFx, ELSE, ENDC)                       |       |
|                                                             | Instructions                                                 | 3-56  |
| 3.8.8.2                                                     | Simple If (IF) Instruction                                   | 3-60  |
| 3.8.8.3                                                     | Do (DO) Instruction                                          | 3-50  |
| 3.8.9                                                       | Instructions for Data Structures                             | 3-61  |
| 3.8.9.1                                                     | Structure Definition (COMN, STRUC, ENDS)                     |       |
|                                                             | Instructions                                                 | 3-51  |
| 3.8.9.2                                                     | Structure Initialization (BDATA, BORG)                       |       |
|                                                             | Instructions                                                 | 3-64  |
| 3.8.10                                                      | Listing Control Instructions                                 | 3-65  |
| 3.8.10.1                                                    | Listing Identification (PROG, TITLE)                         |       |
|                                                             | Instructions                                                 | 3-65  |
| 3.8.10.2                                                    | Format Control (LCNT, EJECT, SPACE,                          |       |
|                                                             | WIDTH) Instructions                                          | 3-65  |
| 3.8.10.3                                                    | Content Control (NLIST) Instructions                         | 3-67  |
|                                                             |                                                              |       |
| 3.9                                                         | ASSEMBLY LISTING                                             | 3-68  |
|                                                             |                                                              |       |
|                                                             |                                                              |       |
| COMMON M                                                    | ODE PROGRAMMING                                              |       |
|                                                             |                                                              |       |
| 4.1                                                         | INTRODUCTION                                                 | 4-1   |
|                                                             |                                                              |       |
| 4.2                                                         | ADDRESS OPERATION INSTRUCTIONS                               | 4-1   |

4.3 COMMON MODE IMMEDIATE OPERATIONS 4-3

4

L

I

1

1

L

1

L

1

Ł

L

| 4.4     | COMMON MODE ASSEMBLER INSTRUCTIONS         | 4 <del>-</del> 3 |
|---------|--------------------------------------------|------------------|
| 4.4.1   | Data Definition Instructions               | 4-4              |
| 4.4.1.1 | Define Address Length Constant Instruction | 4-4              |
| 4.4.1.2 | Define Address Length Storage Instruction  | 4 - 4            |
| 4.4.2   | Assembler Control Instructions             | 4-5              |
| 4.5     | MIXED MODE COMPUTATIONS                    | 4-5              |
| 4.6     | GLOBAL SYMBOLS                             | 4-6              |
| 4.7     | SPECIAL INSTRUCTIONS                       | 4-8              |

## APPENDIXES

| 1 | A | COMMON ASSEMBLY LANGUAGE/32 (CAL/32) OPERATING<br>INSTRUCTIONS |
|---|---|----------------------------------------------------------------|
| I | В | COMMON ASSEMBLY LANGUAGE/32 (CAL/32) ERROR CODES               |
| 1 | С | PERKIN-ELMER OBJECT CODE FORMAT                                |

## FIGURES

| 1-1  | RR Format         | (16-Bit) | <b>1-</b> 5 |
|------|-------------------|----------|-------------|
| 1-2  | RX Format         | (16-Bit) | 1-6         |
| 1-3  | RI Format         | (16-Bit) | <b>1-</b> 5 |
| 1-4  | SF Format         | (16-Bit) | 1-7         |
| 1-5  | RR Format         | (32-Bit) | 1-8         |
| 1-6  | <b>RX1</b> Format | (32-Bit) | 1-8         |
| 1-7  | RX2 Format        | (32-Bit) | <b>1</b> -9 |
| 1-8  | RX3 Format        | (32-Bit) | 1-10        |
| 1-9  | RI1 Format        | (32-Bit) | 1-11        |
| 1-10 | RI2 Format        | (32-Bit) | 1-11        |
| 1-11 | SF Format         | (32-Bit) | 1-12        |
| 1-12 | RXRX Format       | (32-Bit) | 1-13        |

## TABLES

| 3-1 | SUMMARY OF MACHINE INSTRUCTIONS AND MNEMONICS | 3-10 |
|-----|-----------------------------------------------|------|
| 3-2 | SUMMARY OF MACHINE INSTRUCTIONS AND MNEMONICS |      |
|     | EXTENDED FOR THE PERKIN-ELMER 3200 SERIES     |      |
|     | PROCESSORS                                    | 3-18 |
| 3-3 | EXTENDED BRANCH MNEMONICS                     | 3-19 |
| 3-4 | CONSTANT TYPES                                | 3-31 |

# TABLES (Continued)

| 4-1 | COMMON | MODE ADDRESS OPERATIONS | 4-1 |
|-----|--------|-------------------------|-----|
| C-1 | 32-BIT | LOADER ITEM DEFINITIONS | C-2 |
| C-2 | 16-BIT | LOADER ITEM DEFINITIONS | C-4 |

INDEX

Ind-1

V

1997 - 1997 - 1997 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 -

.

#### PREFACE

This manual describes the Perkin-Elmer Common Assembly Language/32 (CAL/32). Chapter 1 is an introduction to the basic concepts of the assembler, central processing unit (CPU), and main memory. Also described are the instruction formats for 16and 32-bit machines, as well as variations in the formats. Chapter 2 introduces assembly language symbolic representation and describes symbolic values. Chapter 3 defines the source program and contains a list of machine instructions, mnemonics, and a detailed description of assembler instructions. Common mode programming and common mode operations are explained in Chapter 4.

CAL/32 operating instructions are listed in Appendix A. Appendix B contains CAL/32 error codes. Appendix C describes the Perkin-Elmer 32-bit object code format and the Perkin-Elmer 16-bit object code format.

ROO of this manual can be used only with CAL/32 RO9 and OS/32 RO6 and higher. The following features are incorporated:

- Support of forward references in the operand of EQU, ORG, DS, and DO
- Fase of use (via DEL and temp files)
- Support of lowercase and underscore

MANUAL NAME

- Faster symbol table paging
- Enhanced Copy
- Externals with offsets
- New start options

The CAL/32 user should be familiar with the following 16- and 32-bit manuals:

PUBLICATION NUMBER

| Model | 8/32 | Processor | User's | Manua 1 | <b>29-42</b> 8 |
|-------|------|-----------|--------|---------|----------------|
| Model | 7/32 | Processor | User's | Manua 1 | C29-405        |

vii

1

ł

| F | UBLICATION<br>NUMBER |
|---|----------------------|
|   |                      |

| 16-Eit Processor User's Manual                         | C29-509 |
|--------------------------------------------------------|---------|
| Series Sixteen Processor User Manual                   | C29-674 |
| Model 3240 Processor User's Manual                     | C29-685 |
| Model 3220 Processor User's Manual                     | C29-693 |
| OS/16 MT2 Programmer's Reference Manual                | S29-429 |
| OS/16 MT2 Operator's Manual                            | S29-430 |
| OS/32 Operator Reference Manual                        | 48-030  |
| OS/32 Supervisor Call (SVC) Reference Manual           | 48-038  |
| OS/32 Application Level Programmer Reference<br>Manual | 48-039  |
| 32-Bit System User Documentation Summary               | 50-003  |

MANUAL NAME

For further information on the contents of all Perkin-Elmer 32-bit manuals, see the 32-Bit Systems User Documentation Summary.

.

.

## CHAPTER 1 BASIC CONCEPTS

## **1.1** INTRODUCTION

Like all assemblers, Common Assembly Language/32 (CAL/32) simplifies the direct control of the processor by providing the programmer with a way of representing actual machine operations in an easily understood symbolic form. Assemblers translate symbolic representations of machine instructions into binary form to be executed by the processor. CAL/32 also includes such features as relocation, segmentation, complex data definitions, and expression analysis. CAL/32 can run on any Perkin-Elmer processor and produce machine code for any Perkin-Elmer processor.

Because assembly language programming is so close to actual machine operations, it is essential that the assembly language programmer have a good understanding of the system architecture. This chapter contains introductory architectural descriptions, and the programmer should read the appropriate processor reference manuals for more information.

## **1.2 THE PROCESSOR**

All Perkin-Elmer processors are stored-program, multi-register, two-address machines. The major components are the central processing unit (CPU) and main memory.

#### 1.2.1 Central Processing Unit (CPU)

To many, the CPU is something of a black box that performs arithmetic and logical operations in a precise and controlled way. To the assembly language programmer, the CPU is not completely opaque. Three of its components--local memory or registers, the program status word (PSW), and the I/O interface--are accessible through assembly language programming.

#### 1.2.1.1 Local Memory (Registers)

All Perkin-Elmer processors have some amount of local memory that can be used as temporary storage, accumulators, or indices. There are three types of local memory:

- General purpose registers
- Single precision floating point registers
- Double precision floating point registers

All processors have at least one set of 16 general purpose registers. In the 16-bit processors, each general purpose register holds 16 binary digits; in the 32-bit processors, 32 binary digits. General purpose registers can be used for integer arithmetic, address arithmetic, logical operations, and character operations.

Floating point registers are used only for floating point arithmetic operations. Processors with floating point registers have either eight single precision registers, or eight single precision registers and eight double precision registers. The single precision registers hold 32 binary digits. The double precision registers hold 64 binary digits.

#### 1.2.2 Program Status Word (PSW)

The PSW defines the current state of the processor. It consists of three major parts:

- Status descriptor
- Condition code
- Location counter

Individual bits and bit fields within the status descriptor portion of the PSW define the current state of interrupts and various hardware features of the processor. By setting or resetting bits within the status descriptor, the programmer can enable or disable such interrupts as I/O, arithmetic fault, and machine malfunction. On those processors with multiple sets of general purpose registers, a field in the status descriptor defines which set is currently in use. Programmers writing user level programs, as opposed to operating system or stand-alone programs, cannot directly access the status descriptor. In this case, the operating system maintains control of interrupts and registers.

*\** 

The condition code provides a means of controlling program flow, based on the results of instruction execution. As certain instructions are executed, the value in the condition code changes to indicate the nature of the result. For example, if an operation produces a zero result, the condition code may be changed to a zero value. With branch instructions, the programmer can test the value in the condition code and branch or not, depending on that value. Not all instruction executions affect the condition code. See the appropriate processor reference manual for more details.

The location counter controls the order of instruction execution. Normally, the processor executes instructions sequentially and uses the location counter to keep track of where the instructions are in main memory, then fetches the instruction from the memory location specified by the address contained in the location counter. It executes that instruction, increments the location counter by the length of the instruction, and fetches the next instruction. Branch instructions, when executed, change the contents of the location counter and thereby affect the branch.

In 32-bit machines, the PSW contains 64 binary digits, the last 24 of which are reserved for the location counter. In 16-bit machines, the PSW contains 32 bits; the last 16 are reserved for the location counter.

## 1.2.3 I/O Interface

The execution of certain machine instructions allows the programmer to control external devices and to cause the transfer of data between external devices and main memory or registers. The actual programming of I/O operations is very much hardware dependant, both in the processor and the peripherals. I/O instructions are restricted to operating systems and stand-alone programs. User programs can communicate with I/O devices through facilities provided by the operating system.

#### 1.2.3.1 Main Memory

To the assembly language programmer, main memory appears as a block of contiguous storage locations. The smallest unit of memory the programmer can reference is the byte (eight bits). The programmer can also reference halfwords (two bytes), fullwords (four bytes), and double words (eight bytes). Each byte in memory is referenced by a unique address. Memory addresses start with zero and are incremented by one for each succeeding byte. Memory addresses in the 32-bit processors always consist of 24 bits. In the 16-bit processors, memory address within the limits of the particular hardware configuration is considered valid. Halfwords must be referenced with halfword addresses. Fullwords must be referenced with addresses that are multiples of four. Double words must be referenced with addresses that are multiples of eight.

## 1.2.4 Software Relocation

Programs written in CAL/32 can be absolute or relocatable. An absolute program is one whose origin (starting location) is specified at assembly time as a fixed halfword location in memory. Subsequent addresses within the program, whether referencing instructions or data, are fixed at assembly time. For execution, absolute programs always must be loaded into memory at the location specified as the origin. This type of programming is useful in stand-alone applications and some operating system situations.

Relocatable programs can be loaded for execution into any halfword location in memory. The origin of a relocatable program is assumed to be relocatable zero. The CAL/32 output for this type of program specifies all addresses in the program as relative displacements from the origin. At link time, the linkage editor resolves all addresses within the program by adding a relocation value (the actual memory address for the start of the program) to the relative addresses supplied by CAL/32. Relocation applies only to addresses within the program. Relocatable programs can contain absolute data.

#### 1.2.5 Hardware Relocation

1

Some Perkin-Elmer processors and their operating systems support hardware relocation and segmentation. Programs prepared for these systems start out as relocatable. A linkage editor processes the relocatable output from CAL/32 to link in any needed subprograms. The output of this process is an absolute program that, because of the relocating hardware, can be loaded at any memory address that is a multiple of 256 for memory access controller (MAC) machines, or 2048 for memory address translator (MAT) machines. At run time, the relocating hardware adds the required relocation value to all addresses supplied by the program. This relocating hardware also provides for program segmentation, where the program is divided into pieces that can be loaded into noncontiguous blocks of memory.

CAL/32 supports segmentation by allowing the programmer to divide the program into pure and impure segments. The pure segment of a program consists of machine instructions and constant data and cannot be modified at run time. (The operating system and the hardware prevent modification.) The impure segment consists of the data base which can be modified at run time. Programs prepared as pure and impure segments can be shared (executed concurrently) by several users. Only one copy of the pure segment resides in memory during execution while there is one copy of the impure segment for each user.

## 1.3 INSTRUCTION FORMATS (16-BIT)

The 16-bit processors have four types of machine instructions: register-to-register, register and indexed storage, register and immediate, and short form. The following abbreviations illustrate the instruction formats:

OP Operation
R1 First operand register
R2 Second operand register
N A 4-bit immediate value
X2 Second operand index register
A2 Second operand direct address
I2 Second operand immediate value

Most instructions require two operands, the first of which is contained in a register. The result usually replaces the contents of the first operand register. Exceptions to these rules are noted in section 1.5.

1.3.1 Register-to-Register (RR) Instructions

Register-to-register instructions cause operations to take place between operands contained in registers. Register-to-register instructions are 16 bits long, as shown in Figure 1-1.

| ۱     | OP |   |   | R 1 |    |    | R 2 |    |
|-------|----|---|---|-----|----|----|-----|----|
| Bits: |    | 7 | 8 |     | 11 | 12 |     | 15 |

| Figure 1-1 RR Fo | rmat ( | 16- | Bit) |
|------------------|--------|-----|------|
|------------------|--------|-----|------|

The first eight bits of the instruction define the operation. The next four bits identify the first operand register. The final four bits identify the second operand register. In most register-to-register instructions, the specified operation takes place between the contents of the first operand register and the contents of the second operand register. The result of the operation replaces the contents of the first operand register.

1-5

## 1.3.2 Register and Indexed Storage (RX) Instructions

Register and indexed storage instructions cause an operation to take place between a first operand, contained in a register, and a second operand, located in main memory. These instructions require 32 bits, as shown in Figure 1-2.



## Figure 1-2 RX Format (16-Bit)

The first eight bits define the operation. The next four bits identify the first operand register, and the next four bits identify an optional index register. The remaining 16 bits specify an address in main memory. The operation takes place between the contents of the first operand register and the contents of the memory location specified. The actual address of the second operand is determined by adding the contents of the index register to the contents of the address field. If the index field of the instruction contains zero, no indexing takes place. In most cases, the result of the operation replaces the contents of the first operand register.

## 1.3.3 Register and Immediate (RI) Instructions

These instructions cause operations to take place between the contents of a register and the contents of an immediate field imbedded in the instruction itself. They are 32 bits long, and are shown in Figure 1-3.

| 1          | OP |    | R 1   | X 2 | 12   | <u>+</u> ا |
|------------|----|----|-------|-----|------|------------|
| Bits:<br>0 |    | 78 | 11 12 | 15  | 5 16 | 31         |

Figure 1-3 RI Format (16-Bit)

The first eight bits specify the operation. The next four bits identify the first operand register. The next four bits identify an optional index register. The final 16 bits are the immediate value. The first operand is the contents of the first operand register. The second operand is obtained by adding the contents of the index register to the contents of the immediate field. If the index field contains zero, no addition takes place. The result of the operation usually replaces the contents of the first operand register.

#### 1.3.4 Short Form (SF) Instructions

These instructions are variations on the register and immediate instructions in which the second operand is small enough to be expressed in four bits. Short form instructions require 16 bits, as shown in Figure 1-4.

| 1     | OP |    | R 1 |       | N | 1  |
|-------|----|----|-----|-------|---|----|
| Bits: |    |    |     |       |   |    |
| 0     |    | 78 |     | 11 12 |   | 15 |

## Figure 1-4 SF Format (16-Bit)

The first eight bits indicate the operation. The next four bits identify the first operand register. The next four bits contain the immediate value. Operations take place between the contents of the first operand register. The result of the operation usually replaces the contents of the first operand register.

#### 1.4 INSTRUCTION FORMATS (32-BIT)

The 32-bit processors recognize seven different types of instructions. These are: register-to-register, three variations on register and indexed storage, two variations on register and immediate, and short form. The following abbreviations are used to illustrate instruction formats:

| OP  | Cperation                            |
|-----|--------------------------------------|
| R 1 | First operand register               |
| R 2 | Second operand register              |
| N   | A 4-bit immediate value              |
| X 2 | Second operand single index register |
| D2  | Second operand displacement          |
| FX2 | Second operand first index register  |
| SX2 | Second operand second index register |
| A 2 | Second operand direct address        |
| I2  | Second operand immediate value       |
|     |                                      |

Most instructions require two operands, of which the first is the contents of a register. The result of the operation usually replaces the contents of the first operand register. Exceptions to these rules are noted in Section 1.5.

## 1.4.1 Register-to-Register (RR) Instructions

The format and function of these instructions are the same as for the 16-bit processors. They cause operations to take place between operands contained in registers, and they require 16 bits. These instructions are shown in Figure 1-5.

| 1     | OP | 1  | R1 | R 2 |    |
|-------|----|----|----|-----|----|
| Bits: |    |    |    |     |    |
| 0     |    | 78 | 11 | 12  | 15 |

| Figure | 1-5 | RR | Format | (32-Bit) |  |
|--------|-----|----|--------|----------|--|
|--------|-----|----|--------|----------|--|

The first eight bits specify the operation. The next four bits identify the first operand register, and the last four bits identify the second operand register. The processor performs the indicated operation between the contents of the first operand register and the contents of the second operand register. In most RR instructions, the result replaces the contents of the first operand register.

## 1.4.2 Register and Indexed Storage One (RX1) Instructions

These instructions define an operation between the contents of a register and the contents of a main memory location. They require 32 bits, as shown in Figure 1-6.

|            | 0 P | 1  | R 1 | <br>I | X 2 |    | 0  | <br>0  |  | D2 | 4<br>/ |
|------------|-----|----|-----|-------|-----|----|----|--------|--|----|--------|
| Bits:<br>0 |     | 78 |     | 11 12 |     | 15 | 16 | <br>17 |  | 18 | 31     |



The first eight bits define the operation. The next four bits identify the first operand register, and the next four bits identify the index register. The next two bits, bits 16 and 17, must be zeros. The next 14 bits constitute a direct program address in a range from 0 to 16383.

The address of the second operand is obtained by adding the contents of the index register to the contents of the 14-bit address field. If the index register field contains zero, this addition does not take place, and the contents of the address field are used as the address. The operation takes place between the contents of the first operand register and the contents of the specified memory location. The result usually replaces the contents of the first operand register.

1.4.3 Register and Indexed Storage Two (RX2) Instructions

These instructions define operations between the contents of a register and the contents of a location in main memory. RX2 instructions are like the RX1 instructions; they require 32 bits. They differ from the RX1 instructions in the method of calculating the second operand address. See Figure 1-7.

| <br>I      | OP |    | R 1 |       | X 2 |    |    | <br> A 2           | <i>4</i> ا |
|------------|----|----|-----|-------|-----|----|----|--------------------|------------|
| Bits:<br>0 |    | 78 |     | 11 12 |     | 15 | 16 | <del>ر</del><br>17 | 7<br>31    |

Figure 1-7 RX2 Format (32-Bit)

The first eight bits define the operation. The next four bits identify the first operand register, and the next four bits identify the index register. The next bit, bit 16, must be a one. The remaining 15 bits are treated as a signed integer in two's complement notation. Bit 17 is the sign bit which, if one, indicates a negative quantity, and if zero, indicates a positive quantity.

The address of the second operand is obtained in two steps.

- The signed integer, with sign bit extended to produce a 32-bit integer, is added to the contents of the index register.
- This intermediate result is added to the value in the incremented location counter. The result is truncated to 24 bits.

į.

If the index register field is zero, the first addition does not take place. The indicated operation takes place between the contents of the first operand register and the contents of the specified memory location. The result usually replaces the contents of the first operand register.

## 1.4.4 Register and Indexed Storage Three (RX3) Instructions

These instructions are analogous to the RX instructions in the 16-bit processors. They call for operations between the contents of a register and the contents of an indexed memory location and require 48 bits. See Figure 1-8.

|            | OP | 1  | R 1 |    |    | FX2 |    | 0  | 1  | 0  | 1 | 0  |    | S¥2 | •••• | 1 A2 | <i>4</i> |
|------------|----|----|-----|----|----|-----|----|----|----|----|---|----|----|-----|------|------|----------|
| Bits:<br>0 |    | 78 |     | 11 | 12 |     | 15 | 16 | 17 | 18 | 1 | 19 | 20 |     | 23   | 24   | 7<br>47  |

Figure 1-8 RX3 Format (32-Bit)

The first eight bits specify the operation. The next four bits identify the first operand register, and the next four bits identify the first index register. Bit 16 must be zero. Bit 17 must be one. Bits 18 and 19 must be zero. The next four bits identify the second index register. The next 24 bits contain a direct memory address.

The address of the second operand is obtained by adding the contents of the first index register to the contents of the second index register. This intermediate result is then added to the contents of the direct address field, and the final result is truncated to 24 bits.

If either of the index register fields contains zero, that level of indexing does not take place. If both are zero, no indexing takes place. In most RX3 instructions, the operation takes place between the contents of the first operand register and the contents of the specified memory location. The result usually replaces the contents of the first operand register.

## 1.4.5 Register and Immediate One (RI1) Instructions

These instructions are similar to the RI instructions in the 16-bit processors. They specify operations that take place between the contents of a register and the contents of a field that is part of the instruction. They require 32 bits, as shown in Figure 1-9.



Figure 1-9 RI1 Format (32-Bit)

The first eight bits indicate the operation. The next four bits identify the first operand register, and the next four bits identify an index register. The second operand is obtained by extending the contents of the immediate field to 32 bits, by propagating the sign bit, and then adding this quantity to the contents of the index register. If the index register field is zero, no addition takes place, and the extended immediate value is the second operand. The operation takes place between the contents of the first operand register and the immediate value. The result usually replaces the contents of the first operand register.

#### 1.4.6 Register and Immediate Two (RI2) Instructions

These instructions are similar to the RI1 instructions, except that the field contains a 32-bit value, and the instruction itself requires 48 bits. See Figure 1-10.

|            | OP |   |   | R 1 |      | X2 | 12    | 44<br>44 | +<br>( |
|------------|----|---|---|-----|------|----|-------|----------|--------|
| Bits:<br>0 |    | 7 | 8 | 1   | 1 12 |    | 15 16 | 23 24    | 47     |

## Figure 1-10 RI2 Format (32-Bit)

The first eight bits define the operation. The next four bits identify the first operand register. The next four bits identify the index register. The second operand is obtained by adding the contents of the index register to the contents of the immediate field. If the index register field is zero, no addition takes place, and the immediate value is the second operand. The operation takes place between the contents of the first operand register and the immediate value. The result usually replaces the contents of the first operand register.

## 1.4.7 Short Form (SF) Instructions

Short form instructions are similar to the SF instructions in the 16-bit processors. They specify operations between the contents of a register and the contents of an immediate field, whose value is small enough to be expressed in four bits. These instructions require 16 bits, as shown in Figure 1-11.

| 1     | OP | 1  | R 1 |       | N |    |
|-------|----|----|-----|-------|---|----|
| Bits: |    |    |     |       |   |    |
| 0     |    | 78 |     | 11 12 |   | 15 |

Figure 1-11 SF Format (32-Bit)

The first eight bits define the operation. The next four bits identify the first operand register. The next four bits are the immediate field. The operation then takes place between this value and the contents of the first operand register. The result usually replaces the contents of the first operand register.

## 1.4.8 Register and Indexed Storage/Register and Indexed Storage (RXRX) Instructions

Register and indexed storage/register and indexed storage (RXRX) instructions resemble a pair of adjacent RX instructions, but represent one cohesive string-processing instruction. An RXRX instruction is comprised of two instruction members. Each member can be any one of the RX1, RX2, or RX3 machine formats, independent of the other member's format. For example, the first instruction member might be of the RX1 format, and the second instruction member might be of the RX3 format, yielding a 10-byte RXRX instruction. Thus, an RXRX instruction length might range from 8, 10, or 12 bytes.

The first eight bits of the first instruction member, OP, specify the operation class. The particular RXRX operation is specified by the contents of the Operation-Modifier (OP-MOD) field in the first eight bits of the second instruction member. OP-MOD is actually generated by the assembler according to the specific RXRX operation mnemonic and the R1/L1 or R2/L2 fields programmed by the user in source code. Refer to Figure 1-12.



Figure 1-12 RXRX Format (32-Bit)

The next four bits in the first instruction member, R1/L1, identify either R1, the string's length-specifying register, or L1, the string's actual length. The user specifies to the assembler whether the value in the R1/L1 field is a register or an immediate value.

The R1/L1 field is assumed to be a register, unless an equal sign (=) precedes the L1 source expression. In machine format, the IL1 field is set when the =I1 source field specifies an immediate value as length. The IL2 field in machine format is reset when the R1 field is used to specify a register that contains the string's length. When the length is an immediate value, its value may range from 0 through 15. When the length is in a register, the register may contain a length that ranges from 0 through 224-1. A length of 0 indicates a null string.

The remaining bits, bits 12 through 31 or 12 through 47, of the first instruction member, OPN1, contain the address/location of the lowest addressable byte of a string or its storage location. The field, OPN1, is then similar to the indexed address portion of an RX1, RX2, or RX3 machine format. See OPN2 below.

The first eight bits of the second instruction member, OP-MOD. are an operation-modifier field containing OPN1's length indicator, IL1, in bit 0; OFN2"s length indicator, IL2, in bit 1; a special circumstances bit, C, in bit 2; and in bits 3 through 7, FUNC, the specific function code of the general operation class, OP. As described above, IL1 and IL2 are determined by the The special circumstances bit, C, and function code, assembler. FUNC, are determined by the assembler from the operation-mnemonic. The C bit is used by some RXRX instructions to indicate that the result of the operation will be forced positive.

The next four bits, bits 8 through 11, of the second instruction member, R2/L2, identify either R2, this string's length-specifying register; or L2, the string's actual length. Again, the user specifies in source format to the assembler whether the value in the R2/L2 field is a register or an immediate value. The R2/L2 source format field is assumed to be a register, unless an equal sign (=) precedes the L2 source expression. In machine format, IL2 is set when the =L2 field is used to specify an immediate value. IL2 is reset when R2 is used to specify a register. When the length is an immediate value, expressed as =L2, its value may range from 0 through 15. When the length is in a register, its value may range from 0 through 224-1. A zero length indicates a null string.

The remaining bits, bits 12 through 31 or 12 through 47, of the second instruction member, OPN2, contain the address/location of the lowest addressable byte of a second member's string. Both OPN1 and OPN2 are similar in format to the indexed address portion of an RX1, RX2, or RX3 machine format. The particular format of either OPN1 or OPN2 is selectively generated by the assembler, independently according to the user source program.

In RX1 machine format, bits 16 and 17 are zero. Bits 12 through 15 identify the index register, X2, the contents of which are added to the absolute 14-bit value, D, to formulate the string's address.

In RX2 machine format, bit 16 is set. Bits 12 through 15 identify the index register, X2, the contents of which are added to the 15-bit displacement value, D2, to formulate the string's address.

In RX3 machine format, bits 16 through 19 are 0100 binary. Bits 12 through 15 identify the first index register, FX2; and bits 20 through 23 identify the second index register, SX2. The contents of both are added to the 24-bit address value, A, to formulate the string's address.

#### NOTES

- When the first member's OPN1 represents the string's address in RX2 format, the displacement value, D2, is relative to the end address of the first instruction member, not to the end of the full RXRX instruction.
- 2. When the second member's OPN2 represents the string's address in RX2 format, the displacement value is relative to the end of the second instruction member, which is also the end of the full RXRX instruction.

## 1.5 VARIATIONS ON INSTRUCTION FORMATS

Not all instructions follow the above instruction formats. In some instructions the fields are redefined. Some instructions do not require two operands. Some instructions do not change the first operand, some instructions change the second operand, and some instructions change neither operand.

#### 1.5.1 Conditional Branch Instructions

Conditional branch instructions use formats that resemble register-to-register, register and indexed storage, and short form instructions. However, the interpretation of the fields differs from the standard, as does the actual operation. In all conditional branch instructions, the first operand identification is interpreted as a mask that is ANDed with the condition code. If the result of this test indicates that the branch is to be taken, then the second operand address is the location to which the processor must go to obtain the next instruction.

In the RR instructions, the second operand register contains the branch address. In the RX instructions, the branch address is obtained by one of the standard methods for obtaining second operand addresses. In the SF instructions, the immediate field is interpreted as a halfword displacement, either forward or backward, from the current location counter. The branch address is obtained by adding or subtracting this quantity from the current location counter.

## 1.5.2 Branch and Link Instructions

These instructions facilitate branching to and returning from subroutines. They use formats similar to RR and RX where the first operand register is the link register. Before the branch is taken, the address of the next memory location following the branch instruction is placed in this register. In the RR instructions, the branch location is the contents of the second operand register. In the RX instruction, the branch address is obtained by one of the usual methods for obtaining second operand addresses.

## 1.5.3 Other Variations

Some instructions change the second operand rather than the first. Most notable among these are the store instructions and the instructions that add the contents of a register to the contents of a memory location.

Test instructions and compare instructions change neither operand. The indicated operation takes place between the two operands, but neither is changed. The result of the operation is indicated by the condition code. Certain other instructions, such as load PSW and simulate interrupt, do not always require a first operand. In addition, all of the I/O instructions do not follow the general rules. For detailed information on how these and other anomalous instructions work, refer to the appropriate processor reference manual.

## CHAPTER 2 SYMBOLIC REPRESENTATION

## 2.1 INTRODUCTION

When writing assembly language programs, the programmer uses meaningful symbols to represent the binary language interpreted by both Common Assembly Language/32 (CAL/32) and the processor. Symbols consist of printable ASCII characters, either singly or in combination. CAL/32 recognizes the complete set of printable ASCII characters. However, depending on the context, there can be restrictions on the use of the complete set. See Chapter 3.

## 2.2 SYMBOLS AND EXPRESSIONS

Symbols represent addresses, register identifiers, absolute values, operation identifiers, and constants. Examples of symbols are:

A LOOP BXLE PART1 REG5 16

Symbols can be combined to form expressions. The arithmetic operators: plus, minus, multiply, divide are represented in CAL/32 by the symbols: +, -, \*, /. They combine with other symbols to form arithmetic expressions. Examples of these arithmetic expressions are:

A+B LAST-FIRST\*TWO A-16

Blanks and parentheses are not permitted within an expression. For example, the sequence:

A - B \* (C + D)

would not be interpreted by CAL/32 as an expression. Depending on the context, CAL/32 might misinterpret the symbols, generate incorrect code, and fail to detect the error. Where CAL/32 can recognize the error, it generates an error message.

The evaluation of expressions takes place from left to right with no rules of precedence. Thus, CAL/32 evaluates the expression:

LAST-FIRST\*TWO

by subtracting the value of First from the value of Last, and multiplying this result by the value of Two.

Logical expressions consist of symbols joined by the logical operators AND and inclusive OR. They are represented in CAL/32 by the symbols & and !. Examples of logical expressions are:

```
X&Y!A
CHAR&NULL
```

Logical expressions are evaluated from left to right with no rules of precedence. Blanks and parentheses are not permitted in logical expressions.

Mixed expressions are formed by combining logical and arithmetic operators. For example:

A-B!TWO

CAL/32 evaluates this expression by first subtracting the value of B from the value of A, and then ORing the result with the value of Two. Mixed expressions are like arithmetic and logical expressions in that blanks and parentheses are not allowed, and the method of evaluation is from left to right with no rules of precedence.

Symbols represent either absolute or relocatable quantities. At assembly time, relocatable quantities have a value equal to their displacement from some fixed point within the program, usually but not necessarily, the origin or starting location. At load time, the relocatable guantity is replaced by an absolute quantity whose value is calculated by adding the relocation value to the relocatable quantity. Absolute quantities are known to the assembler at assembly time and are not changed at load time.

The operations: multiply, divide, AND, and CR are permitted only between absolute data. The plus and minus operators can be used on mixed data. The results of such operations are: CPERATION

RESULT

| Absolute + Absolute       | Absolute    |
|---------------------------|-------------|
| Absolute - Absolute       | Absolute    |
| Relocatable + Relocatable | Invalid     |
| Relocatable - Relocatable | Absolute    |
| Relocatable + Absolute    | Relocatable |
| Relocatable - Absolute    | Relocatable |
| Absolute + Relocatable    | Relocatable |
| Absolute - Relocatable    | Invalid     |

## 2.3 SYMBOLS AND THEIR VALUES

By definition, certain symbols used in CAL/32 programming have implicit values; that is, the value of the symbol is determined by the way in which it is expressed and used. Examples of this kind of symbol are the decimal, hexadecimal, and character symbols used as operands in instructions. There are also global symbols in CAL/32. These symbols have preset values that cannot be redefined by the programmer. The programmer also can define the value of a symbol explicitly by using the equate statement. This section covers the use of implicit and global symbols. Chapter 3 covers the explicit use and definition of symbols.

## 2.3.1 Implicit Symbols

When used in the correct context, a string of decimal digits is automatically assigned the actual value of the number represented by the string. For example, the expression:

A+14

has a value that the assembler determines by adding the quantity 14 to the value A, which must be defined by some other means.

CAL/32 also recognizes the implicit value of special character strings the programmer uses to represent decimal, hexadecimal, and character values. These strings are made up of a single letter that indicates the particular type, followed by a group of characters enclosed in apostrophes that represents the value. The code characters are:

CODE CHARACTER

TYPE

| Н | Halfword  | decimal     |
|---|-----------|-------------|
| F | Fullword  | decimal     |
| Х | Halfword  | hexadecimal |
| Y | Fullword  | hexadecimal |
| С | Character | -           |

2-3

Decimal numbers consist of an optional sign (+ or -) followed by decimal digits representing the actual value. Commas are not allowed in the representation. Halfword decimal values can be represented by from 1 to 5 decimal digits, with a range from -32,768 to +32,767. Fullword values can be represented by from 1 to 10 decimal digits, with a range from -2,147,483,648 to +2,147,483,647. CAL/32 converts these decimal numbers into two's complement binary integers. Examples of decimal symbols, with their internal representation expressed in hexadecimal notation are:

| SYMBCL             | VALU    | JE   |
|--------------------|---------|------|
| Н'125'             | 007D    |      |
| H'32765'           | 7 F F D |      |
| H <b>'+</b> 32765' | 7FFD    |      |
| H'-15'             | FFF1    |      |
| F'123123'          | 0001    | EOF3 |
| F'1'               | 0000    | 0001 |
| F'-2'              | FFFF    | FFFE |
|                    |         |      |

Hexadecimal symbols consist of the X or Y type code followed by a string of hexadecimal digits enclosed in apostrophes. Halfword symbols can use from one to four digits. Fullword symbols can use from one to eight digits. Leading zeros are not required, and the value is right justified. Examples of hexadecimal symbols are:

SYMBOL VALUE

| X * F *   | 000F |      |
|-----------|------|------|
| X • D4E • | OD4E |      |
| Y'030'    | 0000 | 0030 |
| Y * A *   | 0000 | 000A |
| Υ • Ο •   | 0000 | 0000 |
|           |      |      |

Character symbols consist of from one to four ASCII characters enclosed in apostrophes and preceded by the type code C. Characters are right justified, with zero fill. Depending on the context, either a halfword or a fullword results. Examples of character symbols are:

| SYMBOL  | VALUE<br>(HALFWORD) | VALU<br>(FULL) | JE<br>NORD) |
|---------|---------------------|----------------|-------------|
| C'*'    | 002A                | 0000           | 002A        |
| C'12'   | 3132                | 0000           | 3132        |
| C'AB'   | 4142                | 0000           | 4142        |
| C'1234' | 3334                | 3132           | 3334        |

In the last example, where a halfword value was generated, only the rightmost two characters were used. Where the context dictates a halfword, and a longer string is used, a truncation error results. One final type of implicit assignment occurs in the use of symbols as statement identifiers. Where a symbol is used in the name field of a statement, it is automatically assigned a value equal to the value of the current location counter. This type of assignment is covered in Chapter 4.

## 2.3.2 Global Symbols

Six symbols recognized by CAL/32 have predetermined values. They are:

ADC LACC PURETOP IMPTOP ABSTCP

The use of these symbols is somewhat restricted, and they cannot be redefined by the programmer.

In programs written for 32-bit processors, the address length constant (ADC) always has a value of 4, the length of an address constant in bytes. (In 32-bit processors, addresses must be contained in fullwords, even though the actual address is only 24 bits in length.) In programs for which CAL/32 is to generate 16-bit code, ADC has the value of 2. In programs written for 32-bit processors, the log (base 2) of the address length constant (LADC) always has a value of 2. In programs for 16-bit processors, LADC always has a value of 1. Both of these symbols, ADC and LADC, are used most frequently in common mode programming. See Chapter 4.

The symbols PURETOP, IMPTOP, and ABSTOP have values equal to:

| PURETOP | The | next | available | location | in | the | pure segment     |
|---------|-----|------|-----------|----------|----|-----|------------------|
| IMPTOP  | The | next | available | location | in | the | impure segment   |
| ABSTOP  | The | next | available | location | in | the | absolute segment |

Because these values change during assembly, the symbols must be used carefully. They can be used as second operand identifiers in machine instructions and as operands in assembler instructions where they are treated as address values. They cannot be used in assembler instructions that control the location counter. The asterisk symbol (\*), used as an operand rather than as an operator in an expression, always has a value equal to the value of the current location counter. Throughout the assembly process, CAL/32 maintains a location counter analogous to the hardware location counter contained in the central processing unit (CPU). Depending on the organization of the program, this location counter can contain any one of several values. For 32-bit programs the location counter may point to the current location in the absolute segment, the pure segment, or the impure segment. For 16-bit assemblies, the location counter may point to the current relocatable location.

## CHAPTER 3 THE SOURCE PROGRAM

## 3.1 INTRODUCTION

The source program consists of a set of assembly language statements that specify the operations to be performed by the processor, define the constants and storage areas used by the program, and control the assembly process to produce the desired output. Source statements for Common Assembly Language/32 (CAL/32) are of two types: comment statements and instruction statements. Instruction statements are further divided into machine instructions and assembler instructions. Each statement consists of an 80-character record, in which symbols and expressions identify the statement, and where necessary, indicate the operation and locate the operands.

## 3.2 COMMENT STATEMENTS

Comment statements can appear anywhere in the source program. They allow the programmer to include easy-to-read documentation in the source program listing. They produce no object code. The assembler does not process comment statements except to check for proper sequencing and scan for invalid characters.

Comment statements must always start with an asterisk (\*) in the first character position. Positions 2 through 71 can contain any printable ASCII character, including lowercase alphabetic characters. Blanks are considered to be "printable" characters. If a nonprintable character turns up in a comment statement, CAL/32 replaces it with a pound sign (#). Position 72 of a comment statement must contain a blank character. Positions 73 through 80 can, at the programmer's option, be used for sequence identification. The sequence field can contain any printable ASCII character other than lowercase alphabetic characters. Where sequence checking is requested, each successive sequence identifier must be greater, in the ASCII collating sequence, than the previous identifier. Examples of comments are:

| 1 /2 /3                                       |       |
|-----------------------------------------------|-------|
| * THIS IS A COMMENT                           |       |
| * IT MAY APPEAR ANYWHERE IN THE PROGRAM       |       |
| * SUBROUTINE GETCHAR GET                      | 10000 |
| *MOVES A CHARACTER FRCM THE INPUT BUFFER GET  | 10010 |
| *AND RETURNS IT IN GENERAL REGISTER THREE GET | 10020 |

DOCTOTON

## 3.3 INSTRUCTION STATEMENTS

Instruction statements can be written in fixed format or in free format. For either format, there are five distinct fields in each statement. In fixed format, these fields are:

CHARACTER POSITIONS DEFINITION 1 through 8 Name field 10 through 14 Operation field 16 through 14 Operation field

| 16  | through | n  | Operand field  |
|-----|---------|----|----------------|
| n+2 | through | 71 | Comment field  |
| 73  | through | 80 | Sequence field |

Positions 9, 15, and 72 always must contain blank characters. The operand field and the comment field are variable in length, and the first blank character after position 16 serves as a delimiter between the operand field and the comment field. Because of the way the output listing is tabulated, the comment field cannot contain more than 37 characters. If more than 37 characters appear, only the first 37 are printed on the output listing.

CAL/32 does not require source statements to be written in fixed format. It accepts free format source, in which blank characters serve as delimiters. If, for example, the name field is not used, a blank character in the first position indicates that the next nonblank character is the start of the operation field. Similarly, if the operation field requires fewer than five characters, the first blank character following the operation code indicates that the next nonblank character is the first character of the operand field. As in the fixed format statement, the first blank character following the operand field indicates the end of that field and the beginning of the comment field. There are three restrictions on the use of free format:

- 1. Comment length is limited to 37 characters, including blanks.
- 2. Position 72 must contain a blank character.

3. The sequence field must start in position 73.

The last restriction is because CAL/32 cannot distinguish between a blank character as part of a comment and a blank character intended to separate the comment from the sequence field.

If there are no nonblank characters in positions 1 through 20, CAL/32 assumes that the statement is a comment and lists it as such, with a warning note. If more than 15 blanks separate the name field from the operation field, CAL/32 assumes that the
operation field is not present. Similarly, if more than 15 blanks separate the operation field from the operand field, CAL/32 assumes that the operand field is not present. In both cases, CAL/32 generates an error message.

When writing CAL/32 instruction statements, the programmer uses symbolic representation in the name field, the operation field, and the operand field. The following paragraphs describe the use of symbols and expressions in these fields.

# 3.4 NAME FIELD

Where a symbol appears in the name field, it represents the value of the current location counter for that particular instruction. This allows the programmer to refer to specific locations symbolically, without having to know the actual value of the location counter. The following five restrictions apply to the formation of names:

- The first character of a name must be an uppercase or lowercase alphabetic character or one of the special characters:
  - at sign (@)
  - dot (.)
  - dollar sign (\$)
  - underscore (\_)

#### NOTE

Lowercase letters are internally converted to uppercase except in string constants.

- The remaining characters can be made up of any combination of valid first characters, plus the numeric characters 0 through 9.
- 3. The name must consist of from one to eight characters.
- 4. The name must start in the first character position of the source record.
- 5. Imbedded blanks are not permitted.

3-3

ł

1

L

Examples of valid names are:

LABEL LOOP1 .SIN @GOTO \$\$GET5

Examples of incorrect names are:

| 1L00P       | First character is a | numeric |
|-------------|----------------------|---------|
| LOOPCOUNTER | More than eight chan | cacters |
| AB?C        | Question mark is ill | legal   |

As a general rule, a given symbolic string can appear only once in the program where it defines a location. That is, the same symbol may not appear in the name field of more than one instruction. The exception to this is the equate instruction. This is covered in the section on assembler instructions.

# 3.5 OPERATION FIELD

The use of symbols in the operation field is severely restricted. Only previously defined symbols can appear in this field. The symbols that appear in the operation field are called mnemonics; they represent operations to be performed by the processor at run time, or operations to be performed by the assembler. CAL/32 recognizes mnemonics that represent all machine operations for all Perkin-Elmer processors. It also recognizes a large set of assembler mnemonics that allows the programmer to control the assembly process.

Mnemonics can consist of no more than five characters. They are formed in the same way as names and use the same character set. CAL/32 permits users to define mnemonics. This process is described in the section that deals with the equate instruction. Specific mnemonics that define machine operations and assembler operations are described later in this chapter. Examples of operation mnemonics are:

| MNEMONIC | ΤΥΡΕ      | MEANING                   |
|----------|-----------|---------------------------|
| AR       | Machine   | Add register              |
| S        | Machine   | Subtract                  |
| CLI      | Machine   | Compare logical immediate |
| ORG      | Assembler | Set location counter      |

# 3.6 OPERAND FIELD

CAL/32 permits the use of both symbols and expressions in the operand field of instructions. Symbols used in the operand field can be implicitly defined or can be explicitly defined. The rules for forming operands for assembler instructions vary from instruction to instruction, and each is described individually later in this chapter.

Most machine instructions require two operands while some require only one. Where two operands are required, the first is separated from the second by a comma. Following are the general rules for forming operands for machine instructions.

# 3.6.1 Register-to-Register Instructions

Both the first and the second operand must be represented by symbols or expressions with values between 0 and 15 inclusive. If the value is greater than 15 or less than 0, the assembler sets it to 0, and generates an error message. For example, if the symbols 1 and 2 appear in the operand field of the add register instruction:

AR 1,2

CAL/32 generates the machine code to add the contents of register 2 to the contents of register 1 and store the result in register 1. The use of 1 and 2 here is an example of how decimal numbers have an implicit value when used in the proper context. Another example:

# AR X'1', X'2'

shows how hexadecimal symbols can be used as register identifiers. This is an exception to the previously stated rule that hexadecimal symbols generate halfword or fullword values. Where used as register identifiers, decimal, hexadecimal, and character symbols cause the assembler to generate 4-bit values.

Expressions can be used in identifying registers, as in:

where CAL/32 evaluates the expressions and uses the results as the register identifiers. This is not a universally useful feature of the language, although it has some applications in common mode programming. A more useful way to identify registers is to use explicitly defined symbols. Suppose the symbols SUM and INC are defined to have values of 1 and 2, respectively. Then the instruction:

AR SUM, INC

has the same effect as:

AR 1,2

yet the notation is more meaningful because registers 1 and 2 are identified as the SUM and INC registers.

3.6.2 Register and Indexed Storage Instructions

If the first operand is required, it must be a valid register identifier as described for register-to-register instructions. The second operand, separated from the first by a comma, can be:

- a symbol,
- an expression, or
- a symbol or an expression followed by an index register identifier enclosed in parentheses.

Where indexing is used, identification of the registers follows the same rules as those for specifying first or second operand registers. In double-indexed instructions, the first and second index identifiers are separated by a comma. An example of how register and indexed storage instructions are written is:

S 1,A

where the first operand is the contents of general register 1, and the second operand is the value at location A in memory. Another example:

S SUM, TABLE(PTR)

shows how single indexing is expressed. In this case, the first operand is the value contained in the register identified by the symbol SUM, and the second operand is the value at memory location table plus the contents of the index register PIR. Another example:

S SUM, LAST-FIRST(BASE, PTR)

shows the use of double indexing along with the use of an expression in the operand field. A final example:

S SUM, O(ADDR)

illustrates where an address of a second operand is contained in the index register. Here, there must be a symbol in the address field even if it is equal to zero.

3.6.3 Register and Immediate Instructions

The first operand must be specified by a valid register identifier. The second operand can be:

- a symbol,
- an expression, or
- a symbol or an expression followed by an index register identifier enclosed in parentheses.

Example:

### CLI STRNG,C'ABCD'

causes the character string ABCD, represented internally as the fullword character value 4142 4344, to be compared with the contents of the register identified by the symbol STRNG. In another example:

CLI ADDR, LAST-FIRST (PTR)

the expression LAST-FIRST is evaluated by CAL/32 at assembly time. At run time this value is added to the contents of the index register before the comparison takes place. In another example:

CLI ADDR,Y'2000'(PTR)

the fullword, hexadecimal quantity 0000 2000, is added to the contents of the index register. The result is then compared with the contents of the register identified by the symbol ADDR.

# 3.6.4 Register and Indexed Storage/Register and Indexed Storage (RXRX) Instructions

The RXRX instructions have four basic source operand fields, each of which is separated from the other by a comma. The first operand field can be:

- a valid register identifier, symbol, or expression with a defined absolute value in the range 0 to 15
- an equal sign (=) preceding a symbol or an expression with a defined absolute value in the range 0 to 15

The second source operand field, separated from the first by a comma, can be:

- a symbol or an expression
- a symbol or an expression, optionally followed by an index register identifier enclosed in parentheses
- a symbol or an expression, optionally followed by a pair of index register identifiers, separated by a comma, with the pair enclosed in parentheses

The third source operand field, separated from the second by a comma, can be:

- a valid register identifier, symbol, or expression with a defined absolute value in the range 0 to 15
- an equal sign (=) preceding a symbol or an expression with a defined absolute value in the range 0 to 15

The fourth source operand field, separated from the third by a comma, can be:

- a symbol or an expression
- a symbol or an expression, optionally followed by an index register identifier enclosed in parentheses
- a symbol or an expression, optionally followed by a pair of index register identifiers, separated by a comma, with the pair enclosed in parentheses

.

Examples of how these instructions are written are:

MOVE =LENGTH2, HERE, =LENGTH1, THERE

which moves the string of length, LENGTH1, at location THERE to the location HERE up to the number of bytes indicated by LENGTH2. If LENGTH1 is less than LENGTH2, this instruction pads the extra bytes with the right-justified character in general register zero.

In the preceding example, the first operand field is the immediate value of symbol LENGTH2. The equal sign that specifies LENGTH2's value is an immediate value and not a register identifier. The second operand field is the storage address at location HERE. The third operand field is the immediate value of symbol LENGTH1 (its immediacy is again indicated by the equal sign). The fourth operand field is the string at location THERE.

Another example is:

#### MOVEP R7, PRINTOUT(LINE, COL2), R8, MESSAGE(CLASSX, ERRINDX)

which moves the string of the length specified in general register R8, found at the memory location computed by summing the address value of MESSAGE with the contents of both index registers CLASSX and ERRINDX. The string is moved to a storage location whose address value is computed by summing the address value of PRINTOUT plus the contents of both index registers, LINE and COL2. The number of bytes to be filled is the length specified in general register R7. If the length in R8 is less than that in R7, the MOVEP instruction, by definition, pads the extra bytes with the default character, a space.

In the preceding example, the first operand field is the register identifier, R7; the second operand field is the storage address at location PRINTOUT, as double indexed by the register identifiers, LINE and COL2; the third operand field is the register identifier, R8; and the fourth operand field is the string's location MESSAGE, as double indexed by the register identifiers, CLASSX and ERRINDX.

Another example is:

PMV =8, DECSUMS(SALESID), 5, TOTALS(ORDERX)

s die Maar in 1999 van

which packs and moves the unpacked decimal data digit string whose length is indicated in general register 5. Note that the 5 means a general register because no equal sign precedes it. The unpacked decimal data digit string is found at the memory location computed by summing the address value of TOTALS with the

48-050 FOO ROO

contents of the single index register identifier ORDERX. For details on how this conversion takes place, refer to the instruction definitions in the appropriate processor manuals. Generally, the unpacked decimal data is converted to packed decimal data up to the number of digits that may occupy the reserved byte length, indicated by the =8 expression. In this case, 8 bytes are reserved, providing storage for 15 decimal packed digits and a position for the sign-indicator. The PMV instruction, by definition, has various safeguards for illegal digit cases and overflow, and provides leading zeros as needed, when the number of positions available for either the unpacked digits and the packed digits is of unequal length. The memory location to which the converted digit data is moved is computed by summing the address value of DECSUMS with the contents of the single index register SALESID.

In the preceding example, the first operand field is the immediate value =8. Note that the equal sign specifies that 8 is an immediate value and not a register identifier. The second operand field is the address location DECSUMS as singly indexed by the register identifier, SALESID. The third operand field is the register identifier 5; and the fourth operand field is the address location TOTALS, as indexed by the single index register identifier ORDERX.

# 3.7 MACHINE INSTRUCTIONS

Table 3-1 lists the mnemonics for all machine instructions. Where there is no entry in the format column, that instruction is not available for that particular line of processors.

|                         | MNEMONIC | 32-BIT  <br>FORMAT | 16-BIT  <br>FORMAT |
|-------------------------|----------|--------------------|--------------------|
|                         | λ Ι      | PY I               | <br>PY*            |
|                         | n        |                    |                    |
| Add DP Floating Point   | A D      | RX I               | RX                 |
| Add DP Floating Point   | 1        | 1                  |                    |
| Register                | ADR      | RR                 | RR                 |
| Add to Bottom of list   | ABL      | RX                 | RX I               |
| Add to Bottom of list   | 1        | I                  | 1                  |
| Flagged                 | ABLF     | 1                  | RX**               |
|                         | 1        | 1                  | 1                  |
| Add with Carry Halfword | A CH     |                    | RX                 |
| Add with Carry Halfword | 1        | · · · · •          | 1                  |
| Register                | ACHR     | Í                  | RR                 |
| Acknowledge Interrupt   | ACK      | Í                  | RX                 |
| Acknowledge Interrupt   | 1        | Í                  | Í                  |
| Register                | ACKR     | Í                  | RR                 |
| Add Floating Point      | AE I     | RX                 | RX                 |

# TABLE 3-1 SUMMARY OF MACHINE INSTRUCTIONS AND MNEMONICS

|                                         |              | 32-BIT | 16-BIT  |
|-----------------------------------------|--------------|--------|---------|
| INSTRUCTION                             | MNEMONIC     | FORMAT | FORMAT  |
| ====================================    |              |        | ======= |
| Perister                                | A F R        | RR     |         |
| Ndd Halfuord                            |              | RY     |         |
| Add Halfword Immodiato                  |              | RT1    |         |
| Add Halfword to Memory                  |              | RY     |         |
| Add Halfword Register                   | AHR          | RR*    | RR      |
| Acknowledge Interrunt                   | AT           |        |         |
| Add Immediate                           | AT           | RT2    | RT*     |
| l Acknowledge Interrupt                 |              |        |         |
| Register                                | AIR          |        | RR      |
| Add Immediate Short                     | AIS          | SF     | SF      |
| Autoload                                | AL           | RX     | RX      |
| 1                                       |              |        |         |
| Add to Memory                           | AM           | RX     | RX      |
| Add Register                            | AR           | RR     | RR      |
| Add to Top of List                      | ATL          | RX     | RX      |
| Add to Top of List                      |              |        |         |
| Flagged                                 | ATLF         |        | RX      |
| Branch and Link                         | BAL          | КХ     | RX      |
| Branch and Link                         |              |        |         |
| Register                                | BALR         | RR     | RR      |
| Branch to Control                       |              |        |         |
| Storage                                 | BDCS         | RX     | RI      |
| Branch on Equal Status                  |              |        |         |
| High Speed                              | BESHS        |        | RX**    |
| 1                                       |              |        |         |
| Branch on False Condition               |              |        |         |
| Backward Short                          | BFBS         | SF     | SF      |
| 1 · · · · · · · · · · · · · · · · · · · |              |        |         |
| Branch on False Condition               | BFC          | RX     | RX      |
| Branch on False Condition               |              |        |         |
| Register                                | BFCR         | RR     | RR      |
| Branch on False Condition               |              |        |         |
| Forward Short                           | BFFS         | SF     | SF      |
| Branch on Not Equal                     |              |        |         |
| Status High Speed                       | BNSHS        |        | RX**    |
| Branch on True Condition                |              |        |         |
| Backward Short                          | BIBS         | SF     | SF      |
|                                         | DMA          |        |         |
| Branch on True Condition                | BIC          | НХ     | КХ      |
| pranch on True Condition                | DMGD         |        |         |
| NEYISTEI<br>  Dranch on True Condition  | BICK         | КК     | кк      |
| Dranch on frue Conultion                | סידיכ        |        | CE      |
| I Branch on Index High                  | 6110<br>1071 |        |         |
| Branch on Index Iou or                  | DAU          | хл     | A.7     |
| Faual                                   | BYTE         | RY     |         |
| 1                                       |              | UV I   | NN      |

48-050 FOO ROO

3-11

• £.

|                                |          | 32-BIT   | 16-BTT   |
|--------------------------------|----------|----------|----------|
| INSTRUCTION                    | MNEMONIC | FORMAT   | FORMAT   |
|                                |          | DV (     | ======== |
| Compare  <br>  Complement Bit  | C BT I   | RX I     | KY.      |
| Comprehence Bic                | 0121     |          |          |
| Point                          | CD       | RX       | RX       |
| Compare DP Floating            |          |          |          |
| Point Register                 | CDR      | RR       | RR       |
| Compare Floating Point         | CE       | RX       | RX       |
| Compare Floating Point         |          |          |          |
| Register                       | CER      | RR       | RR       |
| Compare Halfword               | СН       | RX       | RX       |
| Compare Halfword Immediate     | CHI      | RI1      | RI       |
| Compare Halfword Register      | CHR      | RR*      | RR       |
| Change to Halfword Value       | CHVR     | RR       |          |
| Compare Immediate              |          | R12      | RI*      |
| Compare Logical                |          | KX<br>DV | KX*      |
| Compare Logical Byte           |          |          | KX I     |
| Compare Logical Halfword       | СТЧ      | ΓΛ       | R X      |
| I Immediate                    | СТИТ     | RT1      | PT       |
| Immediate                      | CLIII    |          | N I      |
| <br>  Compare Logical Halfword |          |          |          |
| Register                       | CLHR     | RR*      | RR       |
| Compare Logical Immediate      | CLI      | RI1      | RI*      |
| Compare Logical Register       | CLR      | RR       | RR*      |
| Compare Register               | CR       | RR       | RR*      |
| Cyclic Redundancy Check        |          | I        |          |
| Module 12                      | CRC12    | RX       | RX * *   |
|                                |          |          |          |
| Cyclic Redundancy Check        |          |          |          |
| Modulo 16                      | CRC16    | RX       | RX**     |
| Decrement Counter High         | DCUC     |          | DV++     |
| Divido                         | DCH2     | ן עם     | RX**     |
| Divide DD Fleeting Deint       | ן ע      |          |          |
| Divide DP Floating Point       | עע       | ΓKΛ Ι    | RA I     |
| Register                       | אַזע     | 88 1     | קק       |
|                                | DDR      | NU 1     | NU I     |
| Divide Floating Point          | DE       | RX I     | RX       |
| Divide Floating Point          |          |          |          |
| Register                       | DER      | RR       | RR       |
| Divide Halfword                | DH       | RX       | RX I     |
| Divide Halfword Register       | DHR      | RR*      | RR       |
| Divide Register                | DR       | RR       | RR*      |

•

|                                 |              | 32-BIT     | 16-BIT             |
|---------------------------------|--------------|------------|--------------------|
| INSTRUCTION                     | MNEMONIC     | FORMAT     | FORMAT             |
|                                 | ============ | .========= | ===============    |
| Enter Control Storage           | ECS          | RI1        | SF                 |
| Exchange Program Status         |              |            |                    |
| Register                        | EPSR         | RR         | RR                 |
| Exchange Byte Register          | EXBR         | RR         | RR                 |
| Exchange Halfword Register      | EXHR         | RR         |                    |
| Float DP Floating Point         |              |            |                    |
| Register                        | FLDR         | RR         | RR                 |
| Float Register                  | FLR          | RR         | RR                 |
| I Fix DP Floating Point         |              |            |                    |
| Register                        | FXDR         | RR         | RR                 |
| Fix Register                    | FYR          | RR         | RR                 |
| Generate Inter-Process          | TAL          | 1111       |                    |
| I Interrunt                     | СТРТ         |            | <br>               |
| Lord                            |              | עס         |                    |
| I Joad Addrogg                  | ן בו<br>דא   |            | лл.<br>ртж         |
| Joad Buto                       |              |            | <b>υν</b><br>Δτ.   |
| road pyte                       | סיד          | Π <b>Λ</b> | КХ                 |
| I Lond Prite High Speed         |              |            | DT++               |
| Load Byte High Speed            | C11011       |            | VI                 |
| I Indirect                      | TDUCT        |            |                    |
| Indrect                         | TRHOT        | תת         |                    |
| Load Byte Register              | T'RK         | RK         | RR                 |
| <br>  Iond Complement Short     | TCC          | <b>C</b> F | C F                |
| Load DD Floating Doint          |              |            | יכ<br>עם           |
| Load DP Floating Point          | עוב          | ПЛ         | ΔΛ                 |
| Designer                        | מתד          | ו ממ       | חח                 |
| Register<br>Lood Planting Daint |              |            |                    |
| Load Floating Point             | μ£           | KX.        | КХ                 |
| Load Floating Point             | TED          |            | <b>DD</b>          |
| register                        | TEK          | ĸĸ         | RR                 |
| l<br>L Load Halfword            | τu           | Þγ         | <b>v</b> a         |
| Load Walfword Immediate         |              |            |                    |
| Load Halfword Logigal           |              |            | Ω <b>Λ</b> ¥<br>UT |
| I Load Halfword Dogistor        |              |            | ΠΛ<br>ΠΟ           |
| I Load Walfword and Cat         |              | י עע<br>עע | ΓΓ                 |
| I road ugitmord gud set         | спр          |            |                    |
| I Load Immediate                |              | RT2        | RT*                |
| Load Immediate Short            | LTS          | SF         |                    |
| Load Multiple                   | T.M          | RX         | R¥ 1               |
| I load Multiple DD Floating     | ,            | <u>лл</u>  | пл                 |
| Doint                           | מאד ו        | RY         |                    |
| I load Multiple Floating        | 1.11.12      |            | .u. <b>n</b> .     |
| Doin+                           | I T.ME       | RY         | RΥ                 |
| I Toad Drogram Status           |              | 11A        | л <b>л</b><br>ру   |
| Joad Program Status             | 1110         |            | <u>л</u> л         |
| Register                        | LPSR         |            | RR                 |
| I Toad DSW                      |              | BX         | BX<br>TUT          |
| I Load DSW Register             |              | RR         | 11 7               |
| I Toad Boal Iddroed             |              |            |                    |
| I TOAR VEAT VARTESS             |              | 11 A.      |                    |

••

| INSTRUCTION                                                                                                      | MNEMONIC                       | 32-BIT<br>FORMAT             | 16-BIT  <br>FORMAT            |
|------------------------------------------------------------------------------------------------------------------|--------------------------------|------------------------------|-------------------------------|
| Load Register<br>  Multiply<br>  Multiply DP Floating                                                            | LR<br>M                        | R R<br>R X                   | RR*<br>RX*                    |
| Point<br>Multiply DP Floating                                                                                    | MC                             | RX                           | R X                           |
| Point Register<br>  Multiply Floating Point<br>  Multiply Floating Point                                         | MDR<br>ME                      | RR<br>RX                     | RR<br>RX                      |
| Register<br>Multiply Halfword<br>Multiply Halfword Register<br>Multiply Halfword Unsigned                        | MER<br>MH<br>MHR<br>MHU        | RR<br>RX<br>RR*              | RR<br>RX<br>RR<br>RX          |
| Register                                                                                                         | MHUR                           |                              | RR                            |
| Move and Process Byte<br>String Register<br>Multiply Register<br>AND<br>AND Halfword<br>AND Halfword Immediate   | MPBSR<br>MR<br>N<br>NH<br>NHI  | RR<br>RR<br>RX<br>RX<br>RI 1 | RR *<br>RX *<br>RX<br>RI      |
| AND Immediate<br>AND Halfword Register<br>AND Register<br>OR<br>Output Command                                   | NI<br>NHR<br>NR<br>O<br>OC     | RI2<br>RR*<br>RR<br>RX<br>RX | RI*<br>RR<br>RR*<br>RX*<br>RX |
| Output Command Register<br>OR Halfword<br>OR Halfword Immediate<br>CR Halfword to Memory<br>OR Halfword Register | CCR<br>OH<br>OHI<br>CHM<br>OHR | RR<br>RX<br>RI1<br>RR*       | RR<br>RX<br>RI<br>RX**<br>RR  |
| OR Immediate<br>OR Register<br>Process Byte<br>Process Byte Register<br>Read Block                               | OI<br>OR<br>PB<br>PBR<br>RB    | RI2<br>RR<br>RX<br>RR<br>RX  | RI*  <br>RR*  <br>RX          |
| <br>  Remove from Bottom of<br>  List<br>  Remove from Bottom of                                                 | RBL                            | RX                           | RX                            |
| List Flagged<br>Read Block Register                                                                              | RBLF<br>RBR                    | RR                           | RX**<br>RR                    |
| Keset Bit<br>  Read Data                                                                                         | R BT<br>R D                    | RX RX                        | RX                            |

١.

| INSTRUCTION                                                                             | MNEMONIC                  | 32-BIT<br>Format | 16-BIT<br>FORMAT |
|-----------------------------------------------------------------------------------------|---------------------------|------------------|------------------|
| Read DCS<br>Read Data High Speed                                                        | RDHS                      | RR               | RR<br>RX * *     |
| Read Data High Speed<br>Register<br>Read Data Register                                  | R D R H S<br>R D R<br>R H | RR               | RR**<br>RR<br>RY |
| Read Halfword Register                                                                  | RHR                       | RR               | RR               |
| Rotate Left Logical  <br>  Rotate Left Logical                                          | RLL                       | RI1              | RI               |
| Short<br>Read Process Data High                                                         | RLLS                      |                  | SF**             |
| Speed<br>Replace PSW                                                                    | R P D H S<br>R P S W      |                  | RX**<br>RR**     |
| <br>  Rotate Right Logical<br>  Rotate Right Logical                                    | RRL                       | RI1              | RI               |
| Short<br>Remove from Top of                                                             | RRLS                      |                  | SF**             |
| List<br>Remove from Top of                                                              | RTL                       | RX               | RX               |
| List Flagged<br>Subtract                                                                | RTLF<br>S                 | RX               | RX**<br>RX*      |
| Store Byte High Speed<br>Indirect<br>Set Bit                                            | SBHSI<br>SBT              | RX               | RI**             |
| Halfword    Subtract with Carry                                                         | SCH                       |                  | RX               |
| Halfword Register<br>Simulate Channel Program                                           | SCHR<br>SCP               | RX               | RR               |
| Subtract DP Floating<br>Point<br>Subtract DP Floating                                   | SD                        | RX               | RX               |
| Point Register  <br>  Subtract Floating Point                                           | SDR<br>SE                 | RR<br>RX         | RR<br>RX         |
| Register<br>Set Program Mask                                                            | SER<br>SETM               | RR               | R R<br>R X       |
| <br>  Set Program Mask Register<br>  Subtract Halfword<br>  Subtract Halfword Immediate | SETMR<br>SH<br>SHI        | RX<br>RI1        | RR<br>RX<br>RI   |
| Subtract Halfword from                                                                  | SHM                       |                  | RX**             |

and the second second

| 1                                   | 1                                       | 32-BIT   | <b>16-</b> BIT |
|-------------------------------------|-----------------------------------------|----------|----------------|
| I INSTRUCTION                       | MNEMONIC                                | FORMAT   | FORMAT         |
|                                     | ======================================= |          |                |
| Subtract Halfword Register          | I SHR                                   |          |                |
| Subtract Immodiato                  |                                         |          |                |
| Subtract Immediate                  |                                         |          |                |
| Simulate Interrupt                  | SINT                                    |          | RI             |
| Subtract Immediate Short            |                                         | I SE     | I SE I         |
| <br>  Shift Left Arithmetic         | SLA                                     | RI1      | RI             |
| Shift Left Halfword                 | i                                       | Ì        | 1              |
| Arithmetic                          | I SLHA                                  | IRT1     | I RT           |
| Shift Left Halfword                 | 1                                       | 1        | 1              |
|                                     |                                         |          |                |
| Shift Toft Togigal                  |                                         |          |                |
| Shift Left Logical                  | I PTT                                   | I KTI    | R I            |
| Shirt Lert Hairword                 | 1                                       |          |                |
| Logical Short                       | STHTZ                                   | SF       | RI             |
| Shift Left Logical                  | 1                                       | 1        | 1              |
| Short                               | SLLS                                    | SF       | SF             |
| Store PSW                           | SPSW                                    | 1        | RR**           |
|                                     |                                         |          | 1              |
| Subtract Register                   | SR                                      | RR       | RR*            |
| Shift Right Arithmetic              | SRA                                     | RI1      | RI             |
| Shift Right Halfword                | 1                                       |          | 1              |
| Arithmetic                          | SRHA                                    | RI1      | RI             |
| Shift Right Halfword                | 1                                       | 1        | 1              |
| Logical                             | SRHL                                    | I RI1    | RI             |
| Shift Right Logical                 | SRL                                     | RI1      | RI             |
|                                     | 1                                       | 1        | 1              |
| Shift Right Halfword                | 1                                       | t        | l ·            |
| Logical Short                       | SRHLS                                   | SF       | SF             |
| Shift Right Logical                 | 1                                       | 1        | 1              |
| Short                               | SRLS                                    | SF       | SF             |
| Sense Status                        | I SS                                    | RX       | RX             |
| Sense Status Register               | ISSR                                    | I RR     | RR             |
| Store                               | IST                                     | RX       | RX*            |
|                                     |                                         | 1        |                |
| Store Byte                          | I STB                                   | RX       | I RY           |
| Store Byte High Sneed               |                                         |          |                |
| Store Byte Register                 | ממתיכ ו<br>ממשיט ו                      | י<br>קקן |                |
| Store Dyre Reyrster                 | NDIG                                    |          |                |
| Store ht troating                   |                                         |          |                |
| POINT<br>Chama Plantic D int        |                                         | I KX     | R X            |
| Store Floating Point                | STE                                     | I KX     | I KX           |
| <br>  Store Halfword                | ן<br>ר כידו                             |          | οv             |
| Store Multiple                      |                                         |          | I DV           |
| Crows Whittels DD<br>Prote Unitible |                                         |          | A A            |
| Disting Dist                        |                                         |          |                |
| rioating Point                      | STMD                                    | I KX     | КХ             |
| Store Multiple Floating             |                                         |          |                |
| Point                               | STME                                    | RX       | RX             |
| Supervisor Call                     | SVC                                     | RX       | RX             |
|                                     |                                         |          |                |

i de la compañía de la

| INSTRUCTION                                                                                         | MNEMONIC                        | 32-BIT  <br>FORMAT                   | 16-BIT  <br>FORMAT           |
|-----------------------------------------------------------------------------------------------------|---------------------------------|--------------------------------------|------------------------------|
| Test Bit<br>Test Halfword Immediate<br>Test Immediate<br>Translate<br>Test and Set                  | TBT<br>THI<br>TI<br>TLATE<br>TS | RX  <br>RI1  <br>RI2  <br>RX  <br>RX | RI<br>RI*<br>RX**            |
| Unchain<br>Write Block<br>Write Block Register<br>Write Data<br>Write DCS                           | UNC<br>WB<br>WPR<br>WD<br>WDCS  | RX<br>RR<br>RX<br>RR                 | RR**<br>RX<br>RR<br>RX<br>RR |
| Write Data Register<br>Write Data High Speed<br>Write Data High Speed<br>Register<br>Write Halfword | WDR<br>WDHS<br>WDRHS<br>WH      | RR<br>RX                             | RR<br>RX**<br>RR**<br>RX     |
| Write Halfword Register<br>Write Processed Data<br>High Speed<br>Exclusive OR                       | WHR<br>WPDHS<br>X               | RR<br>RX                             | RR<br>RX**<br>RX*            |
| Exclusive OR Halfword<br>Exclusive OR Halfword<br>Immediate<br>Exclusive OR Halfword<br>Register    | XH<br>XHI<br>XHR                | RX<br>RI1<br>RR*                     | RX<br>RI<br>RR               |
| Exclusive OR to Memory<br>Exclusive OR Immediate<br>Exclusive OR Register                           | XHM<br>XI<br>XR                 | RI2<br>RR                            | RX**<br>RI*<br>RR*           |

- \* The indicated mnemonic operation code is generated, and the listing is flagged with a question mark to indicate a potential error.
- **\*\*** Model 50 instruction set

j it i de 🐨 au

.

Table 3-2 lists the mnemonics for machine formats extended for the Perkin-Elmer Model 3220 Processors. The 16-bit format is not applicable.

> TABLE 3-2 SUMMARY OF MACHINE INSTRUCTIONS AND MNEMONICS EXTENDED FOR THE PERKIN-ELMER 3200 SERIES PROCESSORS

| *************************************** |                                          |         |
|-----------------------------------------|------------------------------------------|---------|
| 1 1                                     |                                          | 32-BIT  |
|                                         | MNEMONTC I                               | FORMAT  |
|                                         |                                          | ======= |
|                                         | ם אמם                                    |         |
| Dreakpoint                              |                                          |         |
| [ Compare alphanumeric (RU=pad) [       | CPAN I                                   | KYKY    |
| Compare alphanumeric and                |                                          |         |
| default pad                             | CPANP                                    | RXRX    |
| Load interruptible state                | ISRST                                    | RX      |
| Save interruptible state                | ISSV                                     | RX      |
| 1                                       | 1                                        |         |
| Load complement SP register             | LCER                                     | RR      |
| Load complement DP register             | I.CDR                                    | RR      |
| Load DP register from SP memory         | TDE                                      | RY      |
| Load DD register from SD register       | ם בים בים בים בים בים בים בים בים בים בי | סס      |
| Load DP register from sr register       | LDER                                     | ΓΠ      |
| LOAU DY REGISTER IRCM GENERAL           | TDOD                                     |         |
| register pair                           | LDGR                                     | RR      |
|                                         |                                          |         |
| Load process state                      | LDPS                                     | RX      |
| Load SP register frcm DP memory         | LED                                      | RX      |
| Load SP register frcm DP register       | LEDR                                     | RR      |
| Load SF register frcm general           |                                          |         |
| register                                | LEGR                                     | RR      |
| Load general register pair              | ł                                        |         |
| from DP register                        | LGDR I                                   | RR      |
|                                         |                                          |         |
| I load general register                 |                                          |         |
| from SD register                        |                                          | ן מס    |
| I lood marked dening atming             | LGEU (                                   | ЛЛ      |
| Load packed decimal string              | TDD                                      | Ъ¥      |
| as binary                               | TAR 1                                    | KX      |
| Load positive DP register               | LPDR                                     | RR      |
| Load positive SP register               | LPER                                     | RR      |
| Load process segment table              | {                                        |         |
| descriptor                              | LPSTD                                    | RX      |
|                                         | 1                                        | 1       |
| Load system segment table               |                                          |         |
| descriptor                              | LSSTD I                                  | RX      |
| Move and pad (RO=pad)                   | MOVE                                     | RXRX    |
| I Move and nad default rad              | MOVED                                    | RXRY    |
| I Move translated until                 | אעידים א                                 | DYDY    |
| I Dack and move (Intit )                |                                          | DVDV    |
| Pack and move                           |                                          |         |
| Pack and move absolute                  | PAVA DE                                  | K X K X |
| Read error logger                       | RET                                      | RX1 *** |
| Reset memory voltage failure            | RMVF                                     | RX1 *** |
|                                         |                                          |         |

a and a second sec

1

1

TABLE 3-2 SUMMARY OF MACHINE INSTRUCTIONS AND MNEMONICS EXTENDED FOR THE PERKIN-ELMER 3200 SERIES PROCESSORS (Continued)

|                                                                      | MNEMONIC     | 32-BIT<br>FORMAT |
|----------------------------------------------------------------------|--------------|------------------|
| Store DP register in SP memory  <br>  Store binary as packed decimal | STDE         | RX               |
| string                                                               | STPB         | RX               |
| Store process state                                                  |              |                  |
| Unpack and move absolute<br>Store byte with no ECC                   | UMVA<br>XSTB | RXRX<br>RX       |

\*\*\* No register or other operands allowed in source format

In addition to the set of mnemonics listed in Tables 3-1 and 3-2, CAL/32 recognizes a complete set of extended branch mnemonics. These instructions allow the programmer to call for conditional branch instructions without having to state explicitly the condition code mask. Table 3-3 lists these instructions.

# TABLE 3-3 EXTENDED BRANCH MNEMONICS

|   |          |      | ~                                       |               |
|---|----------|------|-----------------------------------------|---------------|
| I |          | IN   | STRUCTION                               | MNEMONIC      |
|   | ======== | :=== | ======================================= | ============= |
| I | Branch   | on   | carry                                   | BC            |
|   | Branch   | on   | carry register                          | BCR           |
|   | Branch   | on   | carry short                             | BCS           |
| 1 | Branch   | 0.0  | DO CAFEY                                |               |
| 1 | Dranen   | on   | no carry                                |               |
|   | Branch   | on   | no carry register                       | BNCR          |
| 1 | Branch   | on   | no carry short                          | BNCS          |
| 1 |          |      |                                         |               |
|   | Branch   | on   | egual                                   | BE            |
| 1 | Branch   | on   | equal register                          | BER           |
|   | Branch   | on   | equal short                             | BES           |
| 1 |          |      |                                         |               |
|   | Branch   | on   | not equal                               | BNE           |
| I | Branch   | on   | not equal register                      | BNER          |
|   | Branch   | on   | not egual short                         | BNES          |
|   | Branch   | on   | low                                     | BL            |
| i | Branch   | on   | low register                            | BLR           |
|   | Branch   | on   | low short                               | BLS           |

# TABLE 3-3 EXTENDED BRANCH MNEMONICS (Continued)

|              | INSTRUCTION             | MNEMONIC                              |
|--------------|-------------------------|---------------------------------------|
| Branch       | on not low              | BNL                                   |
| Branch       | on not low register     | BNLR                                  |
| Branch       | on not low short        | BNLS                                  |
| Branch       | on minus                |                                       |
| Branch       | on minus register       |                                       |
| Branch       | on minus short          |                                       |
| Dranen       | on winds shore          |                                       |
| Branch       | on not minus            | BNM                                   |
| Branch       | on not minus register   | BNMR                                  |
| Branch       | on not minus short      | BNMS                                  |
| D            |                         |                                       |
| Branch       | on plus                 |                                       |
| Branch       | on plus register        | B B B B B B B B B B B B B B B B B B B |
| Branch       | on plus snort           | BR2                                   |
| Branch       | on not plus             | BNP                                   |
| Branch       | on not plus register    | BNPR                                  |
| Branch       | on not plus short       | BNPS                                  |
| Branch       | on overflow             | во                                    |
| Branch       | on overflcw register    | BOR                                   |
| Branch       | on overflcw short       | BOS                                   |
|              |                         |                                       |
| Branch       | on no overflow          | BNO                                   |
| Branch       | on no overflow register | BNOR                                  |
| Branch       | on no overflow short    | BNOS                                  |
| l<br>Branch  | on zero                 |                                       |
| Branch       | on zero register        | BZR                                   |
| Branch       | on zero short           | BZS                                   |
|              | -                       | i i                                   |
| Branch       | on not zero             | BNZ                                   |
| Branch       | on not zero register    | BNZR                                  |
| Branch       | on not zero short       | BNZS                                  |
| <br>  Branch | unconditional           |                                       |
|              | unconditional register  |                                       |
| Branch       | unconditional short     | BS I                                  |
|              |                         |                                       |
| No opei      | ation                   | NOP                                   |
| No oper      | ration register         | NOPR                                  |
|              |                         |                                       |

The extended branch instructions are essentially single operand instructions where the first operand mask value is included in the operation mnemonic. The programmer supplies only the second

.

operand or branch location. For short branches, the programmer does not have to specify the forward or backward direction. CAL/32 determines the direction of the branch and generates the appropriate machine code. For example:

| Т      |
|--------|
|        |
|        |
| NT PTR |
|        |
| TABLE  |
|        |
|        |

In this program, CAL/32 determines the locations of LOOP1 and END and generates the required forward and backward branch instructions.

Two more CAL/32 instructions that do not have direct machine equivalents are:

# INSTRUCTION MNEMONIC

Branch on true condition short BTCS Branch on false condition short BFCS

With these instructions, the programmer must specify the mask value and the branch location. CAL/32 determines the direction, forward or backward, and the appropriate machine operation is generated.

# **3.8** ASSEMBLER INSTRUCTIONS

Assembler instructions control the assembly process. Although they may resemble machine instructions in form, they do not generate any machine executable code. They are used to define symbols, reserve storage, generate data constants, and control the final output.

# 3.8.1 Symbol Definition Instructions

Symbol definition instructions allow the programmer to assign values to symbols and set up communication paths between separately assembled programs. The latter operation facilitates the use of subroutines because they can be written and assembled separately from the main program. At load time, a linking loader uses information supplied by CAL/32 to resolve addresses between main programs and subroutines to set up the correct linkage. 3.8.1.1 Equate (EQU) Instruction

This is one of the most commonly used assembler instructions. It assigns values to symbols and it has the form:

| NAME | OPERATION | OPERAND |
|------|-----------|---------|
|      |           |         |

A symbolic name EQU An expression

Examples of EQU instructions are:

| LOOP  | EQU | LCOP1      |
|-------|-----|------------|
| TOP   | EQU | END-64     |
| DELTA | EQU | BOTTOM-TOP |
| HERE  | EQU | *          |
| START | EQU | X " 10FE " |
| SUM   | EQU | 1          |
| PTR   | FQU | 2          |
|       |     |            |

EQU instructions can appear anywhere in the program. CAL/32 requires that each EQU instruction have a symbol in the name field and treats the absence of this symbol there as an error. The value assigned to a symbol by an EQU instruction is absolute or relocatable, depending on the type of expression in the operand field. If the cperand of an EQU statement contains a forward reference, CAL/32 will perform any additional passes required to define all symbols. CAL/32 does not reserve storage for symbols defined by an EQU instruction. Wherever it encounters the symbol in the program, CAL/32 replaces the symbol with the value defined in the EQU instruction. For example:

| STRNG | EQU | 1                |                        |
|-------|-----|------------------|------------------------|
| PTR   | EQU | 2                |                        |
| INPUT | EQU | 3                |                        |
|       | •   |                  |                        |
|       | •   |                  |                        |
|       | •   |                  |                        |
| LOOP1 | L   | STRNG,TABLE(PTR) | LOAD STRING FROM TABLE |
|       | CLR | STRNG, INPUT     | COMPARE WITH INPUT     |

In this case, CAL/32 generates the code to load register 1 with four bytes located at the address specified by TABLE, indexed by register 2. The next instruction causes CAL/32 to generate the code to compare the four bytes in register 1 with the contents of register 3. The use of the EQU instruction here allows the programmer to assign meaningful names to the registers that hold the character strings, and index into the table. It also

1

provides a simple way to redefine the values assigned to these symbols. By changing the EQU instructions and reassembling, it is possible to change the values assigned to the symbols without doing extensive editing to change each individual statement where these registers are used.

It is also possible, although not recommended, to redefine a symbol within a program. For example:

LOOP1 EQU \* LOOP1 EQU \*

When the symbol LOOP1 is encountered in the first EQU instruction, CAL/32 assigns it the value of the current location counter. Subsequent references to LOOP1 receive this value. Following the second EQU instruction, the value of LOOP1 is changed to the value of the new location counter. Because such redefinitions might not be intentional, CAL/32 issues a warning message wherever a symbol is redefined by an EQU instruction. (In the example, the programmer might have intended to write LOOP2 instead of LOOP1 in the second EQU instruction.)

The user must guard against circular location counter dependency, as shown in the following example:

| A | EQU | *     |
|---|-----|-------|
|   | DS  | 1     |
|   | DS  | B – A |
| В | EQU | *     |
|   | END |       |

CAL/32 will flag an "MOO1 xxxTOP" error where xxx is PURE, IMP, or ABS, depending upon the current location counter.

As stated earlier, CAL/32 permits the user to define operation mnemonics within the program. To do this, the user defines the new mnemonic in an EQU instruction in which the new operation mnemonic is in the name field, and the operand field contains a hexadecimal constant of the form X'nnxy'. Here, nn is the machine language operation code, and x and y are descriptors that tell CAL/32 how to handle the new mnemonic. The values of x and y inform CAL/32 of the instruction format. The values are defined as follows:

48-050 FOO ROO

I

To define extended branch mnemonics, x gets a value equal to the .R1 field (mask) and y gets one of the following values:

| У | = | 3 | RX | format |
|---|---|---|----|--------|
| У | = | С | RR | format |
| у | = | D | SF | format |

For example, in the instruction:

BTC 15, ADDR

the branch on true condition mnemonic and the mask field 15 can be combined into an extended branch instruction as follows:

BTCF EQU X 42F3\*

in which BTCF is the new mnemonic; 42 is the machine code for the branch on true condition instruction; F is the mask value (15); and 3 specifies RX format. Once this new mnemonic is defined, the programmer can write:

BTCF ADDR

instead of:

BTC 15, ADDR

The new mnemonic definition remains in effect only for the program in which it is defined. The new mnemonic must be different frcm all other mnemonics recognized by CAL/32.

There are three things to remember in using equate statements:

- 1. The name field must always contain a valid symbol.
- 2. The operand field must always contain a defined symbol or expression.
- 3. The symbol that appears in the name field of an equate instruction must not appear in the name field of any other instruction, except another equate instruction.

If any of these rules are violated, CAL/32 generates an appropriate error message.

# 3.8.1.2 External, Entry, Weak External, Weak Entry, and Data Entry (EXTRN, ENTRY, WXTRN, WNTRY, and DNTRY) Instructions

These instructions are listed together since they perform corresponding functions to establish links between main programs and subroutines, and between programs with a common data base. These instruction forms are:

| Not used  | EXTRN | Cne or more symbols |
|-----------|-------|---------------------|
| (illegal) |       | separated by commas |
| Not used  | ENTRY | Cne or more symbols |
| (illegal) |       | separated by commas |
| Not used  | WXTRN | One or more symbols |
| (illegal) |       | separated by commas |
| Not used  | WNTRY | Cne or more symbols |
| (illegal) |       | separated by commas |
| Not used  | DNTRY | Cne or more symbols |
| (illegal) |       | separated by commas |

The EXTRN instruction identifies symbols referenced by the program but defined outside the program. The ENTRY instruction identifies symbols defined within the program and referenced externally. (They can be referenced internally as well.)

For example, consider two programs: one calculates the sine and cosine of an angle, the other uses the sine and cosine. The first is a general purpose program that could be used by many other programs. The ENTRY and EXTRN instructions make this possible without having to assemble the sine and cosine program every time it is needed. The sine and cosine program would contain an ENTRY instruction and entry points such as:

|     | ENTRY | SIN,COS |
|-----|-------|---------|
|     | •     |         |
|     | •     |         |
|     | •     |         |
| SIN | EQU   | *       |
|     | •     |         |
|     | •     |         |
|     | •     |         |
| COS | EQU   | *       |
|     | •     |         |
|     | •     |         |
|     | •     |         |

The symbols SIN and COS appear as operands in the ENTRY instruction and as names in the EQU instructions. When CAL/32 assembles this program, CAL/32 informs the linking loader that the locations identified by the names SIN and COS are entry points into the program.

48-050 F00 R00

The program that uses sine and cosine would contain an external statement and branch instructions such as:

> EXTRN SIN, COS ٠ ٠ • BAL LINK, SIN • • BAL LINK, COS ٠ •

| At assembly time, CAL/32 generates object data to inform the linkage editor that the symbols SIN and COS are externally defined. At link time, the linkage editor uses this information, along with the information generated by the entry instruction in the other program, to provide the necessary linkage.

The WXTRN instruction is essentially equivalent to the EXTRN instruction. However WXTRN symbols are subject to the following exception processing by Link:

- An error condition does not arise if the symbol is not resolved.
- Object libraries are not searched in order to satisfy a weak external.
- If a module containing an entry point referenced by a WXTRN symbol is included, then the entry point will be used to satisfy WXTRN references to it in the normal fashion.

The WNTRY instruction is essentially equivalent to the ENTRY instruction. However, WNTRY symbols are subject to the following exception processing by Link.

- Weak entry points are not examined when searching an object library. Therefore, a program module containing a weak entry point is not included to satisfy an external reference.
- If a program module containing a weak entry point is included from a module, the weak entry point will be used to satisfy external references in the normal fashion.

1

The DNTRY instruction is essentially equivalent to the ENTRY instruction. However, symbols nominated by DNTRY are resolved directly when building overlaid modules rather than resolved in an SVC instruction. This instruction identifies a symbol defined local to the program containing the DNTRY instruction.

To help protect references to data in higher level nodes, Link automatically loads the entire path of overlays starting at the overlay containing data and ending with the overlay making the reference to a data entry point (DNTRY). A reference to a program section positioned in a higher level node, via the POSITION command, is treated the same way. A reference to data or a program section in the root will not cause a path of overlays to be loaded.

If a DNTRY is referenced in a lower level node, an SVC 5 manual overlay load might be required to ensure that the overlay is in memory at the time of the reference.

Restrictions on the use of external and entry instructions are:

- The operand field of an external instruction must not contain an expression, such as SIN+4.
- Expressions involving externally defined symbols must be of the form:
  - External symbol + absolute expression
  - External symbol absolute expression

BAL LINK, SIN+4

is a legal use of an externally defined symbol.

- Externally defined symbols cannot be used internally as instruction identifiers.
- Any symbol identified as an entry must appear internally in the name of an instruction.
- Symbols identified as entries cannot be redefined by multiple equate instructions.

# 3.8.1.3 Include (INCLD) Instruction

This information provides Link with a mechanism to guarantee the inclusion of object modules without other linkage references to it. It has the form:

L

1

1

1

1

| NAME                  | OPERATION | CPERAND                                          |
|-----------------------|-----------|--------------------------------------------------|
| Not used<br>(illegal) | INCLD     | One or more<br>symbols<br>separated by<br>commas |

The INCLD is used in the same fashion as the EXTRN to linking references. However, this instruction is used to nominate program modules rather than external symbols.

# NOTE

CAL/32 will generate the same object as in the past, provided none of the following instructions are used: external with offset, DCMD, DNTRY, WNTRY, WXTRN, or INCLD. The assembly of any of these instructions will produce an object that TET will reject. Link is required to process modules containing this extended object. These instructions are only valid in a Target 32 assembly and have no effect on 16-bit object generation.

# 3.8.2 Data Definition Instructions

These instructions allow the programmer to reserve areas of memory to be used at run time. Some of these instructions allow the programmer to specify values with which these areas can be initialized at load time. Other data definition instructions provide easy access to complex data structures.

#### 3.8.2.1 Define Storage (DS, DSH, DSF) Instruction

This instruction causes CAL/32 to reserve a block of storage within the program without initializing the reserved locations to any value. It has the form:

| NAME       | OPERATION | OPERAND     |
|------------|-----------|-------------|
| A symbol   | DS        | An absolute |
| (optional) |           | expression  |
| A symbol   | DSH       | An absolute |
| (optional) |           | expression  |
| A symbol   | DSF       | An absolute |
| (optional) |           | expression  |

The DS mnemonic causes CAL/32 to reserve the specified block of storage starting from the value of the current location counter. In the DSH form, CAL/32 first aligns the location counter on a

L

L

halfword boundary and then reserves the storage. In the DSF form, CAL/32 first aligns the location counter on a fullword boundary. Examples of the define storage instruction are:

| BUF1 | DS  | 100 |
|------|-----|-----|
| BUF2 | DSH | 125 |
| BUF3 | DSF | 16  |

In the first example, CAL/32 reserves 100 bytes of storage by simply adding 100 to the location counter. In the second example, CAL/32 reserves 125 halfwords (250 bytes) of storage. CAL/32 does this by aligning the location counter on a halfword boundary, if it is not already properly aligned, and then adding 250 to it. In the third example, CAL/32 ensures that the location counter is aligned on a fullword boundary and then adds 64 (the byte equivalent of 16 fullwords) to it. If the operand contains a forward reference, CAL/32 will perform any additional passes required to define all symbols.

Define storage instructions are commonly used to reserve storage areas for transient data. Examples of this are I/O buffers and register save areas. For example:

|       | ENTRY | RSAVE    |
|-------|-------|----------|
|       | EXTRN | SIN,CCS  |
| LINK  | EQU   | 15       |
|       | •     |          |
|       | •     |          |
| ,     | •     |          |
| RSAVE | DSF   | 16       |
|       | •     |          |
|       | •     |          |
|       | •     |          |
|       | BAL   | LINK,SIN |
|       | •     |          |
|       | •     |          |
|       | •     |          |

shows how a main program might set up a register save area within itself. The code for the called program might look like:

|     | ENTRY | SIN,CCS   |
|-----|-------|-----------|
|     | EXTRN | RSAVE     |
| RO  | EQU   | 0         |
|     | •     |           |
|     | •     |           |
|     | •     |           |
| SIN | EQU   | *         |
|     | STM   | RO, RSAVE |
|     | •     |           |
|     | •     |           |
|     | •     |           |
|     |       |           |

1

1

where the subroutine stores the general registers in the externally defined area, RSAVE. When using define storage instructions remember that:

- The DSH and DSF forms cf the instruction ensure halfword and fullword alignment.
- The define storage instructions do not initialize memory to any particular value.
- Cnly one operand is allowed in a define storage instruction, and it must be a defined, absolute symbol or expression.

3.8.2.2 Define Constant (DC, DCF) Instruction

The define constant instruction allows the programmer to reserve areas of memory and at the same time specify the initial value to be loaded into them. The define constant instruction has two forms:

| NAME       | OPERATION | OPERAND              |  |  |
|------------|-----------|----------------------|--|--|
| A symbol   | DC        | One or more operands |  |  |
| (optional) |           | separated by commas  |  |  |
| A symbol   | DCF       | One or more operands |  |  |
| (optional) |           | separated by commas  |  |  |

The DC mnemonic ensures that the first of the operands is aligned on a halfword boundary. The DCF mnemonic ensures that the first of the operands is aligned on a fullword boundary. Operands of different types can be used in the same define constant instruction. However, where alignment is a concern, the programmer must be careful in mixing operands of different types. Types of operands are described below.

A single character code indicates the type of constant. This character code is not always required, and the exceptions are noted as they occur. The assembler determines from the character code how it is to interpret the constant and translate it into the proper object format. Table 3-4 lists the character codes recognized by CAL/32, their meanings, and the types of constants generated.

| CODE                 | MEANING                              | MACHINE FORMAT                                                                                                                              |
|----------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| X<br>Y               | Hexadecimal<br>Hexadecimal           | 16-bit binary<br>32-bit binary                                                                                                              |
| H<br>F               | Integer<br>Integer                   | 16-bit signed binary<br>32-bit signed binary                                                                                                |
|                      | Address<br>Address                   | 32-Dit value of address  <br>  16-bit value of address  <br>  Ope balf of 16-bit address                                                    |
|                      | Single precision<br>  floating point | 32-bit floating point  <br>format                                                                                                           |
| D                    | Double precision<br>floating point   | 64-bit floating point<br>format                                                                                                             |
| C                    | Character<br>                        | An 8-bit code per<br>character (7-bit ASCII)                                                                                                |
| P                    | Packed decimal<br>  string<br> <br>  | Fixed point sign-coded<br>integer of binary en-<br>coded 4-bit decimal<br>digits in a string of<br>variable byte length.                    |
| U<br> <br> <br> <br> | Unpacked decimal<br>string           | Fixed point sign-coded<br>integer of 7-bit ASCII<br>encoded decimal digits<br>(8-bits per digit) in a<br>string of variable byte<br>length. |

#### 3.8.2.3 Hexadecimal Constants

A hexadecimal constant consists of one or more hexadecimal digits, 0 through 9 and A through F, enclosed in apostrophes and preceded by the type code X or Y. Where the X type is used, CAL/32 reserves two bytes of storage and generates the loader information that will cause those two bytes to be initialized at load time with the binary representation of the hexadecimal number. The Y type causes four bytes to be reserved and initialized. Examples of hexadecimal constants are:

| CON | STANT      | VALUE   |      |
|-----|------------|---------|------|
| DC  | X'1234'    | 1234    |      |
| DC  | ¥ * 1234 * | 0000    | 1234 |
| DCF | X•20•      | 0020    |      |
| DCF | Y•0064•    | 0000    | 0064 |
| DC  | X'1234ABC' | 4 A B C |      |

.

48-050 FOO ROO

The first example shows a halfword hexadecimal constant which, because of the DC operation code, is aligned on a halfword boundary. The second example shows a fullword hexadecimal constant. In this case, fullword alignment is not guaranteed. The third example shows a halfword constant aligned on a fullword boundary. The fourth example shows how to force fullword alignment for a fullword constant. The last example shows what happens when too many digits are given. CAL/32 truncates the constant to the least significant digits and generates an error message. The maximum number of digits for an X type constant is four. The maximum number for a Y type constant is eight.

#### NOTE

Where fewer than the maximum number of digits are given, CAL/32 right justifies the value in the location and fills in the missing digits with zeros.

Two special mnemonics facilitate the building of hexadecimal tables by eliminating the need to specify the X or Y type code. They have the form:

| NAME       | OPERATION | OP ER AN D           |  |
|------------|-----------|----------------------|--|
| A symbol   | DCX       | One or more operands |  |
| (optional) |           | separated by commas  |  |
| A symbol   | DCY       | One or more operands |  |
| (optional) |           | separated by commas  |  |

Operands for these instructions consist of from one to four hexadecimal digits for the DCX instruction and from one to eight hexadecimal digits for the DCY instruction. Examples of these constants are:

| DCX | 1, | Ο, | 14 | ΑE, | 20  | ,4 | 040 |     |
|-----|----|----|----|-----|-----|----|-----|-----|
| DCY | 1, | 2F | FF | Ε,θ | 54, | 80 | 000 | 000 |

The DCX instruction generates five halfword constants as follows:

The DCY instruction generates four fullword constants as follows:

0000 0001 0002 FFFE 0000 0064 8000 0000

Before generating the constants, CAL/32 ensures that they are properly aligned with halfword constants aligned on halfword boundaries and fullword constants aligned on fullword boundaries.

# 3.8.2.4 Integer Constants

Integer constants can be either halfword or fullword. Halfword constants are expressed by the character code H followed by a string of from 1 to 5 decimal digits enclosed in apostrophes. Fullword constants are expressed by the character code F followed by a string of from 1 to 10 decimal digits enclosed in apostrophes. The range of halfword constants is from -32,768 to +32,767. The range of fullword constants is from -2,147,483,648 to +2,147,483,647. The decimal strings used in these constants must not include commas or blanks. A sign, + or -, can precede the string.

The internal representation of integer constants is two's complement binary. In this notation, positive numbers and zero have their true binary form. For example, a halfword integer with a value of 25 is represented internally (hexadecimal notation) as:

00

Negative numbers are expressed in accordance with the formula:

Value = 2 - x

where n is the number of bits used to express the value, and x is the absolute value of the number. For example, to represent minus 10 in a halfword constant:

 $n = 16 (10_{16})$   $x = 10 (A_{16})$ Value = 10000<sub>16</sub> - A<sub>16</sub> = FFF6<sub>16</sub>

| CONSTANT |                    | VALUE   |      |  |
|----------|--------------------|---------|------|--|
| DC       | H•32767•           | 7 F F F |      |  |
| DC       | H <b>'-</b> 32768' | 8000    |      |  |
| DC       | F'1'               | 0000    | 0001 |  |
| DC       | H'-2'              | FFFE    |      |  |
| DCF      | F'25'              | 0000    | 0019 |  |

The H and F codes themselves do not guarantee correct alignment. To ensure that a fullword integer is aligned on a fullword boundary, the programmer should use the DCF instruction.

CAL/32 does not require that integer constants be defined with the character codes and decimal strings enclosed in apostrophes. A simple decimal string can be used. For example:

DC 1 DC -7

The length of the integer constants generated by these instructions depends on the processor on which the program is to run. For 32-bit processors such instructions generate fullword constants, such as:

| CONSTANT |  | VALUE     |  |
|----------|--|-----------|--|
|          |  | 0000 0001 |  |

| DC  | 1  | 0000 | 0001 |
|-----|----|------|------|
| DCF | -7 | FFFF | FFF9 |

For 16-bit processors, these instructions generate halfword constants, such as:

| CONSTANT |     | VALUE |  |  |
|----------|-----|-------|--|--|
| DC       | 1   | 0001  |  |  |
| DC       | - 7 | FFF9  |  |  |

It is possible to force a fullword alignment by using the DCF mnemonic with a simple decimal string. The use of a DCF instruction affects only the alignment of the first of the integer constants; the length of the constant is determined solely by the processor on which the program is to be run. Thus, when using these instructions with operands which are simple decimal strings, it is not possible to generate a halfword constant for a 32-bit processor.

# 3.8.2.5 Address Constants

Address constants consist of a single character type code followed by a symbol or an expression enclosed in parentheses. The three types of address constants are A, Z, and T. Type A constants generate fullword address constants in programs intended to be run on 32-bit processors; they generate halfword address constants in programs intended to be run on 16-bit processors. Types Z and T address constants always generate halfword values. Examples of address constants are:

| DC | A(LOOP+2)     |
|----|---------------|
| DC | A(TABLE)      |
| DC | A(TOP-BOTTOM) |
| DC | Z(ICVECTOR)   |
| DC | T(ALPHATAB)   |

For 32-bit processors, the first three examples cause CAL/32 to reserve a fullword of storage, initialized at load time to contain the value of the expression or symbol enclosed in parentheses. This value can be absolute or relocatable, depending on the nature of the expression. The address quantity is right justified in the least-significant 24 bits of the fullword, and the most-significant 8 bits are forced to zero. However, it is possible to use the most-significant bits for some purpose. They might be used as flag bits as in the example:

| FARAM | DS    | 4                     |
|-------|-------|-----------------------|
| ADDR  | DC    | A (PARAM+Y'A0000000') |
|       | EXTRN | SIN                   |
| LINK  | EQU   | 15                    |
| ADREG | EQU   | 14                    |
|       | •     |                       |
|       | •     |                       |
|       | •     |                       |
|       | STE   | RO, PARAM             |
|       | L     | A DR EG, A C DR       |
|       | BAL   | LINK, SIN             |
|       | •     |                       |
|       | •     |                       |
|       | •     |                       |

At the time of the branch and link instruction, register 14 contains the address of the location PARAM in the least-significant 24 bits. The most-significant 8 bits contain the value X'AO'. The subroutine can use the address portion and the flag portion independently, as:

|     | ٠   |                       |               |
|-----|-----|-----------------------|---------------|
|     | •   |                       |               |
| SIN | EQU | * .                   |               |
|     | •   |                       |               |
|     | •   |                       |               |
|     | •   |                       |               |
|     | LE  | R4,O(ADREG)           | GET PARAMETER |
|     | ΤI  | A DR EG,Y ' A0000000' | TEST FLAGS    |
|     | •   |                       |               |
|     | •   |                       |               |
|     | -   |                       |               |

The Z type address constants generate halfword values. They can be used in programs for 32-bit processors if the programmer is certain that the actual address cannot exceed 65,535, the maximum unsigned value that can be expressed in a halfword.

The T type address constants are used as entries in translation tables. These instructions cause CAL/32 to reserve a halfword of storage initialized with one half of the actual address, right justified. The most significant bit is zero. These constants are intended for use with the translation tables associated with the translate instruction and with the auto driver channel.

Address constants can be written without the type code and parentheses, as in:

| TABLE | DS | 16    |         |    |        |     |
|-------|----|-------|---------|----|--------|-----|
| BUFF1 | DS | 64    |         |    |        |     |
|       | •  |       |         |    |        |     |
|       | •  |       |         |    |        |     |
|       | •  |       |         |    |        |     |
| ADD1  | DC | TABLE | ADDRESS | ΟF | TABLE  |     |
| ADD2  | DC | BUFF1 | ADDRESS | OF | BUFFER | ONE |
|       | •  |       |         |    |        |     |
| •     | •  |       |         |    |        |     |
|       | •  |       |         |    |        |     |

Where this convention is used, the size of the generated constant depends on the processor for which the program is written. For 32-bit assemblies, CAL/32 generates fullword constants. For 16-bit assemblies, CAL/32 generates halfword constants. The programmer can force halfword constants to be generated by using the mnemonic DCZ, as:

DCZ TABLE, BUFF1

which causes a series of halfword address constants to be generated.

#### 3.8.2.6 Floating Point Constants

The source form for floating point constants consists of a decimal number enclosed in apostrophes and preceded by the letter E for single precision, or the letter D for double precision. The decimal number consists of:

- an optional plus sign or minus sign,
- cne or more decimal digits that may include a decimal point, and
- an optional E character followed by an optional plus sign or minus sign, followed by one or two decimal digits denoting a power of 10.

Single precision floating point constants require a fullword of storage. Double precision floating point constants require a doubleword of storage. Internally, floating point constants are represented in excess 64 notation. In this kind of notation, each floating point number consists of a sign, an exponent, and a fraction. The first bit of the number is the sign bit. If this bit is a 1, the number is negative; if it is a 0, the number is positive. The next 7 bits represent the exponent, expressed in excess 64 notation. This field can contain any value between 0 and 127 inclusive. The remaining bits, 24 for single precision and 56 for double precision, represent the fraction with an implied radix point before the first bit.

The true value of the floating point number is obtained by multiplying the fraction by 16 raised to the power indicated by the exponent field. In excess 64 notation, this power is determined by subtracting 64 from the value in the exponent field. In this way, values equal to or greater than 64 produce a 0 or positive power. Raising 16 to this power and then multiplying by the fraction produces values between .0625 and 7.5 x 10. Exponent field values that are less than 64 produce a negative power and values between .06249... and 5.4 x 10-. Floating point 0 is represented by a fullword or a double word of zercs.

Examples of floating point constants are:

#### CONSTANT

INTERNAL REPRESENTATION

| DC | E • 1 •     | 4110           | 0000 |      |      |
|----|-------------|----------------|------|------|------|
| DC | E • 0 • 0 • | 0000           | 0000 |      |      |
| DC | E'7.2E74'   | 7F19           | 7817 |      |      |
| ÐC | D'10.5'     | 41A8           | 0000 | 0000 | 0000 |
| DC | D'5.4E-79'  | 0010           | 01D1 | 33A9 | 49F6 |
| DC | D'7.2E+75'  | <b>7</b> F F E | BOE3 | AD97 | 8760 |

48-050 F00 R00

In the internal representation of floating point constants, the fractional part can consist of from 1 to 6 hexadecimal digits for single precision, and up to 14 hexadecimal digits for double precision. If the decimal number exceeds this degree of accuracy, the magnitude of the number is preserved but the precision is lost. In performing the conversion from decimal to internal floating point, CAL/32 carries guard digits to ensure 6 hexadecimal digit accuracy for single precision and 14 hexadecimal digit accuracy for double precision. The programmer must ensure proper alignment.

# 3.8.2.7 Character Constants

Character constants consist of the single letter code C followed by a string of ASCII characters enclosed in apostrophes. All characters are translated into 7-bit ASCII, in which the most significant bit is always 0. Examples of character constants are:

```
DC C'NAME'
DC C'APOSTROPHE = '' '
```

The second example shows how an apostrophe is included in a character constant. Between enclosing apostrophes, a double apostrophe is treated as a single character. The maximum number of characters that can be defined in a single character constant is 64. If the number of characters in a constant is odd, CAL/32 appends a blank character at the end to maintain halfword alignment.

# 3.8.2.8 Decimal String Constants

The source format for decimal string constants consists of a decimal number enclosed in apostrophes and preceded by the letter P for packed decimal string constants, or by the letter U for unpacked decimal string constants. The decimal number is an integer and consists of an optional plus sign or minus sign, followed by 1 to 31 decimal digits.

The machine internal representation of the packed decimal string constant is a fixed-point, sign-coded integer, where each digit occupies 4 bits and each byte holds 2 digits. That is, each decimal digit, 0 through 9, is binary encoded in a 4-bit hexadecimal digit. As the number of decimal digits varies from 1 to 31, the length in bytes of the decimal string varies from 1 to 16 bytes. The last hexadecimal digit contains a 4-bit code for sign; a hexadecimal C for plus, or a hexadecimal D for minus. The integer representation is right-justified within the variable length string, so the least-significant digit of the decimal number occupies the hexadecimal digit just preceding the sign code. Each digit is thus consecutively packed, with the
most-significant digit (zero or nonzero) in bit positions 0 through 3 of the leftmost byte of the string. Refer to the examples that follow for the differences in internal representation, when the packed decimal string constant is defined by either the define constant (DC) instruction or the define byte (DB) instruction.

The machine internal representation of the unpacked decimal string constant is a fixed-point, sign-coded integer, where each zoned digit occupies a byte. That is, each decimal digit, 0 through 9, is encoded in 7-bit ASCII with the leftmost bit 0; providing an 8-bit byte with the left hexadecimal digit containing a zone code of 3 and the right hexadecimal digit containing the binary encoded decimal digit. As the number of decimal digits varies from 1 to 31, the length in bytes of the decimal string varies from 1 to 31 bytes. The integer representation is right-justified within the variable length string. The rightmost byte contains the least significant digit in its rightmost hexadecimal digit and the sign code in its leftmost hexadecimal digit. The sign code is a 4-bit code, described above with a hexadecimal C for plus, and a hexadecimal D for minus. Each digit is thus consecutively coded into bytes, with the most-significant digit (zoned zero or zoned nonzero). Refer to the following examples for the differences in internal representation, when the unpacked decimal string constant is defined by either the DC instruction or the DB instruction.

The address of the string is the address of the leftmost byte containing the most-significant digit (zero or nonzero). The address generated for either the packed decimal string constant or the unpacked decimal string constant is that associated with the label of the source statements and the current location counter. Examples of the PDS constants are:

|     |                                    | IN            | NT ER N I | ۱L    |      |
|-----|------------------------------------|---------------|-----------|-------|------|
|     |                                    | REPRI         | ESENTI    | ATION |      |
| SOU | RCE FORMAT                         | (HEXP         | DECI      | 1AL)  |      |
|     |                                    |               |           |       |      |
| DB  | P'1'                               | 1C            |           |       |      |
| DB  | P*+50*                             | 050C          |           |       |      |
| DB  | P'-879'                            | 879D          |           |       |      |
| DB  | P"+1234"                           | 0123          | 4C        |       |      |
| DB  | P'-12345'                          | 1234          | 5D        |       |      |
| DB  | P'1234567890123456789012345678901' | 1234          | 5678      | 9012  | 3456 |
|     |                                    | 7890          | 1234      | 5678  | 901C |
| DC  | P*1*                               | 001C          |           |       |      |
| DC  | P'+50'                             | 050C          |           |       |      |
| DC  | P'-879'                            | 8 <b>79</b> D |           |       |      |
| DC  | P <b>'+1234'</b>                   | 0001          | 234C      |       |      |
| DC  | P'12345'                           | 0012          | 345C      |       |      |
| DC  | P'1234567890123456789012345678901' | 1234          | 5678      | 9012  | 3456 |
|     |                                    | 7890          | 1234      | 5678  | 901C |

Note that as string-processing instructions are intended to operate at the lowest addressable level, on byte-addressable locations these constants are most efficiently generated by the DB instructions, described in the define byte instruction section. If the DC instruction is used, an extra byte of leading zeros is generated, when the number of digits is a multiple of 4, or is an odd number of digits not divisible by 3. Examples of unpacked decimal string (zoned) constants are:

| SOURCE FORMAT                                                       | IN<br>REPRE<br>(HEXA                 | ITERNI<br>SENTI<br>DECIN     | AL<br>ATION<br>MAL)          |                      |
|---------------------------------------------------------------------|--------------------------------------|------------------------------|------------------------------|----------------------|
| DB U • 1 •<br>DB U • + 50 •<br>DB U • - 879 •                       | C1<br>35C0<br>3837                   | D9                           |                              |                      |
| DB U*+1234*<br>DB U*12345*<br>DB U*1234567890123456789012345678901* | 3132<br>3132<br>3132<br>3132<br>3930 | 33C4<br>3334<br>3334<br>3132 | D5<br>3536<br>3334           | 3738<br>3536         |
| EC U'1'                                                             | 3738<br>3536<br>30C1                 | 3930<br>3738                 | 3132<br>3930                 | 3334<br>C1           |
| LC U'+50'<br>DC U'-879'<br>DC U'+1234'                              | 35C0<br>3038<br>3132                 | 37D9<br>33C4                 |                              |                      |
| DC U'-12345'<br>DC U'1234567890123456789012345678901'               | 3031<br>3031<br>3839<br>3637         | 3233<br>3233<br>3031<br>3839 | 34D5<br>3435<br>3233<br>3031 | 3637<br>3435<br>3233 |
|                                                                     | 3435                                 | 3637                         | 3839                         | 30C1                 |

As string processing instructions require programmed length attributes, familiarization with the internal storage requirements for both packed decimal string and unpacked decimal string constants is advisable. In the previous examples, the relationship of number of digits to byte length is as follows:

| CONSTANT | DEFINED BY | BYTE LENGTH                       |
|----------|------------|-----------------------------------|
| Packed   | DB         | (integer of $n/2$ ) + 1           |
| Packed   | DC         | 2*(integer of n/4) + 2            |
| Unpacked | DB         | n                                 |
| Unpacked | DС         | n, for n even<br>n + 1, for n odd |

where n is the number of decimal digits in the source formats of the decimal constants.

#### 3.8.3 Define Byte (DB) Instruction

This instruction defines consecutive 8-bit bytes of data. It has the form:

| NAME                   | OPERATION | OPERAND                                     |
|------------------------|-----------|---------------------------------------------|
| A symbol<br>(optional) | DB        | One or more operands<br>separated by commas |

The symbol used in the name field of the DB instruction is assigned the value of the current location counter. There is no automatic alignment. The programmer must ensure proper alignment where the symbolic name of a DB instruction is used as an operand identifier in an instruction requiring its operand to be located on a halfword, fullword, cr double word boundary.

The operand field can contain one or more operands, separated by commas. There can be an even or an odd number of operands. The operands can be any symbol or expression value. For any operand, other than character or decimal string expressions, the least significant eight bits of the operand value are used to generate one byte of data. Examples of the DB instructions are:

DB X • F 7 • 128 DB DB - 1 C'A' DB C'ABCDEFG' DB

As shown in the examples, the operand of a DB instruction can be a signed integer. In this case, the integer can have any value between -128 and +127, inclusive.

A special form of the DB instruction:

DB \*

forces alignment of the location counter to a halfword boundary. If, when this instruction is encountered, the location counter contains an odd value, one byte of zero value is generated, and the location counter is made even. If the location counter is already even, this instruction has no effect.

### 3.8.4 Define List (DLIST) Instruction

This instruction provides a simple means for defining circular lists used by the machine instructions:

- Add to top of list
- Add to bottom of list
- Remove from top of list
- Remove from bottom of list

The define list instruction has the form:

| NAME       | OPERATION | OPERAND     |
|------------|-----------|-------------|
| A symbol   | DLIST     | An absolute |
| (optional) |           | expression  |

The absolute expression in the operand field specifies the number of slots in the list. For 32-bit assemblies, CAL/32 reserves four halfwords of storage for list pointers, followed by the specified number of fullwords (slots). The first halfword list pointer is initialized with a value equal to the number of slots in the list. The remaining three pointers are initialized to zero. For 16-bit assemblies, CAL/32 reserves four bytes of storage for list pointers, followed by the specified number of halfwords. The first byte pointer is initialized to a value equal to the number of slots in the list. The remaining byte pointers are initialized to zero. An example of the DLIST instruction is:

LIST1 DLIST 100

In a 32-bit assembly, this has the same effect as:

LIST1 DCF X'64',X'0',X'0',X'0' DS 400

The DLIST instruction forces alignment to a fullword boundary in 32-bit assemblies. It forces alignment to a halfword boundary for 16-bit assemblies.

#### 3.8.5 Define Command (DCMD) Instruction

This instruction causes the string within the set of apostrophes to be passed directly to the object code.

| NAME       | OPERATICN | OPERAND    |
|------------|-----------|------------|
| A symbol   | DCMD      | C 'command |
| (optional) |           | string*    |

The operand of the DCMD instruction is subject to the same syntactic rules as any other character string. CAL/32 performs no syntax checking on the command string.

CAL/32 will generate the same object as in the past, provided the DCMD instruction is not used. The assembly of this instruction will produce an object that TET will reject. Link is required to process modules containing this extended object. The DCMD instruction is valid only in a Target 32 assembly and has no effect on the 16-bit object generation.

## 3.8.6 Location Counter Instructions

These instructions allow the programmer to select the current location counter and set its value. For 32-bit assemblies, CAL/32 maintains three location counters: pure, impure, and absolute. For 16-bit assemblies, it maintains two location counters: relocatable and absolute. At any given time, only one location counter can be in use. With these instructions, the programmer can control the program segmentation and relocation.

### 3.8.6.1 Pure (PURE) Instruction

This instruction causes all subsequent machine instructions to be assembled as part of the pure segment. It has the form:

| NAME CPECALLON OPENAL | NAME | OPERATION | OPERAND |
|-----------------------|------|-----------|---------|
|-----------------------|------|-----------|---------|

| A symbol   | PURE | None      |
|------------|------|-----------|
| (optional) |      | (ignored) |

The current location counter is saved, and the new location counter is set to point to the next halfword boundary beyond the most recently used location in the pure segment. If a PURE instruction occurs in a relocatable 16-bit program, it has no effect. If it occurs in an absolute 16-bit program, it causes a switch to the relocatable location counter.

# 3.8.6.2 Impure (IMPUR) Instruction

This instruction causes all subsequent instructions to be assembled as part of the impure segment. It has the form:

| NAME      | OPERATION | OPERAND   |
|-----------|-----------|-----------|
| A symbol  | IMPUR     | None      |
| (optional | )         | (ignored) |

The current location counter is saved, and the new halfword boundary is set beyond the most recently used impure address. In 16-bit assemblies, this instruction has no effect if the program is already in relocatable mode. If it is in absolute mode, the location counter is switched to relocatable.

## NOTE

Unless otherwise specified by the programmer, impure mode is assumed.

## 3.8.6.3 Origin (ORG) Instruction

This instruction selects a location counter and sets it to a defined value. It has the form:

| NAME       | OPERATION | OPERAND     |
|------------|-----------|-------------|
| A symbol   | ORG       | A symbol or |
| (optional) |           | expression  |

The operand of the origin instruction determines which location counter is selected and the value it is given. If the value of the operand is pure, impure, absolute, or relocatable, the corresponding location counter is selected and set to the operand value. If the operand contains a forward reference, CAL/32 will perform any additional passes required to define all symbols.

The user must guard against circular location counter dependency, as in the following example:

| 1 |   | ORG | A   |
|---|---|-----|-----|
| i |   | LIS | 4,4 |
| Ì | A | EQU | В   |
| Ì |   | LIS | 4,4 |
| 1 | В | EQU | *   |
| i |   | END |     |

L

CAL/32 will flag an "MOO1 xxxTOP" error, where xxx is PURE, IMP, or ABS depending on the current location counter.

#### NOTE

If no ORG instruction appears at the beginning of a program, CAL/32 assumes it to be relocatable starting at relocatable zero. For 32-bit programs it also assumes the impure segment.

3.8.6.4 Absolute (ABS) Instruction

This instruction causes the location counter to be put in the absolute mode. It has the form:

| NAME      | OPERATION | OPERAND   |
|-----------|-----------|-----------|
| A symbol  | ABS       | None      |
| (optional | .)        | (ignored) |

The current location counter is saved, and the new location counter is set to point to the next halfword boundary beyond the most recently used absolute location. If the absolute location counter was not previously used, it is set to zero.

#### 3.8.6.5 Align (ALIGN) Instruction

This instruction aligns the current location counter to a power of 2. It has the form:

| NAME                   | OPERATION | OP ER AN D                |
|------------------------|-----------|---------------------------|
| A symbol<br>(optional) | ALIGN     | A symbol or<br>expression |

The value contained in the operand field determines the type of alignment. Symbols used in the operand field must be previously defined. The value in the operand field must be absolute and equal to either two, four, or eight. If the operand value is two, CAL/32 adjusts the location counter to ensure that it contains a halfword address. CAL/32 forces fullword alignment if the operand value is four, and double word alignment if the value is eight. If at the time of this instruction, the location counter is already properly aligned, CAL/32 does not change it. If it is not properly aligned, CAL/32 increments it by the minimum amount necessary to force proper alignment. A symbol, if used in the name field, receives the value of the location counter after the alignment is performed.

#### NOTE

If the value of the operand is not absolute, or if it is not correctly defined, CAL/32 forces fullword alignment, and generates an error message.

### 3.8.6.6 Conditional No Operation (CNOP) Instruction

This instruction is similar to the ALIGN instruction in that it | aligns the location counter to a power of 2. It has the form:

| NAME       | OPERATION | OPERAND     |
|------------|-----------|-------------|
| A symbol   | CNOP      | A symbol or |
| (optional) |           | expression  |

The CNOP differs from the ALIGN instruction in that instead of merely incrementing the location counter, it actually inserts no operation instructions into the program stream. The value of the operand must be absolute and equal to two, four, or eight. Symbols used in the operand field must have been previously defined. If at the time this instruction is encountered, the location counter is on an odd boundary, CAL/32 increments it by one to make it even, inserts the required number of CNOP instructions to force alignment, and generates an error message. This instruction has no effect if the location counter is already properly aligned. A symbol, if used in the name field, receives the value of the location counter associated with the first CNOP instruction generated.

### 3.8.7 Assembler Control Instructions

These instructions allow the programmer to control the assembly process itself, identify the type of processor on which the program is to be run, halt the assembly operation temporarily, and request a limited amount of optimization.

## 3.8.7.1 Target (TARGT) Instruction

This instruction identifies the type of processor on which the program is to be run. It has the form:

| NAME       | OPERATION | OPERAND     |
|------------|-----------|-------------|
| A symbol   | TARGT     | A symbol or |
| (optional) |           | expression  |

The value of the operand expression must be either 16 or 32, absolute. Symbols used in the operand field must be previously defined. If the operand value is 16, CAL/32 generates object code for 16-bit processors. If the value is 32, it generates object code for 32-bit processors. If the value is anything else, CAL/32 generates a warning message and generates code for the same type of processor on which it is running. If there is no TARGT instruction in the program, CAL/32 assumes the target machine to be the same as the machine on which the assembly is running.

#### NOTE

The TARGT instruction must precede any PURE or IMPUR instructions or any instruction that generates machine code.

### 3.8.7.2 End (END) Instruction

The END instruction indicates the end of the source input. It has the form:

| A symbol   | END | A symbol or           |
|------------|-----|-----------------------|
| (optional) |     | expression (optional) |

Because of its function, this statement must be the last instruction in the source input file. The optional operand, if used, identifies the starting location of the program. For example:

| MAIN | EQU | *    |
|------|-----|------|
|      | •   |      |
|      | •   |      |
|      | •   |      |
| LAST | END | MAIN |

The END instruction, with the operand MAIN, causes CAL/32 to output information identifying the location MAIN as the starting location of the program. The loader and the operating system use this information to ensure that the program starts at the requested location. If there is no operand, the END instruction merely terminates the assembly process without outputting any loader information. The END instruction is required in all CAL/32 programs.

### | 3.8.7.3 Copy Library (CLIB) Instruction

This instruction allows the user to specify or change library files from within a program. It has the form:

CLIB vol:fname.ext

| Each CLIB statement logically concatenates the new library file (operand of CLIB) to any existing library file. If the new library file cannot be assigned, CAL/32 will log an error message and pause.

## 3.8.7.4 Copy (COPY) Instruction

This instruction allows the programmer to insert source code from library files into the source code received from the regular source input file. It has the form:

| NAME OPERATION OF | PER | AND |
|-------------------|-----|-----|
|-------------------|-----|-----|

A symbol COPY A symbol [,vol:fname.ext] (optional) (required)

CAI/32 assumes that the library file was assigned to lu 7 (see Appendix A). CAL/32 also assumes that the file is made up of 80-character records. It searches through the logical file, looking only at the first 10 characters of each record until it finds a file label of the form:

| 1 | and Z   |    | ~ · | •   |     |    |     |      |        |    |
|---|---------|----|-----|-----|-----|----|-----|------|--------|----|
| 3 | through | 10 | A   | va] | Lid | s) | ymb | olic | : name | of |
|   |         |    | fı  | rom | 1   | to | 8   | char | acter: | 5  |

in which the symbolic name exactly matches the symbol in the operand field. If the search is unsuccessful, CAL/32 logs the message:

CCPY ERFCR: xxxxxxx

in which xxxxxxx is replaced by the name of the file being sought. This might happen in the case of incorrect file assignment. The operator can change the assignment and resume the assembly process from the location of the COPY instruction. The COPY instruction allows only one operand. The programmer must provide one COPY instruction for each file to be copied into the source stream.

If the optional second operand is supplied, CAL/32 will assign and search only that physical file and ignore any files logically attached by CLIB. If the file cannot be assigned, CAL/32 will log an error message and pause.

The copy process terminates when an END statement is encountered in the file, or when a record with either /\* or /& in the first two character positions is encountered. Where an END instruction is encountered in the copy file, it does not mean the end of the source file but only the end of the copy file. At this point, CAL/32 resumes reading from the source input file. COPY instructions may not appear in files which are themselves being included in a source program by means of a COPY instruction.

#### 3.8.7.5 File Copy (FCOPY) Instruction

The assembler instruction FCOPY allows the user to copy an entire library file. It has the fcrm:

FCOPY vol:fname.ext

When FCOPY is in effect, a /\* starting in column 1 or an END in the op code field will be skipped, and copying will continue until an end of file is reached. If the file cannot be assigned, CAL/32 will log an error message and pause.

3.8.7.6 Pause (PAUSE) Instruction

The PAUSE instruction allows the programmer to halt the assembly process. It has the form:

NAME OPERATION OPERAND

A symbol PAUSE None (optional) (ignored)

The PAUSE instruction temporarily halts the assembly process. When the assembler encounters a PAUSE instruction, the assembler requests the operating system under which it is running to suspend execution. The system notifies the operator. The operator can resume execution of the assembler at the instruction

48-050 FOO ROO

ł

1

ł

1

1

immediately following the PAUSE instruction by using the operating system command CONTINUE. For example, the PAUSE instruction can be used by the operator to reassign a copy file, such as:

COPY REGEQUS COPY REGISTER EQUATES PAUSE COPY COMBLKS COPY COMMON BLOCKS

## 3.8.7.7 Squeeze (SQUEZ) Instruction

The SQUEZ instruction puts CAL/32 into a mode in which it performs a limited amount of space optimization. It has the form:

| NAME | OPERATION | OPERAND |
|------|-----------|---------|
|      |           |         |

| A symbol   | SQUEZ | A symbol or           |
|------------|-------|-----------------------|
| (optional) |       | expression (optional) |

When in optimization mode, CAL/32 makes multiple passes over the source input. During each pass, it attempts to reduce long instructions (48 and 32 bits) to shorter forms (32 and 16 bits). The value of the operand expressions sets the maximum number of passes. If CAL/32 can complete the optimization in fewer passes, it stops the optimization process and completes the assembly.

The value of the operand expression must be an absolute number between 1 and 99. Any symbols used in the expression must have been previously defined. If the operand value is 0, or if there is no operand, CAL/32 assumes a maximum of 9 passes.

#### NOTE

If there are user induced errors in the source stream (illegal mnemonics or undefined symbols), CAL/32 terminates the squeeze operation and goes on to produce the final assembler output. Some instructions in this output may have been squeezed, depending on where in the process the errors were discovered.

CAL/32 performs three types of space optimization:

- 1. Changes RX3 instructions to RX2 or RX1
- 2. Changes operation codes to allow the use of an equivalent, but shorter, instruction
- 3. Eliminates unconditional branch instructions to the next halfword location

An example of the first type of optimization is the forward reference instruction. In this instruction, the operand is defined in the program at some point beyond the instruction to which it refers.

### Example:

|       | •   |          |
|-------|-----|----------|
|       | •   |          |
|       | •   |          |
|       | A   | R1,VALUE |
|       | •   |          |
|       | •   |          |
|       | •   |          |
| VALUE | DCF | F'125'   |
|       | •   |          |
|       | •   |          |
|       | •   |          |

When CAL/32 processes the ADD instruction, it cannot tell if the location of the second operand, identified by the symbol VALUE, is within the range of either an RX1 or RX2 instruction. It has to assume that an RX3 instruction is necessary. By making additional passes over the source input after all addresses have been resolved, CAL/32 has the needed information to determine if the reference to VALUE is within the range of either an RX1 or an RX2 instruction and make the substitution.

An example of the second type of optimization is:

LI R3,-1

In the optimization mode, CAL/32 reduces this instruction to:

LCS R3,1

which reduces the length of the instruction from 48 bits to 16 bits, without changing the effect. Depending on the processor, the substituted instruction might be faster or slower than the original instruction.

#### NOTE

CAL/32 changes an operation code only in the object output. The original instruction remains in the listing, flagged with an asterisk. 1

L

ł

The third type of optimization does not occur in normal programming, but it does sometimes appear in compiler generated CAL/32. For example:

|          | •           |                                |
|----------|-------------|--------------------------------|
|          | •           |                                |
| CONTINUE | •<br>B<br>L | R1,SAVE<br>CONTINUE<br>R1,TEMP |
|          | •           |                                |
|          | •           |                                |
|          |             |                                |

In this case, CAL/32 simply eliminates the unnecessary branch instruction, although the branch instruction does appear in the assembly listing, flagged with an asterisk.

More than one SQUEZ instruction can appear in the program. The first SQUEZ instruction sets the number of additional passes. Subsequent SQUEZ instructions put CAL/32 back into optimization mode after a NO SQUEZ instruction (described below) took it out of the optimization mode. Operands may appear in the subsequent SQUEZ instructions, but they are ignored.

Because CAL/32 looks at only one instruction at a time, and because its global data is limited to the symbol table, squeezing might introduce errors into the program. This is most likely to happen when data and instructions are mixed.

Example:

|       | •     |         |
|-------|-------|---------|
|       | •     |         |
|       | •     |         |
|       | BTC   | 8,LOOP1 |
|       | •     |         |
|       | •     |         |
|       | •     |         |
| LOOP1 | EQU   | *       |
|       | •     |         |
|       | •     |         |
|       | •     |         |
|       | BFC   | O,LOOP2 |
|       | DS    | 26      |
|       | ALIGN | 4       |
| CONST | DC    | F'256'  |
| LOOP2 | EQU   | *       |
|       | •     |         |
|       | •     |         |
|       | •     |         |

If on one pass, CONST is already aligned on a fullword boundary, the branch to LOOP2 can be converted to a short format branch. A subsequent pass may allow the branch to LOOP1 to be shortened. When this happens, CONST is no longer on a fullword boundary, and CAL/32 adds two to the location counter to align it properly. This forces LOOP2 out of the range of a short branch instruction. CAL/32 will recover from this situation by changing the branch instruction back to its original format and marking it internally as unsqueezable.

### 3.8.7.8 Squeeze Related (NOSQZ, ERSQZ, NORX3) Instructions

There are three additional instructions that can be used to control squeezing and optimization of the source input file. They have the form:

| NAME                                 | OPERATION | OPERAND               |
|--------------------------------------|-----------|-----------------------|
| A symbol<br>(optional)               | NOSQZ     | Not used<br>(ignored) |
| A symbol                             | ERSQZ     | Not used              |
| (optional)<br>A symbol<br>(optional) | NORX 3    | Not used<br>(ignored) |
|                                      |           |                       |

The no squeeze instruction (NOSQZ) has the effect of turning off the optimization processes initiated by a previous SQUEZ instruction. Optimization can be restarted by a subsequent squeeze statement. NOSQZ overrides a squeeze start option.

The error squeeze instruction, (ERSQZ) can be used with the SQUEZ instruction. It forces CAL/32 to continue squeezing even after assembly errors are detected.

The no RX3 instruction (NORX3) provides a simpler form of optimization during a normal 2-pass assembly. Once this instruction is encountered, CAL/32 forces RX instructions to the RX1 or RX2 format. RX3 instruction formats are still generated if double indexing is specified, or if the instruction references an element of a common block or an externally defined symbol. This instruction can be safely used in programs that are smaller than 16kb. It must not be used in segmented (pure and impure), programs. ł

### 3.8.7.9 Sequence Checking (SQCHK, NOSEQ) Instructions

The sequence checking instructions enable and disable the sequence checking of source. They have the form:

| NAME       | OPERATION | OPERAND   |
|------------|-----------|-----------|
| A symbol   | SQCHK     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | NOSEQ     | Not used  |
| (optional) |           | (ignored) |

The sequence check instruction (SQCHK) causes CAL/32 to compare each source statement sequence number with the number of the preceding statement. Each successive number must be greater in the ASCII collating sequence than the preceding one. CAL/32's initial sequence value is equal to eight spaces, so that numbers can be right justified in the field without leading zeros. If a source statement contains a value equal to or less than the preceding statement, CAL/32 generates an error message. The sequence fields of statements included in the program by a COPY instruction are not checked.

The no sequence check instruction (NOSEQ) disables the sequence checking process. The sequence field of this instruction is checked, if sequence checking was in effect at the time. The default mode of CAL/32 is NOSEQ.

## 3.8.7.10 Scratch (SCRAT) Instruction

The scratch instruction causes CAL/32 to copy the source input file to a scratch device during pass one. It has the form:

|   | NAME   | AME OPERATION |          |
|---|--------|---------------|----------|
| A | symbol | SCRAT         | Not used |

|            | <br>      |
|------------|-----------|
| (optional) | (ignored) |
|            |           |

Subsequent passes over the source input file are read from the scratch device. Since no statement preceding the SCRAT instruction can be copied, the SCRAT instruction should be the first statement in the program.

#### 3.8.7.11 Pass Pause (PPAUS) Instruction

This instruction causes CAL/32 to issue a pause request to the operating system at the end of each pass. It has the form:

| NAME      | OPERATION | OPERAND   |
|-----------|-----------|-----------|
| A symbol  | PPAUS     | Not used  |
| (ignored) |           | (ignored) |

The purpose of the PPAUS instruction is to allow the operator to reset the source input file to the beginning for the next pass. This is useful in situations where no scratch file is available, and the source input file is not rewindable.

## NOTE

Where neither the SCRAT instruction nor the PPAUS instruction is used, CAL/32 issues a rewind command to the source input lu at the end of each pass.

### 3.8.7.12 Message (MSG) Instruction

The message instruction allows the programmer to log a message to the system console. It has the form:

NAME OPERATION OPERAND A symbol MSG Text (optional)

The operand field contains the text of the message. All characters following the operation field, up to and including position 71, are sent to the system console as a message. This instruction can appear anywhere in the program, and the message is logged on every pass.

### 3.8.7.13 Batch Assembly (BATCH, BEND) Instructions

The batch assembly instructions provide a means for assembling more than one complete program in a batch stream. They have the form:

| NAME      | CPERATICN | OPERAND   |
|-----------|-----------|-----------|
| None      | BATCH     | Not used  |
| (illegal) |           | (ignored) |
| None      | BEND      | Not used  |
| (illegal) |           | (ignored) |

The batch instruction (BATCH) initiates the batch stream. It has the effect of redefining the END instruction so CAL/32 does not terminate itself at the end of the required number of passes. Rather, CAL/32 terminates the assembly of that particular program, reinitializes itself, and starts reading the next program from the source input file. The BATCH instruction must

3-55

be the first statement in the stream of programs. If it is used, CAL/32 assumes that there is a scratch device. Options specified in the operating system START command remain in effect for the entire batch assembly (see Appendix A).

The batch end instruction (BEND) terminates the batch assembly. It must appear immediately following the END instruction in the last program of the stream. The BEND instruction tells CAL/32 to go to end of task when final assembly is completed. The end of task code returned is equal to the highest code generated during the batch assemblies. CAL/32 will also terminate a batch assembly normally if end of file or end of medium status is detected when attempting to read the first statement after the END of an assembly.

3.8.7.14 Unreferenced Externals (UREX, NUREX) Instructions

| These instructions permit or suppress the output of object code | for unreferenced externals. The default state is UREX. They | have the form:

| l | NAME                  | OPERATION | OPERAND               |
|---|-----------------------|-----------|-----------------------|
|   | Not used<br>(ignored) | UREX      | Not used<br>(ignored) |
|   | Not used<br>(ignoreá) | NUREX     | Not used<br>(ignored) |

### 3.8.8 Conditional Assembly Instructions

These instructions allow the programmer to include in the program code sequences that may or may not be assembled, depending on some condition. By simply reassembling the program and redefining the conditions, a single program can be made to serve more than one purpose.

3.8.8.1 Compound Conditional (IFx, ELSE, ENDC) Instructions

There are three instructions in this set. They have the form:

| OPERATION | OPERAND                          |
|-----------|----------------------------------|
| IFx       | A symbol or                      |
|           | expression                       |
| ELSE      | A symbol or                      |
|           | expression                       |
|           | (ignored)                        |
| ENDC      | A symbol or                      |
|           | expression                       |
|           | (ignored)                        |
|           | OPERATION<br>IFx<br>ELSE<br>ENDC |

L

1

The compound conditional instructions are used to provide complete conditional assembly capability. A symbol used in the name field of an IF instruction is defined if the condition described by the instruction is true. A symbol used in the name field of an ELSE instruction is defined if the corresponding if condition is false. Symbols used in the name fields of end condition instructions are always defined.

In the first instruction, the compound IF instruction, x represents the actual condition. Following is a list of the various mnemonics for these instructions:

| MNEMONIC | MEANING    | MNEMONIC |    | MEANING   |
|----------|------------|----------|----|-----------|
| IFZ      | If zero    | IFNM     | If | nonminus  |
| IFNZ     | If nonzero | IFE      | If | even      |
| IFP      | If plus    | IFO      | If | odd       |
| IFNP     | If nonplus | IFU      | Ιf | undefined |
| IFM      | If minus   | IFD      | Ιf | defined   |
|          |            |          |    |           |

CAL/32 tests the value of the operand when processing compound IF instructions. If the operand meets the condition specified by the operation, the instructions immediately following the IF instruction are assembled. If the operand does not meet the specified condition, the instructions immediately following the IF instruction are not assembled.

The FLSE instruction reverses the state of the assembler as set by a previous compound IF statement. If the assembler was not assembling code because a previous IF statement turned off the assembly process, the appearance of an ELSE instruction would cause the assembler to resume assembling, starting with the instruction immediately following the ELSE instruction. If the assembler was assembling code because a previous if condition was met, the appearance of the ELSE instruction would cause the instructions immediately following the else instruction not to be assembled. An ELSE instruction is not required to appear in a block of conditionally assembled code.

The third instruction of this set is the end condition instruction (ENDC) which terminates the presently active condition. Normal assembly process resumes with the next instruction. Any compound IF instruction used in the program must have a corresponding ENDC instruction. If the end of the source file is reached before an existing condition terminates, CAL/32 terminates the condition, generates an error message, and resumes normal assembly on the next pass. If the operand of the IFx contains a forward reference, CAL/32 will perform any additional passes required to define all symbols. As an example of conditional assembly, consider a subroutine that can receive its parameters in either of two ways: first, the parameters are located by referencing a list of addresses immediately following the branch and link instruction in the main

program; second, the address of the actual parameter list is contained in register 14. The subroutine could handle both of these situations with conditional assembly, as follows:

•

•

|       | •            |          |                              |
|-------|--------------|----------|------------------------------|
|       | •            |          |                              |
|       | IFZ          | CALL1    |                              |
| ŲВ    | LH           | R1,0(RF) | GET FIRST PARAMETER ADDRESS  |
|       | LH           | R1,0(R1) | GET FIRST PARAMETER          |
|       | LH           | R2,2(RF) | GET SECOND PARAMETER ADDRESS |
|       | LH           | R2,0(R2) | GET SECOND PARAMETER         |
|       | AIS          | RF,4     | ADJUST RETURN ADDRESS        |
|       | ELSE         |          | LIST NOT IN LINE             |
| UB    | ΓH           | R1,0(RE) | GET FIRST PARAMETER          |
|       | LH           | R2,2(RE) | GET SECOND PARAMETER         |
|       | ENDC         |          |                              |
|       | •            |          |                              |
|       | •            |          |                              |
|       | •            |          |                              |
| ETURN | BR           | RF       | RETURN TO CALLER             |
|       | •            |          |                              |
|       | •            |          |                              |
|       | •            |          |                              |
| ETURN | •<br>BR<br>• | R F      | RETURN TO CALLER             |

If at assembly time, the value of CAL1 is zero, the instructions between the IF instruction and the ELSE instruction are assembled, and the instructions between the ELSE instruction and ENDC instruction are not assembled. If the value of CAL1 is other than zero, only the instructions between the ELSE instruction and the ENDC instruction are assembled.

Another example of conditional assembly shows how conditions can be nested:

|   |        | •               |           |                      |
|---|--------|-----------------|-----------|----------------------|
|   |        | •               | 1.001     |                      |
|   |        | 1 F N P         | LGTH      | CONDITION #1         |
| * | ERROR  | 1               |           | LGTH IS NOT POSITIVE |
|   |        | ELSE            |           | CONDITION #1         |
|   |        | IFZ             | SRC-DST   | CONDITION #2         |
| * | FRROR  | 2               |           | SEC IS FOULL TO DET  |
|   | DIALOI | <u>म्</u> राद्य |           | CONDITION #2         |
|   |        | TUT             |           | CONDITION #2         |
|   |        | гнт             | R I, LGIN |                      |
|   |        | IFP             | SRC-DST   | CONDITION #3         |
|   |        | LHI             | R2,SRC    |                      |
|   |        | LHI             | R3,DST    |                      |
|   |        | ELSE            | ·         | CONDITION #3         |
|   |        | LHT             | E2.DST    |                      |
|   |        | THT             | R3.SRC    |                      |
|   |        | ENDC            | 1.0,010   | END CONDITION #3     |
|   |        | ENDC            |           | END CONDITION #5     |
|   |        | ENDC            |           | END CONDITION #2     |
|   |        | ENDC            |           | END CONDITION #1     |
|   |        | •               |           |                      |
|   |        | •               |           |                      |
|   |        | -               |           |                      |

This set of nested conditionals depends on the values of three symbols: LGTH, SRC, and DST. If LGTH is negative or zero, only the comment:

\* ERROR 1 LGTH IS NOT POSITIVE

is produced. If LGTH is positive, and SRC is equal to DST, only the second comment:

\* ERRCR 2

SRC IS EQUAL TO DST

is produced. If LGTH is positive, and SRC is greater than DST, the following instructions:

LHI R1,LGTH LHI R2,SRC LHI R3,DSC

are assembled. If LGTH is positive, and SRC is less than DST, the following instructions are assembled:

LHI R1,LGTH LHI R2,DST LHI R3,SRC

The user must be careful, when using a forward reference in the operand field of the IFU instruction, to avoid the following type of code:

| В | IFU<br>EQU | A<br>8 |
|---|------------|--------|
|   | ENDC       |        |
| A | EQU        | 1      |
|   | IFNZ       | В      |
|   | DS         | 10     |
|   | ENDC       |        |
| В | EQU        | 0      |
|   | END        |        |

1

1

1

CAL/32 will flag this code with an "MOO1 xxxTOP" error where xxx is PURE, IMP, or ABS, depending upon the location counter used.

## NOTE

A condition once set by an IF instruction remains in effect until the corresponding ENDC instruction is encountered. Thus, when the first condition was met, the first comment was produced. The ELSE instruction reversed this state, and no subsequent code was assembled.

3.8.8.2 Simple If (IF) Instruction

The simple IF instruction is retained in CAL/32 to maintain compatibility with previous assemblers. It has the form:

| NAME       | CPERATICN | OPERAND     |
|------------|-----------|-------------|
| A symbol   | IF        | A symbol or |
| (optional) |           | expression  |

What CAL/32 does on encountering an IF instruction depends on the value of the operand. If the operand has a nonzero value, CAL/32 assembles all statements following the IF instruction, until the end of the source file is reached, or until another IF instruction is encountered in which the operand value is zero. At this point, CAL/32 stops assembling the source input until the END instruction, or another IF instruction with a nonzero operand value, is encountered. If the operand contains a forward reference, CAL/32 will perform any additional passes required to define all symbols.

#### NOTE

Do not use simple IF instructions and compound IF instructions in the same program. Simple IF instructions must not be used in nested conditionals.

3.8.8.3 Do (DO) Instruction

The DO instruction provides a form of conditional and multiple assembly capability. It has the form:

| NAME                   | OPERATION | OPERAND                   |
|------------------------|-----------|---------------------------|
| A symbol<br>(optional) | DO        | A symbol or<br>expression |

L

I

The DO instruction causes the statement immediately following it to be assembled as many times as specified by the value of the operand. The value of the operand must be between 0 and 32,767. If the value of the operand is 0, the next instruction is skipped. If the operand contains a forward reference, CAL/32 will perform any additional passes required to define all symbols.

The user must guard against circular location counter dependency, as in the following example:

| A | EQU | *     |
|---|-----|-------|
|   | DO  | B – A |
|   | DS  | 2     |
| В | EQU | *     |
|   | END |       |

CAL/32 will flag an "MOO1 xxxTOP" error, where xxx is PURE, IMP, or ABS, depending upon the current location counter.

#### 3.8.9 Instructions for Data Structures

These instructions allow the programmer to define complex data structures. Some of these instructions allow the programmer to define and initialize data blocks compatible with FORTRAN common.

3.8.9.1 Structure Definition (COMN, STRUC, ENDS) Instructions

Structure definition instructions are used to define data structures. They have the form:

| NAME       | OPERATION | OPERAND   |
|------------|-----------|-----------|
| A symbol   | COMN      | Not used  |
| (optional) |           | (ignored) |
| A symbol   | STRUC     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | ENDS      | Not used  |
| (optional) |           | (ignored) |

The common instruction (CCMN) defines FORTRAN compatible common blocks. The structure instruction (STRUC) defines other types of data structures. The end structure instruction (ENDS) terminates both common definitions and data definitions.

The symbol in the name field of a COMN or STRUC statement contains the absolute value of the length of the structure or common block. The symbol specified with the ENDS instruction is associated with the current value of the offset counter.

1

ł

1

I

L

A symbol is always required in the name field of a COMN instruction. To define FORTRAN compatible blank common, a special symbol consisting of two slashes (//) must appear in the first two positions of the name field. The remaining positions must be blank. If the name field is blank, CAL/32 will assume (//) was intended for a FORTRAN blank common.

The scope of the common block consists of all the storage definitions between the COMN instruction itself and the next ENDS statement. Only define storage, origin, and equate instructions are permitted between a COMN and its corresponding ENDS instruction. The define storage instructions included within the common block definition do not actually reserve storage; they define offsets within the common block. Origin statements can be used to modify the offset ccunter. The equate instructions can be used to define symbols relative to elements in the common block. Common blocks cannot be nested within other common blocks or within other structure definitions.

The following is an example of the definition of FORTRAN compatible common blocks:

C FORTRAN PRCGRAM INTEGER\*2 I,J,K,KK,K2,L COMMON A(10), I, J(3,20) COMMON/COMONE/E(30), K(4), KK CCMMON/COMTWO/X,Y,Z,K2,L(24)

The CAL/32 code to define these common blocks is:

| 11     | COMN |     | DEFINE BLANK COMMON            |
|--------|------|-----|--------------------------------|
| A      | DS   | 40  | TEN FLOATING POINT NUMBERS     |
| I ,    | DS   | 2   | ONE TWO-BYTE INTEGER           |
| J      | DS   | 120 | SIXTY TWO-BYTE INTEGERS        |
|        | ENDS |     | END OF BLANK COMMON DEFINITION |
| COMONE | COMN |     | DEFINE COMMON BLOCK COMONE     |
| В      | DS   | 120 | THIRTY FLOATING POINT NUMBERS  |
| K      | DS   | 8   | FOUR TWC-BYTE INTEGERS         |
| KΚ     | DS   | 2   | ONE TWO-BYTE INTEGER           |
|        | ENDS |     | END COMMON BLOCK COMONE        |
| COMTWO | COMN |     | DEFINE COMMON BLOCK COMTWO     |
| Х      | DS   | 4   | ONE FLOATING POINT NUMBER      |
| Y      | DS   | 4   | ONE FLOATING POINT NUMBER      |
| Z      | DS   | 4   | ONE FLOATING POINT NUMBER      |
| К 2    | DS   | 2   | CNE TWO-BYTE INTEGER           |
| L      | DS   | 48  | TWENTY FOUR TWO-BYTE INTEGERS  |
|        | ENDS |     |                                |

Common block definitions must precede any statements that reference the common block. Referencing a common element plus a displacement is permitted in the operand of a machine instruction, in a define constant instruction, or in a block data origin instruction defined below. STRUC is used to define general purpose data structures. The scope of this data structure consists of all the storage definitions between the structure instruction and its corresponding ENDS instruction. Only define storage, origin, and equate instructions can be used in a structure definition. The define storage instructions do not actually reserve storage; they define offsets within the data structure. Origin statements can be used to modify the value of the offset counter. Equate statements can be used to define names relative to elements in the data structure. Data structures cannot be nested within other data structure definitions or within common block definitions.

To define a linked list structure, each node of which contains a 2-byte forward pointer, a 2-byte backward pointer, six bytes, and a set of values such as: four bytes, one byte, one byte and six bytes, the programmer might write:

| NODE | STRUC | 2 |                         |
|------|-------|---|-------------------------|
| FWD  | DS    | 2 | DEFINE FORWARD POINTER  |
| BAK  | DS    | 2 | DEFINE BACKWARD POINTER |
| VALA | DS    | 4 | DEFINE FOUR-BYTE VALUE  |
| VALB | DS    | 1 | DEFINE ONE-BYTE VALUE   |
| VALC | DS    | 1 | DEFINE ONE-BYTE VALUE   |
| VALD | DS    | 6 | DEFINE SIX-BYTE VALUE   |
|      | ENDS  |   |                         |

The effect of this definition is the same as:

| NODE | EQU | 16 |
|------|-----|----|
| FWD  | EQU | 0  |
| ΒAK  | EQU | 2  |
| VALA | EQU | 4  |
| VALB | EQU | 8  |
| VALC | EQU | 9  |
| VALD | EÇU | 10 |

٠

Once NODE is defined, it can be used as follows:

|       | •               |                                      |                      |                               |                |                                 |
|-------|-----------------|--------------------------------------|----------------------|-------------------------------|----------------|---------------------------------|
|       | LHI<br>LB<br>LH | R5,POCL<br>R0,VALB(R5)<br>R5,FWD(R5) | G ET<br>G ET<br>G ET | ADDRESS<br>VALUE B<br>POINTER | OF<br>OF<br>TO | POOL<br>FIRST NODE<br>NEXT NODE |
|       | •               |                                      |                      |                               |                |                                 |
| 200 L | DS<br>•         | 1 G O * N O D E                      |                      |                               |                |                                 |

Data structure definitions must precede any references to their elements in RX3 format instructions, unless the NORX3 instruction or the SQUEZ instruction was used.

### 3.8.9.2 Structure Initialization (BDATA, BORG) Instructions

Structure initialization instructions define FORTRAN compatible block data subprograms that consist of labeled common blocks. They have the form:

NAME OPERATION CPERAND A symbol BDATA Not used (optional) (ignored) A symbol BORG Not used (optional) (ignored)

The block data instruction (BDATA) must precede any statements that generate data, and the block data subprogram must not contain any executable code. The common blocks to be initialized must be defined at the beginning of the block data subprogram. Once they are defined, the block origin instruction (BORG) is used to initialize the data elements of the common blocks. The operand of the block origin instruction consists of the common block name followed immediately by the element name or its displacement enclosed in parentheses. Only one operand is allowed. The following is an example of a block data subprogram:

|   | BDA *              | TA         |                   |                  |         |         |       |
|---|--------------------|------------|-------------------|------------------|---------|---------|-------|
|   | *<br>*             |            | COMMON            | BLOCK            | DEFINIT | LION    |       |
|   | BLK CCM            | N          |                   |                  |         |         |       |
| A | DS 4               |            |                   |                  |         |         |       |
| В | DS 40              |            |                   |                  |         |         |       |
| Y | DS 20              |            |                   |                  |         |         |       |
| Z | DS 4               |            |                   |                  |         |         |       |
|   | ENDS<br>*          |            |                   |                  |         |         |       |
|   | *                  |            | INITIAL           | LIZE EI          | LEMENTS | A, B+8, | AND Z |
|   | *                  |            |                   |                  |         |         |       |
|   | BORG BLK<br>DC E'1 | (A)<br>0'  | REFEREI           | NCE BY           | NAME    | ι.      |       |
|   | BORG BLK<br>DC E'2 | (64)<br>0' | REFERE            | NCE BY           | DISPLAC | CEMENT  |       |
|   | BORG BLK           | (B+8)      | REFERE!<br>DISPLA | NCE BY<br>CEMENT | NAME AN | 1 D     |       |
|   | DC E•3<br>END      | 0 •        |                   |                  |         |         |       |

This program initializes A to a floating point value of 10; Z to a floating point value of 20; and the third fullword, B, to a floating point value of 30.

### 3.8.10 Listing Control Instructions

These instructions allow the programmer to exercise some control over the format and the content of the source listing produced by CAL/32 on the final pass of the assembly.

### 3.8.10.1 Listing Identification (PROG, TITLE) Instructions

Listing identification instructions are used to force CAL/32 to print header information at the top of each page of the source listing. They have the form:

| NAME                                 | OPERATION | OPERAND |
|--------------------------------------|-----------|---------|
| A symbol                             | PROG      | Text    |
| (optional)<br>A symbol<br>(optional) | TITLE     | Text    |

The program instruction (PROG) specifies the primary heading for each page of the listing. In addition, it causes the symbol in the name field to be placed at the beginning of the object file for program identification. On 16-bit assemblies, only the first six characters of the name field are put in the object file.

All characters in the operand field (a maximum of 56) up to and including position 71 are printed in the primary header line of each page of the listing. If more than one PROG instruction is encountered in a module, the last PROG instruction will override all previous ones.

The title instruction (TITLE) is a way to specify subheadings that can be changed within the program. The text contained in the operand field up to and including position 71, is printed on the line immediately below the heading produced by the PROG instruction. As many TITLE instructions as required can appear in the source input file. Each time a TITLE instruction is encountered, CAL/32 starts a new listing page with the new subheading when the next printable statement is processed. Subsequent pages contain this same subheading, until another TITLE instruction appears. If two or more TITLE instructions occur together in sequence, only the last TITLE instruction affects the subheading content since a new page will be printed only when a printable statement is encountered.

TITLE instructions themselves are not printed although they are included in the statement count.

1

1

1

3.8.10.2 Format Control (LCNT, EJECT, SPACE, WIDTH) Instructions

Format control instructions allow the programmer to control the format of the listing. They have the form:

| OPERATION | OPERAND                                      |
|-----------|----------------------------------------------|
| LCNT      | A symbol or                                  |
|           | expression                                   |
| EJECT     | A symbol or                                  |
|           | expression                                   |
| SPACE     | A symbol or                                  |
|           | expression                                   |
| WIDTH     | A symbol or                                  |
|           | expression                                   |
|           | OPERATION<br>LCNT<br>EJECT<br>SPACE<br>WIDTH |

The operand field of the line count instruction (LCNT) specifies the number of lines to be printed on each page of the listing. The operand value must be an absolute number no greater than 99 and no less than 10. The default value of the line count is 58.

Whenever the eject instruction (EJECT) appears, it overrides the specified or default line count, and causes CAL/32 to start a new page when the next printable statement is processed. The new page starts with whatever headings are in use. This statement is included in the statement count, but it is not printed. If one or more EJECT instructions occur together in sequence, only one page is advanced since the actual advance occurs only when a printable instruction is encountered. EJECT instructions themselves are not printed although they are included in the statement count.

The operand field of the space instruction (SPACE) specifies the number of lines to be skipped in the listing. The value of the operand must be absolute. If the number of lines to be skipped exceeds the number of lines remaining on the page, this instruction has the same effect as an EJECT instruction and is included in the statement ccunt, but not printed.

The operand field of the width instruction (WIDTH) specifies the number of columns to be printed across the page. The value of the operand field must be an absolute number, not greater than 132 and not less than 64. The default value is 132.

## 3.8.10.3 Content Control (NLIST) Instructions

The content control instructions control the content of the listing. They have the form:

| NAME       | OPERATION | OPERAND   |
|------------|-----------|-----------|
| A symbol   | NLIST     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | LIST      | Not used  |
| (optional) |           | (ignored) |
| A symbol   | LSTC      | Not used  |
| (optional) |           | (ignored) |
| A symbol   | NLSTC     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | ERLST     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | LSTM      | Not used  |
| (optional) |           | (ignored) |
| A symbol   | NLSTM     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | FREZE     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | NFREZ     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | CROSS     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | NCROS     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | LSTUR     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | NLSTU     | Not used  |
| (optional) |           | (ignored) |
| A symbol   | WARN      | Not used  |
| (optional) |           | (ignored) |
| A symbol   | NWARN     | Not used  |
| (optional) |           | (ignored) |

The no list instruction (NLIST) suppresses listing of the source program. Only those statements that contain errors are printed.

The list instruction (LIST) reverses this situation, and all source statements are printed. The assembler default is to print all source statements.

The list conditionals instruction (LSTC) permits printing of unassembled conditional assembly statements. This is the normal default mode of the assembler.

The no list conditionals instruction (NLSTC) suppresses printing of unassembled conditional statements.

The error list instruction (ERLST) causes CAL/32 to print all assembly errors by type, along with number of each statement on which the error occurred, immediately after symbol table listing.

The list macro instruction (LSTM) permits printing of all macro expansions that are part of the source input file. The macro instruction, the expanded source code, and the generated object code are printed. A plus character (+) precedes each statement number in the expanded source to identify those statements as part of a macro. This is the normal mode of the assembler.

The no list macro instruction (NLSTM) suppresses printing of macro expansions. Only the macro statement itself is printed.

The freeze (FREZE) instruction halts incrementing of the statement counter when a copy file or macro expansion are included in the source input file. All statements in the copy file or macro expansion receive the same statement number as that of the COPY instruction. This is the normal mode of the assembler.

The no freeze (NFREZ) instruction increments the statement counter for every statement encountered in the source input.

The cross reference (CROSS) instruction uses CAL/32 to generate and print a cross reference listing of all the symbols used in the program. Each symbol is listed in alphabetical order, along with identification of the statements in which it is referenced. The statement in which it is defined is flagged with an asterisk. This is the normal mode of the assembler.

The no cross (NCROS) instruction prevents the generation of a cross reference listing.

The list unreferenced symbols (LSTUR) instruction causes unreferenced symbols to be listed in the symbol list. This is the normal mode of the assembler. 1

The no list unreferenced symbols (NLSTU) instruction suppresses the listing of unreferenced symbols in the symbol list.

The warning (WARN) instruction allows CAL/32 to flag warnings in the listing and tally the number of warnings encountered. This is the normal mode of the assembler.

The no warning (NWARN) instruction suppresses both the warnings and the warning count from the listing. 

#### 3.9 ASSEMBLY LISTING

The assembly listing consists of two sections: the source and object program statements and the symbol cross reference table. The format for printing the source and object program statements is basically the same for either 16-bit assemblies or 32-bit assemblies. The only difference is in the number of characters printed for the location counter and the object data.

Ł

- In 16-bit assemblies, only four hexadecimal digits are printed for the location counter, and a maximum of eight hexadecimal digits for the data. The letter R is appended to the location counter value if the relocatable location counter is being used.
- In 32-bit assemblies, six hexadecimal digits are printed for the location counter and a maximum of 12 hexadecimal digits for the object data. In addition, the actual second operand address of RX2 and SF instructions is printed next to the object data. This address is preceded by an equal sign (=). The letter I is appended to the location counter if the impure location counter is being used. The letter P is appended to the location counter if the pure location counter is being used.
- In both 16- and 32-bit assemblies, the letter F is appended to the data field to indicate that the statement references an externally defined symbol, a symbol in a common block, or an undefined symbol.

The statement number is a decimal number between 1 and 99999. Each source statement read by the assembler is assigned a unique statement number, beginning with 1, except for source statements from a copy file or macro expansion with the FREZE instruction. The first column of the listing can contain any of the following characters:

CHARACTER

#### MEANING

- ! The name field of this instruction contains a symbol that was redefined by an EQUATE instruction.
- ? A machine instruction not available on the target machine was used; an equivalent instruction existed and was substituted, or

a machine dependent instruction was used in assembling a common mode program, or

an assembler instruction was used with an improper but assemblable operand, or

a SCRAT card was encountered as other than the first statement or when batch mode is in effect, or

an EXTRN/ENTRY symbol is longer than 6 characters for target 16, or

a DS instruction was encountered in a pure section.

\* A machine instruction was shortened or modified by squeezing.

3-69

1

The following information is printed at the beginning of the cross reference listing:

- Start options in the START command
- The number of errors detected by the macro processor if the program assembled was generated by the macro processor.
- Number of CAL/32 errors and the page number of the last error
- Number of CAL/32 warnings and the page number of the last warning
- Number of passes
- Message indicating the use of symbol table paging to disk
- Message indicating abnormal termination of squeezing because of squeeze-induced errors
- Message indicating the amount of required table space

Following this, each symbol used in the program is listed in alphabetical order along with its value. If a cross reference was requested, the statement number of each statement containing a reference to the symbol is printed following the value. The statement number in which the symbol is defined is printed with an asterisk (\*) following. Associated with each symbol is a flag used to indicate one of the following:

FLAG

1

MEANING

| x   | Properly defined local symbol |
|-----|-------------------------------|
| M   | Multiply defined symbol       |
| U   | Undefined symbol              |
| <   | Entry symbol                  |
| < U | Undefined entry               |
| >   | Externally defined symbol     |
| > M | Multiply defined external     |
| * * | Unreferenced external         |
|     |                               |

The flag is printed in the first column of the line containing the symbol.

If an error is detected in a source statement, the following message is printed immediately after the error statement:

\*\*Annn\*\*

A indicates the general type of error, and nnn is a decimal number that further identifies the error. Appendix B contains a complete list of CAL/32 error codes.

## CHAPTER 4 COMMON MODE PROGRAMMING

## 4.1 INTRODUCTION

A useful feature of Common Assembly Language/32 (CAL/32) is mode programming where a single source file can be used to produce object code for either 16-bit processors or 32-bit processors. In creating a common mode source file, the programmer must be aware of certain restrictions and safeguards and, in some cases, must use special operation mnemonics that can be translated into either 16-bit or 32-bit operations.

### 4.2 ADDRESS OPERATION INSTRUCTIONS

Addresses for 16-bit processors occupy 16 bits, a halfword. For the 32-bit processors, addresses occupy the least-significant 24 bits of a fullword. In normal mode, CAL/32 makes no distinction between operations on address quantities and operations on other data types. However, when writing in common mode, the programmer must use special operation mnemonics for address operations so CAL/32 can translate them into the correct target machine code. Table 4-1 lists these instructions, their mnemonics, and the target machine translations.

| INSTRUCTION                                                                                                                                            | MNEMONIC                                         | 32-BIT  <br>TRANS-  <br>LATION      | 16-BIT  <br>TRANS-  <br>LATION            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------|-------------------------------------------|
| Add Address<br>Add Address Immediate<br>Add Address RR<br>Add Address to Memory<br>Compare Address                                                     | AA<br>AAI<br>AAR<br>AAR<br>CA                    | A<br>AI<br>AR<br>AM<br>C            | AH<br>AHI<br>AHR<br>AHM<br>CH             |
| <pre>Compare Address Immediate Compare Address RR Compare Logical Address Compare Logical Address Immediate Compare Logical Address RR Immediate</pre> | CAI<br>CAR<br>CLA<br>CLA<br>CLAI<br>CLAR<br>CLAI | CI<br>CR<br>CL<br>CLI<br>CLR<br>CLI | CHI<br>CHR<br>CLH<br>CLHI<br>CLHR<br>CLHI |

### TABLE 4-1 COMMON MODE ADDRESS OPERATIONS

# TABLE 4-1 COMMON MODE ADDRESS OPERATIONS (Continued)

|                                                                                                                                          | MNEMONIC                      | 32-BIT<br>TRANS-<br>LATION | 16-BIT<br>TRANS-<br>LATION    |
|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|----------------------------|-------------------------------|
| Load Address                                                                                                                             | LDA                           | L                          | LH                            |
| Load Address Immediate                                                                                                                   | LDAI                          | LA                         | LHI                           |
| Load Address RR                                                                                                                          | LDAR                          | LR                         | LHR                           |
| AND Address                                                                                                                              | NA                            | N                          | NH                            |
| AND Address Immediate                                                                                                                    | NAI                           | NI                         | NHI                           |
| AND Address RR                                                                                                                           | NAR                           | NR                         | NHR                           |
| OR Address                                                                                                                               | OA                            | O                          | OH                            |
| OR Address Immediate                                                                                                                     | OAI                           | OI                         | OHI                           |
| OR Address RR                                                                                                                            | OAR                           | OR                         | OHR                           |
| Subtract Address                                                                                                                         | SA                            | S                          | SH                            |
| Subtract Address Immediate                                                                                                               | SAI                           | SI                         | SHI                           |
| Subtract Address RR                                                                                                                      | SAR                           | SR                         | SHR                           |
| Shift Left Address Arithmetic                                                                                                            | Slaa                          | SLA                        | SLHA                          |
| Shift Left Address Logical                                                                                                               | Slal                          | SLL                        | SLHL                          |
| Shift Right Address Arithmetic                                                                                                           | Sraa                          | SRA                        | SRHA                          |
| Shift Right Address Logical                                                                                                              | SRAL                          | SRL                        | SRHL                          |
| Store Address                                                                                                                            | STA                           | ST                         | STH                           |
| Test Address Immediate                                                                                                                   | TAI                           | TI                         | THI                           |
| Exclusive OR Address                                                                                                                     | XA                            | X                          | XH                            |
| Exclusive OR Address Immediate                                                                                                           | XAI                           | XI                         | XHI                           |
| Exclusive OR Address RR<br>  Multiply Address<br>  Multiply Address RR<br>  Divide Address<br>  Divide Address RR<br>  Divide Address RR | XAR<br>MA<br>MAR<br>DA<br>DAR | XR<br>M<br>MR<br>D<br>DR   | XHR<br>MH<br>MHR<br>DH<br>DHR |

CAL/32 translates these instructions into halfword or fullword instructions, depending on the target machine. For example:

|      | •            |                    |
|------|--------------|--------------------|
|      | •            |                    |
|      | L D A<br>A A | R1,ADD1<br>R1,DISP |
|      | •            |                    |
|      | •            |                    |
|      | •            |                    |
| ADD1 | DC           | A(TABLE)           |
| DISP | DC           | 2                  |
|      | •            |                    |
|      | •            |                    |
|      | •            |                    |

When CAL/32 assembles these instructions for 16-bit execution, it produces object code that would normally correspond to:

LH R1,ADD1 AH R1,DISP

For 32-bit programs, CAL/32 produces code that would correspond to:

L R 1, ADD 1 A F 1, DISP

Translation is at the object code level; CAL/32 prints the original common mode code on the listing.

## 4.3 COMMON MODE IMMEDIATE OPERATIONS

CAL/32 provides a common mode immediate operation for the load immediate LDI instruction. Depending on the target machine, the LDI is translated into a fullword-referencing LI instruction for the 32-bit machine, or a halfword-referencing LHI instruction for the 16-bit machine, as follows:

| INSTRUCTION    | COMMON   | 32-BIT      | 16-BIT      |
|----------------|----------|-------------|-------------|
|                | MNEMCNIC | TRANSLATION | TRANSLATION |
| Load Immediate | LDI      | LI          | LHI         |

### 4.4 COMMON MODE ASSEMBLER INSTRUCTIONS

In addition to all of the regular assembler instructions described in Chapter 3, CAL/32 recognizes four assembler instructions primarily for use in common mode programming. Two of these are data definition type instructions; the other two are assembler control type instructions.

4-3

#### 4.4.1 Data Definition Instructions

The common mode data definition instructions are: define address length constant and define address length storage. They have the form:

| NAME                   | OPERATION | OPERAND                                     |
|------------------------|-----------|---------------------------------------------|
| A symbol<br>(optional) | DAC       | One or more operands<br>separated by commas |
| A symbol<br>(optional) | DAS       | A symbol or<br>expression                   |

### 4.4.1.1 Define Address Length Constant Instruction

The define address length constant instruction is equivalent to the define constant instruction. It is used in common mode programming to reserve storage to be initialized with address length constants. For 32-bit assemblies, the constants are fullwords aligned on fullword boundaries. For 16-bit assemblies, the constants are halfwords aligned on halfword boundaries.

## 4.4.1.2 Define Address Length Storage Instruction

The define address length storage instruction is equivalent to the define storage instruction. In 32-bit assemblies, the instruction reserves the specified amount of fullwords aligned on a fullword boundary. In 16-bit assemblies, it reserves the specified amount of halfwords aligned on a halfword boundary. Examples of the use of these instructions are:

| •   |          |
|-----|----------|
| •   |          |
| DAC | A(TABLE) |
| DAS | 16       |

.

•

-
When assembled for 32-bit execution, the define address length constant instruction generates a fullword containing the address of TABLE. The define address length storage instruction reserves 16 fullwords of storage. When assembled for 16-bit execution, these instructions cause CAL/32 to generate a halfword containing the address of TABLE, along with a storage area of 16 halfwords.

#### NOTE

Define address length storage instructions can be used in common block and structure definitions.

4.4.2 Assembler Control Instructions

Two special assembler instructions control error checking. Their form is:

| NAME                   | OPERATICN | OPERAND               |
|------------------------|-----------|-----------------------|
| A symbol<br>(optional) | CAL/32    | Not used<br>(ignored) |
| A symbol<br>(optional) | NOCAL     | Not used<br>(ignored) |

The first of these instructions (CAL/32) establishes the common mode and enables common mode error checking. In this mode, any machine dependent instruction causes a nonfatal error, and a warning flag is printed on the assembly listing.

The NOCAL/32 instruction disables the common mode and its error checking mechanisms until the next CAL/32 instruction is encountered. This is the assembler default mode in which an operation code mnemonic, not valid for the targeted processor but for which there is a valid equivalent, is assembled using the valid equivalent. A question mark (?) is then printed in the left hand margin of the listing.

#### 4.5 MIXED MODE COMPUTATIONS

On 32-bit processors, mixed mode computations, such as adding a halfword guantity to an address length quantity contained in a register, can be performed. In general, any halfword arithmetic or logical operation can be performed on address length quantities contained in registers. The exceptions are: shifts, multiply, and divide. The halfword forms of these instructions should never be used with address length quantities. Instead, use the special address operation instructions.

#### 4.6 GLOBAL SYMBOLS

The global symbols, ADC and LADC, are used primarily in common mode programming. In 32-bit assemblies, ADC has a value of four, the length in bytes of an address length constant. LADC has a value of two, the log (base 2) of the address length. In 16-bit assemblies, ADC has a value of two, and LADC has a value of one. Illustrated are these symbol uses in which a main program calls a subroutine and passes parameters to the subroutine in a list of addresses immediately following the branch and link instruction:

|        | -   |                              |
|--------|-----|------------------------------|
|        | •   |                              |
|        | BAL | RF, SUB                      |
|        | DAC | A(PARM1), A(PARM2), A(PARM3) |
| RETURN | EQU | *                            |
|        | •   |                              |
|        | •   |                              |
|        | -   |                              |

The subroutine picks up the parameters and calculates the return address as follows:

| SUB    | AIS<br>NAT | RF,LADC<br>PF,-ADC     | ADJUST RF FOR<br>ALTGNMENT  |
|--------|------------|------------------------|-----------------------------|
|        | LDA        | R1,0(RF)               | ADDRESS OF FIRST PARAMETER  |
|        | LDA        | R2,ADC(RF)             | ADDRESS OF SECOND PARAMETER |
|        | LDA        | R3,2*ADC(RF)           | ADDRESS OF THIRD PARAMETER  |
|        | •          |                        | •                           |
|        | •          |                        |                             |
| CHDEND | •<br>0     | $2 \pm \lambda DC(DE)$ |                             |
| SUBEND | Ľ          | 3 ADC(RF)              | REIURN TO CALLER            |
|        | •          |                        |                             |
|        |            |                        |                             |
|        | -          |                        |                             |

The add immediate short instruction and the add address immediate instruction are needed in the subroutine because alignment of address constants in 32-bit assemblies can cause a halfword of filler to be inserted between the branch and link instruction and the first address constant. In this case, the address in register 15 is the address of this halfword, and these instructions increment the address in register 15 to make it point to the first address constant. If no filler is required, because the first constant is naturally aligned on a fullword boundary, register 15 points to the first constant, and these two instructions have no effect. Another use of LADC is in shift instructions where a byte pointer must be converted into an address pointer, as:

| •    |              |                            |
|------|--------------|----------------------------|
| •    |              |                            |
| ΓB   | R T, INDEX   | GET BITE POINTER           |
| SLAL | R1,LADC      | CONVERT TO ADDRESS POINTER |
| LDA  | R2,TABLE(R1) | GET ADDRESS FROM TABLE     |
| BR   | R 2          |                            |
| •    |              |                            |
| •    |              |                            |
| •    |              |                            |

In 16-bit assemblies, LADC has a value of one, and the shift left logical instruction has the effect of doubling the value of the byte pointer, converting it into a halfword pointer. In 32-bit assemblies, LADC has a value of two, and the shift instruction has the effect of quadrupling the value of the byte pointer, converting it into a fullword pointer.

The LADC symbol can also be used where machine dependent code must be written within a common mode program. For example:

٠ IFNZ LADC-1 RF,A L RF,B A STRF,A ELSE LM RE,A RF, B+2ΑH ACH RE,B STM RE,A ENDC • •

٠

IF TRUE USE 32 BIT CODE LOAD FULLWORD IN RF ADD FULLWORD B STORE IN A LADC-1 IS FALSE USE 16 BIT LOAD FULLWORD IN RE AND RF ADD LOW ORDER B ADD HIGH ORDER B STORE IN A

shows how fullword addition, requiring double registers in 16-bit assemblies and single registers in 32-bit assemblies, can be handled in a common mode program.

#### 4.7 SPECIAL INSTRUCTIONS

By definition, the instructions load multiple, store multiple, and load PSW, operate on address length data. This is why there are no address operation mnemonics for these instructions. Where these instructions are used in common mode programming, the data on which they operate must be defined by the define address length constant and the define address length storage instructions. For example:

|        | •    |                  |
|--------|------|------------------|
|        | •    |                  |
|        | •    |                  |
|        | LPSW | NEWPSW           |
|        | •    |                  |
|        | •    |                  |
|        | •    |                  |
| START  | STM  | RO, SAVE         |
|        | LM   | RO, PARAM        |
|        | •    |                  |
|        | •    |                  |
|        | •    |                  |
| NEWPSW | DAC  | STATUS, A(START) |
| RSAVE  | DAS  | 16               |
| FARAM  | DAC  | CON1,CON2,       |
|        | •    |                  |
|        | •    |                  |
|        | •    |                  |
|        |      |                  |

List processing instructions operate on address length quantities within the list. There is some incompatibility between the 16and the 32-bit versions of these instructions. The 16-bit list instructions require byte pointers at the head of the list. The 32-bit list instructions require halfword pointers. List instructions can be used in common mode programming as long as the number of slots in the list does not exceed 255. Lists always should be defined with the define list instruction. Use byte instructions where it is necessary to refer to the list pointers in the program. Define displacement into the list pointer fields in terms of the LADC symbol. For example:

|       | •     |              |                   |
|-------|-------|--------------|-------------------|
|       | •     |              |                   |
|       | •     |              |                   |
| SLOTS | EQU   | LADC-1       | . NUMBER OF SLOTS |
| USED  | EQU   | 2*LADC-1     | NUMBER USED       |
| CTOP  | EQU   | 3*LADC-1     | CURRENT TOP       |
| NBOT  | EQU   | 4*LADC-1     | NEXT BOTTOM       |
|       | •     |              |                   |
|       | •     |              |                   |
|       | •     |              |                   |
|       | LΒ    | R1,LIST+CTOP |                   |
|       | •     |              |                   |
|       | •     |              |                   |
|       | •     |              |                   |
| LIST  | DLIST | 32           |                   |
|       | •     |              |                   |
|       | •     |              |                   |
|       | •     |              |                   |

In this example, the load byte instruction is used along with the value of CTOP to access the current top pointer in the list.

#### APPENDIX A COMMON ASSEMBLY LANGUAGE/32 (CAL/32) OPERATING INSTRUCTIONS

The CAL/32 assembler requires a minimum of one lu and up to a maximum of 11 logical units for operation, depending on the options selected and the features invoked by the source program. All of these logical units can be assigned by the user. However, if an lu is needed and not assigned, CAL/32 will allocate temporary system files for logical units 4, 5, 6, 8, 9, 12, and 13. CAL/32 will delete and reallocate permanent files for logical units 2 and 3, provided they were not previously assigned and the DEL start option was specified. The logical units used are:

| LU | USE                                                                                                                                                                                                                                                                                                  | LOGICAL<br>RECORD    | ALLOCATED<br>BY CAL/32 | REQUIRED<br>FOR |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------------|-----------------|
| 1  | Source input device.<br>The source input to be<br>assembled is read from<br>this device on pass<br>one. This device is re-<br>wound prior to each<br>subsequent pass unless<br>BATCH is specified and<br>the source input is not<br>on a random access<br>device, or SCRAT or<br>PPAUS is specified. | 80                   | No                     | All             |
| 2  | Binary output device.<br>Assembled object pro-<br>gram is written to this<br>device on last pass.                                                                                                                                                                                                    | 108 T=16<br>126 T=32 | If DEL<br>specified    | A11             |
| 3  | Assembly listing output<br>device. Assembly list-<br>ing is written to this<br>device on the last pass.                                                                                                                                                                                              | 54 - 132             | If DEL<br>specified    | A11             |
| 4  | Source scratch device.<br>The source input is<br>copied to this device<br>during pass one. The<br>source input is read<br>from this device on all<br>subsequent passes.                                                                                                                              | 80                   | Yes                    | SCRAT<br>BATCH  |

I

| LU | USE                                                                                                                                                                                                                                                 | LOGICAL<br>RECORD | ALLOCATED<br>BY CAL/32 | REQUIRED<br>FOR             |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------------------|-----------------------------|
|    | Symbol cross reference<br>scratch device. Cross<br>reference information<br>is built on this device<br>during the last pass. A<br>device assigned to this<br>lu must support random<br>access.                                                      | 256               | Yes                    | CROSS                       |
| 6  | Symbol table paging<br>device. Symbol table<br>information is paged to<br>this device during all<br>passes. A device<br>assigned to this lu<br>must support random<br>access.                                                                       | 512               | Yes                    | Insuffi-<br>cient<br>memory |
| 7  | Source library input<br>device. Source inform-<br>ation to be included in<br>the main assembly is<br>read from this device<br>on each pass unless<br>SCRAT or BATCH was<br>specified. Then the<br>library is searched and<br>read on pass one only. | 80                | No                     | СОРҮ                        |
| 8  | Forward equate scratch<br>device. This lu can be<br>used if forward refer-<br>enced equates exist in<br>the source input. This<br>device must support<br>random access.                                                                             | 256               | Yes                    | Forward<br>equates          |
| 9  | Error tabulation device.<br>Error messages and<br>their associated line<br>numbers are written in<br>binary to this device<br>during the last pass<br>and written to lu 3<br>after completion of the<br>assembly and symbol<br>table listing.       | 80                | Yes                    | ERLST                       |

1

| LU<br>LU         | USE                                                                                       |  | LOGICAL<br>RECORD | 1 | ALLOCATED  <br>BY CAL/32 | KEQUIRED<br>FOR |
|------------------|-------------------------------------------------------------------------------------------|--|-------------------|---|--------------------------|-----------------|
| 12               | PCB file directory<br>  scratch device. This<br>  device must support<br>  random access. |  | 256               |   | Yes                      | CLIB            |
| 13<br> <br> <br> | PCB name directory<br>scratch device. This<br>device must support<br>random access.       |  | 256               |   | Yes                      | СОРҮ            |

When an assembly terminates, an end of task code is passed to the operating system in the operand field of the SVC 3 instruction. The meanings of the possible end of task codes are:

| E   | N | D OF |
|-----|---|------|
| TAS | K | CODE |

#### MEANING

- 0 Assembly complete without errors.
- 1 Illegal option passed with the START command. Assembly is aborted after logging the illegal options to the console. The user should retry.
- 2 One or more errors detected during the assembly. This end of task code is also used if errors are detected in one or more programs of a batch assembly.
- 3 Misplaced BEND.
- 4 Symbol table overflow.

I

L

When operating under OS/32, CAL/32 accepts certain control options as arguments of the START command. Any combination of spaces and/or commas can separate or follow the options specification:

| START            |                                             |
|------------------|---------------------------------------------|
| OPTION           | OPERANDS                                    |
|                  |                                             |
| PPAIIS           | None                                        |
| CROSS            | None                                        |
| NLIST            | None                                        |
| NORYT            | None (alias for NORY3)                      |
| SOUEZ            | Number of passes (1-99)                     |
| SOCHK            | None                                        |
| SCRAT            | None                                        |
| TARCT            | 16 or 32                                    |
| WT DTH           | Width of listing                            |
|                  | Lines per page (10-99)                      |
| ERLST            | None                                        |
| ERSOZ            | None                                        |
| NISTC            | None                                        |
| CAL              | None                                        |
| NLSTM            | None                                        |
| BATCH            | None                                        |
| FREZE            | None                                        |
| NDISK            | None (inhibits symbol table paging to disk) |
| NFIX             | None (prevents CAL/32 from making           |
| <u> </u>         | extra passes to fix squeeze-induced errors) |
| DEL              | None                                        |
| LIST             | None                                        |
| LSTC             | None                                        |
| LSTM             | None                                        |
| <u>lstu</u> r    | None                                        |
| <u>ur</u> ex     | None                                        |
| <u>W A</u> R N   | None                                        |
| <u>NC</u> ROS    | None                                        |
| <u>nd</u> el     | None                                        |
| <u>n f</u> rez   | None                                        |
| NLSTU            | None                                        |
| NOCAL            | None                                        |
| NOSOZ            | None                                        |
| NUSEQ            | None                                        |
| NUREX            | None                                        |
| <u>N W</u> A R N | None                                        |
| <u>NO</u> RX3    | None                                        |

| Start options have the following form:

| option [=operand]

L

A typical start command for a CAL/32 assembly with start options is:

#### ST , DEL, SQUEZ=99, NCROSS

The delete start options (DEL, NDEL) enable or disable CAL/32 from deleting and reallocating object and listing files when needed. If the DEL option is in effect and lu 2 and lu 3 are unassigned, CAL/32 will delete, reallocate, and assign them to fname.OBJ and fname.LST, respectively. The default option is NDFL, in which case CAL/32 will simply log an 8100 error to the console and pause. In the event that lu 1 is not assigned to a direct access device, the DEL option will have no effect, and CAL/32 will issue an 8100 error before pausing.

When CAL/32 encounters conflicting start options such as CROSS and NCROS, it will regard the last option encountered as the intended option. This allows the user to redefine the default start options via CSS. For example:

LO CAL32 AS 1,SOURCE.CAL ST ,NCROSS DEL @1 \$EXIT

The above CSS effectively changes the default options to NCROSS and delete unless overridden by the parameter 21.

#### **OPERATING INSTRUCTIONS FOR OS/32**

CAL/32 will not run on a 16-bit machine, however it will still produce 16-bit object code if reguested.

Before using CAL/32 under OS/32, the relocatable object supplied must be established as an OS/32 task, using Link. A typical command sequence using Link to establish CAL/32 is:

LO .BG,LINK T .BG ST >ES TA >OP work=5000, SYS=FFFFF, SEG,ROL >IN CAL32 >BU CAL32 >END I

CAL/32 is segmented into pure and impure code for shared use with OS/32 systems that support this capability. To establish CAL/32 as a nonsharable task, remove the SEG option from the above command sequence. TET can be used instead of Link provided the source does not contain any of the following instructions: external with offset, DNTRY, WNTRY, WXTRN, INCLD, DCMD.

A typical command sequence to establish CAL/32 using TET is: 1

> LO .BG, TET 32 Load TET32 AS 5,CON: Assign interactive device AS 7, CON: AL TETSCRT, IN Allocate and assign scratch AS 4, TETSCET ST ES TA Establish task command IN CAL32.OBJ Read CAL/32 object EXP 80 Get 20kb for symbol table Build CAL/32 task BU TA, CAL/32 MAP PR: Obtain map END

The established CAL/32 task can then be loaded with the LOAD command and devices or files assigned as required. For example:

LO .BG, CAL32 T .BG AS 1, PROGRAM.CAL, SRO Scurce input UEZ Assign listing device UEZ Start assembly AS 3, PR: ST , DEL, SQUEZ

When assembly is completed, CAL/32 terminates through the operating system, which logs the message:

END OF TASK n

where n is the end of task code.

The files used for scratch, cross reference, paging, forward equates, PCB file directory, PCB name directory, and error summary will be allocated by CAL/32 as temporary operating system files if they are needed and were not previously assigned by the 1 user. 1

A-6

1

ł

1

I

1

### APPENDIX B COMMON ASSEMBLY LANGUAGE/32 (CAL/32) ERROR CODES

| A 0 0 1 | the address               | The address is out of range for the specified instruction format.                                                                               |
|---------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| A 00 2  | the address               | The address is out of range for an RX2 instruction.                                                                                             |
| 8003    | the operand               | The operand of a previously squeezed<br>instruction was changed making the<br>squeezed instruction invalid.                                     |
| B 0 0 1 | alignment                 | The address of the operand is on an incorrect boundary for the instruction specified.                                                           |
| B002    | alignment                 | An odd address used in a T constant<br>location counter was not even when<br>the instruction was specified.                                     |
| C001    | common mode               | An opcode that is not part of the<br>common mode set is used in a common<br>mode assembly.                                                      |
| D001    | data structure            | An illegal statement appears in a STRUC or COMN definition.                                                                                     |
| E001    | END placement             | An END statement was encountered<br>within a STRUC or COMN definition or<br>within an unterminated conditional.                                 |
| F001    | missing operand           |                                                                                                                                                 |
| F002    | register<br>specification | A register value is not in the<br>range of 0 to 15, or an odd register<br>value is used where an even value is<br>required.                     |
| F003    | invalid source<br>field   | Invalid label in the source field,<br>a label in the name field is not<br>followed by a space, or a required<br>label is missing; e.g., on EQU. |
| F004    | invalid symbol            | More than 8 characters were specified in a symbol.                                                                                              |

- An invalid type for EXTRN; e.g., FOO5 EXTRN common block, or EXTRN was used in an expression. The value of data is too large to F006 immediate field fit into the immediate field. A fullword EXTRN is used in RI1 instruction. A character string
- FOO7 ENTRY A symbol declared as an ENTRY is undefined. Improper type for ENTRY; e.g., common block name.

long.

- F008 delimiter Operands are not separated by commas. Unrecognizable operator. The last operand is not followed by a CR or a blank. Unbalanced parentheses. Opcode is not followed by a space or a CR.
- F009 invalid expression Expression uses common element names not in the same block.
- F010 apostrophe No ending apostrophe in C,D,E,F, H,P,U,X, or Y constant. Illegal character encountered in C, D, E, F, H, P, U, X, or Y constant prior to the ending apostrophe.
- F011 invalid operand T constant was specified in TARGT 16 assembly. Argument mode of T constant is not ABS, PURE, or IMPURE. Illegal data specified in BDATA program. Fullword EXTRN used as an operand of DCZ. Value of DB operand must be absolute. Value of DS, DSF, DSH. Invalid symbol used for ENTRY name. Symbol used as ENTRY must be ABS, PURE, IMPURE, or Relocatable. Invalid symbol used for EXTRN name. Invalid data in BORG. Operand of CNOP or ALIGN is not absolute. Operand of DLIST is not absolute.

Improper type for EXTRN operand; e.g., common block name. Transfer address on END statement is an improper type; e.g., EXTRN. Illegal operand on EQU.

used as an immediate field is too

F012 improper statement Label only

| F013 | file descriptor            | Syntax error on fd of a COPY, FCOPY,<br>or CLIB statement                                                                                                                                                                                                                          |
|------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F014 | missing string             | No characters between apostrophes of C,E,D,F,H,P,U,X or Y constant                                                                                                                                                                                                                 |
| F015 | invalid character          | Illegal character encountered<br>between apostrophes of an E or D<br>constant.                                                                                                                                                                                                     |
| I001 | conditional                | An ELSE or ENDC statement found<br>without a matching IFx                                                                                                                                                                                                                          |
| ₩001 | symbol definition          | The symbol in the name field is also<br>used in the name field of another<br>statement. The value or type of a<br>symbol changed from its definition<br>on a previous pass. (This can occur<br>by illegal use of conditionals, ORG,<br>DO, DS, or a misplaced SCRAT<br>statement.) |
| M002 | symbol definition          | An attempt was made to redefine a<br>symbol with an EQU that is the name<br>field of a statement.                                                                                                                                                                                  |
| 0001 | illegal opcode             | The opcode used is totally<br>unrecognizable or illegal for the<br>specified TARGT.                                                                                                                                                                                                |
| P001 | location counter           | The location counter exceeded 216 on<br>a TARGT-16 or 224 on a TARGT-32<br>assembly.                                                                                                                                                                                               |
| P002 | reentrancy check           | The instruction attempts to modify<br>PURE code.                                                                                                                                                                                                                                   |
| R001 | relocation error           | An invalid combination of<br>relocatable terms in an expression.<br>A relocatable operand follows a<br>unary minus.                                                                                                                                                                |
| S001 | sequence check             | The value in the sequence numbers<br>field is not greater than the<br>previous sequence number.                                                                                                                                                                                    |
| S002 | СОРҮ                       | COPY statement appears within a file<br>being copied. An invalid symbol<br>used as COPY operand. The operand<br>of CCPY is not followed by a space,<br>comma, or CR.                                                                                                               |
| S003 | invalid option<br>sequence | A COPY, PAUSE, MSG, or DO<br>statement immediately follows a DO<br>statement.                                                                                                                                                                                                      |

48-050 F00 R00

B **- 3** 

• :

| 1    | S004    | in <b>v</b> alid option | An argument is not absolute or<br>exceeds 32767. An argument of LCNT<br>is in the range of 10 to 99. An<br>argument of WIDTH is not in the<br>range of 64 to 132. An argument of<br>TARGT does not evaluate to either 16<br>or 32. An argument of SQUEZ is not<br>in the range of 1 to 99. |
|------|---------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | S005    | PROG                    | Multiple PROG statements were encountered in a program.                                                                                                                                                                                                                                    |
|      | T 00 1  | overflow                | The intermediate or final result of<br>an arithmetic expression exceeded<br>231 - 1.                                                                                                                                                                                                       |
|      | T 0 0 2 | floating point          | An overflow occurred during<br>conversion of floating point<br>constant.                                                                                                                                                                                                                   |
|      | T003    | value                   | The data item exceeds the range for specified type; e.g., X'12345'.                                                                                                                                                                                                                        |
|      | T004    | divisor                 | A division by 0 is attempted.                                                                                                                                                                                                                                                              |
| 1    | U001    | not used                |                                                                                                                                                                                                                                                                                            |
|      | U 0 0 2 | undefined symbol        | A referenced symbol is not defined<br>in the program.                                                                                                                                                                                                                                      |
|      | U 0 0 3 | undefined symbol        | An attempt was made to circularly define a symbol; e.g.:                                                                                                                                                                                                                                   |
| <br> |         |                         | A EQU B<br>B EQU A                                                                                                                                                                                                                                                                         |
| <br> | UOO 4   |                         | File specified as an operand of FCOPY, CLIB, or COPY does not exist.                                                                                                                                                                                                                       |
| 1    | U005    |                         | Program name is not found in any of the PCB libraries.                                                                                                                                                                                                                                     |

#### APPENDIX C PERKIN-ELMER OBJECT CODE FORMAT

Modules in Perkin-Elmer object code format produced by CAL/32 are divided into records. Each record contains 126 bytes of information for 32-bit object code, or 108 bytes of information for 16-bit object code. The first 4 bytes of each record of the object code format are organized as follows:

|       |          | 4        |            |    | 4       |    |
|-------|----------|----------|------------|----|---------|----|
| 1     | Sequence | number   | <u> </u>   |    | Checksu | m  |
| Bits: |          | <i>y</i> |            |    |         |    |
| 0     |          |          | <b>1</b> 5 | 16 |         | 31 |

The sequence numbers are sequential negative integers -1, -2, -3, etc., represented in two's complement form. The first record in a program must have sequence number -1. Subsequent records must be in proper order to be loaded.

The checksum is an exclusive OR sum of all halfwords in the record, except itself, plus a halfword of all 1's.

The remainder of the record is a sequence of items; an item is a byte of loader information. There are two types of items--loader items and data items. Each loader item is followed by a certain number (which can be 0) of data items. The loader items and their meanings are listed in Tables C-1 and C-2.

## TABLE C-1 32-BIT LOADER ITEM DEFINITIONS

| LOADER<br>ITEM | MEANING                      | NUMBER OF DATA<br>ITEMS FOLLOWING |
|----------------|------------------------------|-----------------------------------|
| =========      |                              |                                   |
| 0              | End of record                | None                              |
| 1              | End of program               | None                              |
| 2              | Reset sequence number        | None                              |
| 3              | Block data indicator         | 8-byte name,                      |
|                |                              | 3-byte displacement,              |
|                |                              | any absolute data                 |
|                |                              | item (20-5B)                      |
| 4              | Absolute program address     | 3-byte address                    |
| 5              | Pure relocatable program     | 3-byte address                    |
| i              | address                      | • • • • • • • • •                 |
| 6              | Impure relocatable program   | 3-byte address                    |
| -              | address                      |                                   |
| 7              | 2 bytes of pure relocatable  | 2-bvte address                    |
|                | data                         |                                   |
| 8              | 2 bytes of impure            | 2-byte address                    |
| C              | relocatable data             |                                   |
| q              | 4 hytes of pure relocatable  | 4-byte address                    |
| 2              | data                         | - bles adaress                    |
| Δ              | l li hytes of impure         | l lebyte address                  |
|                | relocatable data             | - Plee address                    |
| P              | Common reference             | Rebuto addrogg                    |
| 1.             | Common reletence             | 3-byte displacement               |
| C              | ניעת סא                      | S-byte displacement               |
| C              | <b>EVT</b> UN                | l o-byte name, for-               |
|                |                              | Lowed by item 4,                  |
| л              | דייתראיי                     |                                   |
| D              | ENIRI                        | 8-byte name ror-                  |
|                |                              | lowed by item 4,                  |
| T              |                              | 5, OF 6                           |
| Ł              | Common definition            | 8-byte name fol-                  |
|                |                              | lowed by a 3 byte                 |
| -              |                              | length                            |
| E              | Program label                | 8-character name                  |
| 10             | 3 bytes absolute and 3       | 6 bytes                           |
|                | bytes pure relocatable       |                                   |
| 11             | 3 bytes absolute and 3       | 6 bytes                           |
|                | bytes impure relocatable     |                                   |
| 12             | Load program transfer        | Item 4, 5, or 6                   |
| 13             | Define start of chain        | Item 4, 5, or 6                   |
|                | (reference)                  |                                   |
| 14             | Load chain definition        | Item 4, 5, or 6                   |
|                | address                      |                                   |
| 15             | 2 bytes absolute and 2 bytes | 4 bytes                           |
|                | pure relocatable             |                                   |
| 16             | 2 bytes absolute and 2 bytes | 4 bytes                           |
| !              | impure relocatable           |                                   |

1

## TABLE C-1 32-BIT LOADER ITEM DEFINITIONS (Continued)

| LOADER<br>ITEM | MEANING                                    | NUMBER OF DATA<br>ITEMS FOLLOWING |
|----------------|--------------------------------------------|-----------------------------------|
| 17             | Short form EXTRN                           | 1 8-byte name and                 |
|                |                                            | 1 Item 4, 5, or 6                 |
| 18             | Length of impure and pure                  | 3-byte impure length              |
| İ              | segments                                   | and 3-byte pure                   |
|                |                                            | length                            |
| 19             | Perform fullword chain                     | None                              |
| 1A             | Perform halfword chain                     | None                              |
| 1 E            | No operation                               | None                              |
| 1 C            | 2-byte pure translation                    | 2 bytes                           |
|                | table address                              | 1                                 |
| 1D<br>         | 2-byte impure translation<br>table address | 2 bytes  <br>                     |
| 1 E            | Not used                                   | N/A                               |
| 1F             | 1 byte absolute data                       | 1 byte                            |
| 20             | 2 bytes absolute data                      | 2 bytes                           |
| 21             | 4 bytes absolute data                      | 4 bytes                           |
| 22             | 6 bytes absolute data                      | 6 bytes                           |
| 23             | 8 bytes absolute data                      | 8 bytes                           |
| <b>i</b> •     | •                                          | •                                 |
| •              | •                                          | •                                 |
|                |                                            | • 100 but an                      |
|                | 120 bytes absolute data                    | 120 bytes                         |
|                | Future use                                 |                                   |
| 05             | Excended EXIAN LETELENCE                   | I symbol name                     |
| 1              |                                            | 1 1-byte flag                     |
| 1              |                                            | xxxx xx00 standard                |
| 1              |                                            | EXTRN                             |
| 1              |                                            | EXTRN                             |
| ł<br>          |                                            | EXTRN                             |
|                |                                            | 4-byte offset                     |
|                |                                            | Item 4, 5, or 6                   |
| 66             | Extended entry                             | 8-byte entry symbol               |
| 1              |                                            | 1-byte flag                       |
| 1              |                                            | XXXX XXUU Standard                |
| 1              | 1                                          | entry                             |
| 1              | 1                                          | AXXX XXVI Udid                    |
| 1              | 1                                          | I YYYY YY10 Week                  |
| 1              | 1                                          | A A A A V WEAR                    |
| 1              | 1                                          | 1 Ttem 4, 5, or 6                 |
| 67             | l Link commands                            | 1 1-byte length                   |
| 1 07           |                                            | 1 1-80 characters                 |
|                | 1                                          | of command                        |
| 1              |                                            |                                   |
|                |                                            |                                   |

48-050 FOO 800

C-3

I

#### TABLE C-2 16-BIT LOADER ITEM DEFINITIONS

| LOADER<br>ITEM                          | MEANING                               | NUMBER OF DATA<br>ITEMS FOLLOWING |
|-----------------------------------------|---------------------------------------|-----------------------------------|
| ======================================= | = = = = = = = = = = = = = = = = = = = |                                   |
| 0                                       | End of record                         | None                              |
| 1                                       | End of program                        | None                              |
| 2                                       | Perform chain                         | None                              |
| 3                                       | Toggle absolute/relocatable  <br>mode | None                              |
| 4                                       | Transfer address                      | 2-byte address                    |
| 5                                       | Load program address (ORG)            | 2-byte address                    |
| 6                                       | Load reference address                | 2-byte address                    |
| 7                                       | Load definition value                 | 2-byte address                    |
| 8                                       | 2 bytes absolute data                 | 2 bytes data                      |
| 9                                       | 2 bytes relocatable data              | 2 bytes data                      |
| A                                       | 4 bytes absolute data                 | 4 bytes data                      |
| В                                       | 2 bytes absolute and 2 bytes          | 4 bytes data                      |
| 0                                       | relocatable data                      |                                   |
| C                                       | EXTRN reference                       | o-byte name                       |
| D<br>F                                  | ENTRY definition                      | b-byte name                       |
| E<br>E                                  | Decode next item                      | Next item                         |
| Ю.<br>Ю                                 | Declare common block                  | b-byte name                       |
| F 4                                     | I Joad common block                   | 6-byte size                       |
| E                                       | definition value                      | 2-byte name                       |
| т.Э.                                    | 2 bytes absolute block data           | 2-byte offset                     |
| r∠                                      | 2 DYTES ADSOLUTE DIOCK data           | Debyte name                       |
|                                         |                                       | 2 bytes data                      |
| τэ                                      | <br>  // hytog shgolyto block doto    | 6-byte name                       |
| EJ                                      | I A NALES UNSOTATE NTOCK AGIG         | Debyte name<br>Debyte offect      |
|                                         |                                       | L 2 Drie Olisei                   |
| F /1                                    | <br>  Posot soguonco numbor to -1     | I 4 DYLES UALA<br>I Nono          |
| £4<br>TE                                | I i hyto shooluto data                | 1 huto data                       |
|                                         | 1 1 byte absolute data                | i byte uata                       |
| ro                                      | I I DACE ADSOUTCE DIOCK data          | J-byte Hame                       |
|                                         |                                       | 2-Dyte offset                     |
| P                                       |                                       | L DYTE UATA                       |
| Ľ                                       | Program label                         | o-byte name                       |

All items are given in hexadecimal. Note that item E is actually a compound item whose interpretation depends on the item it follows. Item E and the following item are considered a single control item, however, and cannot be split across object records. This effectively allows more than 16 different control items, though most of them require only 1 nibble. INDEX

| A                               |         | ERSQZ                       | 3-53  |
|---------------------------------|---------|-----------------------------|-------|
|                                 | o       | EXTRN                       | 3-25  |
| Absolute (ABS) instruction      | 3-45    | FCOPY                       | 3-49  |
| Adsolute programs               | 1-4     | FREZE                       | 3-67  |
| ADSOLUTE QUANTITLES             | 2-2     |                             | 3-60  |
| ABSTUP                          | 2-5     |                             | 3-56  |
| Address length                  | 2-5     |                             | 3-44  |
| Address length constant (ALC)   | 2-5     |                             | 3-21  |
|                                 | 4-6     |                             | 3-00  |
| Address operation instructions, | <i></i> |                             | 3-67  |
| address operations              | 4-1     |                             | 3-6/  |
| assembler                       | 4-3     |                             | 3-67  |
| Immediate operations            | 4-3     |                             | 3-5/  |
| Align (ALIGN) instruction       | 3-45    |                             | 3-55  |
| Alignment,                      | <i></i> |                             | 3-0/  |
| ADC, effect on (                | 4-6     |                             | 3-0/  |
| CNUP, effect on                 | 3-46    |                             | 3-0/  |
| Arithmetic expressions          | 2-1     |                             | 3-07  |
| Arithmetic operators            | 2-1     | NICTU                       | 3-0/  |
| Assembler control instructions  | 3-46    |                             | 3-67  |
| <b>a i a i i i i i</b>          | 4-5     |                             | 3-53  |
| Assembler instructions,         |         | NOSEQ NOSEQ                 | 3-54  |
| ABS                             | 3-45    | NUSUZ                       | 3-53  |
| ALIGN                           | 3-45    | NUREX                       | 3-50  |
| BATCH                           | 3-55    |                             | 3-6/  |
| BDATA                           | 3-64    |                             | 3-44  |
| BEND                            | 3-55    | PAUSE                       | 3-49  |
| EORG                            | 3-64    | PPAUS                       | 3-54  |
| CLIB                            | 3-48    |                             | 3-65  |
| CNUP                            | 3-46    |                             | 3-43  |
| CCMN                            | 3-61    | I reserved storage          | 3-21  |
| CUPY                            | 3-48    | SURAL                       | 3-54  |
| CRUSS                           | 3-67    | SPACE                       | 3-00  |
|                                 | 4-4     |                             | 3-54  |
|                                 | 4-4     |                             | 3-50  |
|                                 | 3-41    |                             | 3-01  |
|                                 | 3-30    |                             | 3-47  |
|                                 | 3-30    |                             | 3-00  |
|                                 | 3-43    |                             | 3-50  |
|                                 | 3-42    |                             | 3-67  |
|                                 | 3-25    |                             | 3-00  |
|                                 | 3-00    |                             | 3-25  |
| D2                              | 3-28    | Alon<br>Accombly lighting   | 3-23  |
|                                 | 3-28    | Assembly listing            | 3-05  |
|                                 | 3-28    | ksterisk, úsed as operand   | 2-0   |
|                                 | 3-00    |                             |       |
| ELSE                            | 3-20    |                             |       |
|                                 | 3-47    | D                           |       |
|                                 | 3-61    | Batch accombly inctructions |       |
| LULD<br>LULD                    | 3-05    | BATCH                       | 3- 55 |
| 501<br>501                      | 3-23    |                             | 3-55  |
| <u>грист</u>                    | 3-67    |                             | 3-55  |
| EVISI                           | 10-6    |                             | 3-30  |
|                                 |         |                             |       |

Ind-1

| Batch end (BEND) instruction   | 3-56 |
|--------------------------------|------|
| Batch (BATCH) instruction      | 3-55 |
|                                | 3-56 |
| Binary language symbols,       |      |
| absolute values                | 2-1  |
| addresses                      | 2-1  |
| constants                      | 2-1  |
| operation identifiers          | 2-1  |
| register identifiers           | 2-1  |
| Block data (BDATA) instruction | 3-64 |
| Branch and link instructions   | 1-15 |

# С

| CAI/32 instructions             | 4-5          |
|---------------------------------|--------------|
| Central processing unit (CFU),  |              |
| I/C interface                   | 1-1          |
| local memory                    | 1-1          |
| PSW                             | 1-1          |
| registers                       | 1 - 1        |
| Character symbols               | 2-4          |
| Comment statements,             |              |
| nonprintable characters         | 3-1          |
| printable characters            | 3-1/         |
| Common blocks                   | 3-61         |
| Common (COMN) instruction       | 3-61         |
| Common mode programming         | 4-1          |
| Compound conditional            |              |
| instructions,                   |              |
| ELSE                            | 3-56         |
| ENCC                            | 3-56         |
| IFx                             | 3-56         |
| Condition code                  | 1-2          |
| Conditional assembly            |              |
| instructions                    | 3-56         |
| Conditional branch instructions | 1-15         |
| Conditional no operation (CNOP) |              |
| instruction                     | 3-46         |
| Content control instructions,   |              |
| CRCSS                           | 3-67         |
| ERLST                           | 3-67         |
| FREZE                           | 3-67         |
| LIST                            | 3-67         |
| LSTC                            | 3-67         |
| LSTM                            | 3-67         |
| LSTUR                           | 3-67         |
| NCROS                           | 3-67         |
| NFREZ                           | 3-67         |
| NLIST                           | 3-67         |
| NLSTC                           | 3-67         |
| NLSTM                           | 3-67         |
| NLSTU                           | 3-67         |
| N W A R N                       | 3-67         |
| WARN                            | 3-67         |
| Constant                        | 2-5          |
| Constants,                      |              |
| address                         | 3-35         |
| character                       | <b>3-</b> 38 |
| decimal string                  | 3-38         |
| double precision floating       |              |
| point                           | 3-37         |
| hexadecimal,                    |              |
| DCX                             | 3-32         |
| DCY                             | 3-32         |
| integer,                        |              |
| fullword                        | 5-23         |
| naltword                        | 5-55         |
| internal representation         | 5-55         |

| length                    | 3-34 |
|---------------------------|------|
| packed decimal string     | 3-38 |
| single precision floating |      |
| point                     | 3-37 |
| unpacked decimal string   | 3-38 |
| Constant types            | 3-31 |
| Copy (CCPY) instruction   | 3-48 |
| Copy (CLIB) library       |      |
| instruction               | 3-48 |
| Cross reference (CRCSS)   |      |
| instruction               | 3-68 |

# D

| Data definition instructions,   |       |
|---------------------------------|-------|
| DAC                             | 4-4   |
| DAS                             | 4 – 4 |
| DC                              | 3-30  |
| DCF                             | 3-30  |
| DS                              | 3-28  |
| DSF                             | 3-28  |
| DSH                             | 3-28  |
| Data structures                 | 3-61  |
| Decimal symbols                 | 2-2   |
| Define address length constant  |       |
| (DAC) instruction               | 4-4   |
|                                 | 4-8   |
| Define address length stcrage   |       |
| (DAS) instruction               | 4-4   |
| Define byte (DB) instruction    | 3-41  |
| Define command (DCMD)           |       |
| instruction                     | 3-43  |
| Define list (DLIST) instruction | 3-42  |
| Define storage (DS) instruction | 3-63  |
| DEL                             | A-5   |
| Delete start options            | A-5   |
| DCF instruction                 | 3-34  |
| DCX instruction                 | 3-32  |
| DCY instruction                 | 3-33  |
| DNTRY instruction               | 3-25  |
| Do (DO) instruction             | 3-60  |

## Ε

| Eject (EJECT) instruction      | 3-66 |
|--------------------------------|------|
| ELSE instruction               | 3-57 |
| End condition (ENDC)           |      |
| instruction                    | 3-57 |
| End (END) instruction          | 3-47 |
| End of task codes              | A-3  |
| End structure (ENDS)           |      |
| instruction                    | 3-61 |
| ENTRY instruction              | 3-25 |
| Equate instruction             | 3-63 |
| Errcr codes                    | E-1  |
| Error list (ERLST) instruction | 3-68 |
| Error squeeze (FRSQZ)          |      |
| instruction                    | 3-53 |
| Extended branch mnemonics      | 3-19 |
| EXTRN instruction              | 3-25 |

F

ł

| Fields,   |     |
|-----------|-----|
| name      | 3-3 |
| operand   | 3-5 |
| operation | 3-4 |

| File copy (FCCPY) instruction | 3-49 |
|-------------------------------|------|
| Format control instructions,  |      |
| EJECT                         | 3-66 |
| LCNT                          | 3-66 |
| SPACE                         | 3-66 |
| WIDTH                         | 3-66 |
| Freeze (FREZE) instruction    | 3-68 |

# G

| Global symbols, |              |
|-----------------|--------------|
| ABSTCP          | 2-5          |
| ADC             | 2 <b>-</b> 5 |
|                 | 4-6          |
| IMPTCP          | 2-5          |
| LADC            | 2-5          |
|                 | 4-6          |
| PURETOP         | 2-5          |
|                 |              |

#### Н

| Hexadecimal sym | abols | 2-4 |
|-----------------|-------|-----|
|-----------------|-------|-----|

## IJK

| Implicit symbols            | 2-3   |
|-----------------------------|-------|
| Impure (IMPUR) instruction  | 2-3   |
| Impure segments             | 1-4   |
| Include (INCLD) instruction | 3-27  |
| Instruction statements,     |       |
| fixed format                | 3-2   |
| free format                 | 3-2   |
| Instructions,               |       |
| address crerations, common  |       |
| mode                        | 4-1   |
| assembler                   | 3-21  |
| assembler, common mode      | 4-3   |
| immediate operations,       |       |
| common mode                 | 4-3   |
| operating                   | A - 1 |
| 16-bit machine              | 1-5   |
|                             | 3-10  |
| 32-bit machine              | 1-7   |
|                             | 3-10  |
| Integer constants,          |       |
| fullword                    | 3-33  |
| halfword                    | 3-33  |
| internal representation     | 3-33  |
| I/C interface               | 1-1   |

### L

| LADC                          | 2-5  |
|-------------------------------|------|
| Line count (LCNT) instruction | 3-66 |
| Linked list structures        | 3-63 |
| List conditionals (LSTC)      |      |
| instruction                   | 3-67 |
| Listing control instructions  | 3-65 |
| Listing identification        |      |
| instructions,                 |      |
| FROG                          | 3-65 |
| TITLE                         | 3-65 |
|                               |      |

| List (LIST) instruction       | 3-67 |
|-------------------------------|------|
| List macro (LSTM) instruction | 3-68 |
| List unreferenced symbols     |      |
| (LSTUR) instruction           | 3-68 |
| Load multiple instruction     | 4-8  |
| Load PSW instruction          | 4-8  |
| Local memory (registers)      | 1-2  |
| double precision floating     |      |
| point                         | 1-2  |
| general purpose               | 1-2  |
| single precision floating     |      |
| pcint                         | 1-2  |
| Location counter,             |      |
| absolute                      | 3-43 |
| impure                        | 3-43 |
| pure                          | 3-43 |
| Logical expressions           | 2-2  |
|                               |      |

## M

| Machine instructions,     |      |
|---------------------------|------|
| mnemonics                 | 3-10 |
| Main memory               | 1-1  |
| Message (MSG) instruction | 3-55 |
| Mixed expressions         | 2-2  |
| Mixed mode computations   | 4-5  |

### N

| Name field                     | 3-3  |
|--------------------------------|------|
| NDEL                           | A-5  |
| NOCAL/32 instruction           | 4-5  |
| No cross (NCROS) instruction   | 3-68 |
| No freeze (NFREZ) instruction  | 3-68 |
| No list conditionals (NLSTC)   |      |
| instruction                    | 3-67 |
| No list (NLIST) instruction    | 3-67 |
| No list macro (NLSTM)          |      |
| instruction                    | 3-68 |
| No list unreferenced symbols   |      |
| (NLSTU) instruction            | 3-68 |
| No RX3 (NORX3) instruction     | 3-53 |
| No sequence check instruction  | 3-54 |
| No squeeze (NOSQZ) instruction | 3-53 |
| No warning (NWARN) instruction | 3-68 |

### 0

| Object code formats      | C-1   |
|--------------------------|-------|
| Operand fields, rules    | 3-5   |
| Operating instructions   | A- 1  |
| for OS/32                | A - 5 |
| Operation fields,        |       |
| mnemonics                | 3-4   |
| restrictions             | 3-4   |
| Optimization mode        | 3-50  |
| Crigin (ORG) instruction | 3-44  |
|                          | 3-63  |
|                          |       |

### ΡQ

1

| Pass pause  | (PPAUS)  | instruction | 3-54 |
|-------------|----------|-------------|------|
| Pause (PAUS | E) instr | ruction     | 3-49 |
| Program (PF | OG) inst | truction    | 3-65 |

. .....

| Program segmentation<br>Program status word (PSW),<br>condition code<br>location counter<br>status descriptor<br>Pure (PURE) instruction<br>Pure segments<br>FURETCP<br>R | 1-4<br>1-2<br>1-2<br>3-43<br>1-4<br>2-5 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
|                                                                                                                                                                           |                                         |
| Register and immediate (RI)                                                                                                                                               | 1-5                                     |
| Register and immediate one                                                                                                                                                | 57                                      |
| (RIT)<br>Register and immediate two                                                                                                                                       | 1-10                                    |
| (RI2)<br>Register and indexed storage                                                                                                                                     | 1-11                                    |
| (RX)                                                                                                                                                                      | 1-6                                     |
| Register and indexed storage/                                                                                                                                             | 3-0                                     |
| register and indexed stcrage<br>(PXRX)                                                                                                                                    | 1-12                                    |
| Posistor and indexed starses                                                                                                                                              | 3-8                                     |
| one (RX1)                                                                                                                                                                 | 1-8                                     |
| Register and indexed storage two (RX2)                                                                                                                                    | 1-9                                     |
| Register and indexed storage                                                                                                                                              | 1-10                                    |
| Registers,                                                                                                                                                                | 1 10                                    |
| couble precision floating point                                                                                                                                           | 1-2                                     |
| general purpose<br>single precision floating                                                                                                                              | 1-2                                     |
| point<br>Register-to-register (PP)                                                                                                                                        | 1-2                                     |
| Register to register (RR)                                                                                                                                                 | 1-5                                     |
| Relocatable programs                                                                                                                                                      | 3-5<br>1-4                              |
| Relocatable guantities                                                                                                                                                    | 2-2                                     |
| S                                                                                                                                                                         |                                         |
| Scratch (SCRAT) instruction                                                                                                                                               | 3-54                                    |
| Sequence check (SQCHK)<br>instruction                                                                                                                                     | 3-54                                    |
| Short form (SF) instruction                                                                                                                                               | 1-7                                     |
| Simple if (IF) instruction                                                                                                                                                | 3-60                                    |
| 16-bit machine instructions,<br>register and immediate (RI)                                                                                                               | <b>1-</b> 5                             |
| register and indexed<br>storage (RX)                                                                                                                                      | 1-5                                     |
| register-to-register (RR)                                                                                                                                                 | 1-5                                     |
| Snort form (Sr)<br>Source program,                                                                                                                                        | 1-5                                     |
| comment statements<br>instruction statements                                                                                                                              | 3-1<br>3-1                              |
| Space (SPACE) instruction                                                                                                                                                 | 3-66                                    |
| NOSEQ                                                                                                                                                                     | 3-54                                    |
| SUCHK<br>Squeeze (SQUEZ) instruction                                                                                                                                      | 3-54<br>3-50                            |
| Squeeze related instructions,<br>ERSOZ                                                                                                                                    | 3-53                                    |
| NOSQZ<br>NCRX3                                                                                                                                                            | 3-53                                    |
|                                                                                                                                                                           |                                         |

| Start option                   | A - 4 |
|--------------------------------|-------|
| Statements,                    |       |
| comment                        | 3-1   |
| instruction                    | 3-2   |
| Status descriptor              | 1-2   |
| Store multiple instruction     | 4-8   |
| Structure definition           |       |
| instructions,                  |       |
| COMN                           | 3-61  |
| ENDS                           | 3-61  |
| STRUC                          | 3-61  |
| Structure initialization       |       |
| instructions,                  |       |
| BDATA                          | 3-64  |
| EORG                           | 3~64  |
| Structure (SIRUC) instruction  | 3-61  |
| Symbol definition instructions | 3-21  |
| Symbolic representation        | 2-1   |
| Symbols,                       |       |
| character                      | 2-4   |
| decimal                        | 2-2   |
| fullword                       | 2-4   |
| global                         | 2-3   |
|                                | 2-5   |
| halfword                       | 2-4   |
| hexadecimal                    | 2-4   |
| implicit                       | 2-3   |
| System architecture,           | - •   |
| CPU                            | 1-1   |
| main memory                    | 1-1   |
| -                              | • •   |

#### Т

| Target (TAPGI) instruction   | 3-47 |
|------------------------------|------|
| 32-bit machine instructions, |      |
| register and immediate cne   |      |
| (RI1)                        | 1-10 |
| register and immediate two   |      |
| (RI2)                        | 1-11 |
| register and indexed stcrage |      |
| one (RX1)                    | 1-8  |
| register and indexed storage |      |
| three (RX3)                  | 1-10 |
| register and indexed stcrage |      |
| two (RX2)                    | 1-9  |
| register and indexed         |      |
| storage/register and         |      |
| indexed storage (RXRX)       | 1-12 |
| register-to-register         | 1-8  |
| short form (SF)              | 1-12 |
| Title instructions           | 3-65 |

## UV

| Unreferenced externals |      |
|------------------------|------|
| instructions,          |      |
| NUREX                  | 3-56 |
| UREX                   | 3-56 |

## WXYZ

I

| Warnin | ng (WARN) instruction | 3-68 |
|--------|-----------------------|------|
| Width  | (WIDTH) instruction   | 3-66 |
| WNTRY  | instructions          | 3-25 |
|        |                       | 3-26 |
| WXTRN  | instructions          | 3-25 |
|        |                       | 3-26 |

## PUBLICATION COMMENT FORM

| From                        |                                          | Date                                  |                                          |                              | <br> |
|-----------------------------|------------------------------------------|---------------------------------------|------------------------------------------|------------------------------|------|
| Title                       |                                          | . Publicatio                          | n Title                                  |                              | <br> |
| Company                     |                                          | Publicatio                            | n Number                                 |                              | <br> |
| Address                     | an a | •.                                    |                                          |                              |      |
|                             | an a |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |
| FOLD                        |                                          |                                       |                                          |                              | FOLD |
| Check the appropriate item. |                                          |                                       |                                          |                              |      |
| Error Page No.              | Drawing No                               |                                       | <u>n ar alan - ina - ina - ina - ina</u> |                              |      |
| Addition Page No.           | Drawing No                               | •                                     |                                          | intelline – editionalization |      |
| Other Page No               | Drawing No                               | • • • • • • • • • • • • • • • • • • • |                                          |                              |      |
| Explanation:                |                                          |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |
|                             | ۰.                                       |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |
| FOLD                        |                                          |                                       |                                          |                              | FOL  |
|                             |                                          |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |
|                             |                                          |                                       |                                          |                              |      |

CUL ALONG LINE

.

|                          |                                                                                                 |                                                                          | · · ·           | · · · · · · · · · · · · · · · · · · · |
|--------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------|---------------------------------------|
|                          |                                                                                                 |                                                                          |                 | '<br>                                 |
|                          |                                                                                                 |                                                                          |                 |                                       |
|                          |                                                                                                 |                                                                          |                 |                                       |
|                          |                                                                                                 |                                                                          |                 | l                                     |
| •                        |                                                                                                 |                                                                          |                 | 1                                     |
|                          |                                                                                                 |                                                                          |                 | I                                     |
|                          |                                                                                                 |                                                                          |                 | 1                                     |
|                          |                                                                                                 |                                                                          |                 |                                       |
|                          |                                                                                                 |                                                                          |                 |                                       |
|                          |                                                                                                 |                                                                          |                 | FOLD                                  |
|                          |                                                                                                 |                                                                          | 1 11 11 1       |                                       |
|                          |                                                                                                 |                                                                          |                 | NO POSTAGE                            |
|                          |                                                                                                 |                                                                          | 1 11 11 1       | NECESSARY<br>IF MAILED                |
|                          |                                                                                                 |                                                                          |                 | IN THE<br>UNITED STATES               |
|                          |                                                                                                 |                                                                          |                 |                                       |
|                          | BUS                                                                                             | SINESS REPLY                                                             | MAIL            |                                       |
|                          | FIRST CLASS                                                                                     | PERMIT NO. 22                                                            | OCEANPORT, N.J. |                                       |
|                          |                                                                                                 |                                                                          |                 |                                       |
|                          | POSTAGE WILL B                                                                                  | E PAID BY ADDRESSEE                                                      |                 |                                       |
|                          |                                                                                                 | E PAID BY ADDRESSEE                                                      | R               |                                       |
|                          | POSTAGE WILL B<br>PERK<br>Computer Syst                                                         | E PAID BY ADDRESSEE                                                      | R               |                                       |
|                          | POSTAGE WILL B<br><b>PERK</b><br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ              | E PAID BY ADDRESSEE                                                      | R               |                                       |
|                          | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ                     | E PAID BY ADDRESSEE                                                      | R               |                                       |
|                          | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ                     | E PAID BY ADDRESSEE                                                      | R               |                                       |
| сн рив                   | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ                     | E PAID BY ADDRESSEE<br>IN-ELME<br>ems Division<br>Ce<br>07757<br>MS 322A | R               |                                       |
| СН РИВ                   | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ<br>SLICATIONS DEPT. | E PAID BY ADDRESSEE<br>IN-ELME<br>ems Division<br>Ce<br>07757<br>MS 322A | <b>:R</b>       |                                       |
| <b>CH PUB</b>            | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ<br>SLICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>:R</b>       | FOLD                                  |
| <b>CH PUB</b>            | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ<br>SLICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>:R</b>       | FOLD                                  |
| СН РИВ<br>               | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ<br>SLICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>:R</b>       | FOLD                                  |
| <b>СН РИВ</b><br>        | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ<br>COCEANPORT       | E PAID BY ADDRESSEE                                                      | <b>:R</b>       | FOLD                                  |
| <b>CH PUB</b>            | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ<br>SLICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>:R</b>       | FOLD                                  |
| <b>CH PUB</b>            | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plat<br>Oceanport, NJ<br>CLICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>:R</b>       | FOLD                                  |
| <b>СН РИВ</b><br>        | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ<br>CLICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>:</b> R      | FOLD                                  |
| <b>СН РИВ</b><br><br>ого | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ<br>SLICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>:R</b>       | FOLD                                  |
| <b>CH PUB</b>            | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plat<br>Oceanport, NJ<br>CLICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>:R</b>       | FOLD                                  |
| <b>СН РИВ</b><br>        | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ<br>ILICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>R</b>        | FOLD                                  |
| СН РИВ<br>               | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plac<br>Oceanport, NJ<br>SLICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>:</b> R      | FOLD                                  |
|                          | POSTAGE WILL B<br>PERK<br>Computer Syst<br>2 Crescent Plat<br>Oceanport, NJ<br>CLICATIONS DEPT. | E PAID BY ADDRESSEE                                                      | <b>R</b>        | FOLD                                  |