# mitra 15 Reference manual

Contents

| General                                         | 1-1  |
|-------------------------------------------------|------|
| Introduction                                    | 1-1  |
| MITRA 15 main features                          | 1-1  |
| Models MITRA 15/20, MITRA 15/30                 | 1-3  |
| MITRA 15 operating system                       | 1-8  |
| Applications                                    | 1-11 |
|                                                 |      |
| GENERAL LAYOUT                                  | 2-1  |
| Core memory                                     | 2-1  |
| Processing units                                | 2-1  |
| Micro-programmed ROM (or micro-processor)       | 2-2  |
| Registers                                       | 2-4  |
| Logical and arithmetical operator               | 2-4  |
| Indicators                                      | 2-5  |
| Communication with the environment              | 2-6  |
| Interrupts, suspensions, traps                  | 2-6  |
| Mode and protection                             | 2-9  |
| STRUCTURE OF A PROGRAM                          | 3-1  |
| Definition of modularity                        | 3-1  |
| Definition of a section                         | 3-1  |
| Section and segment bases                       | 3-1  |
| Consequences of modularity on MITRA 15 programs | 3-1  |
|                                                 |      |
| Constituents of a program<br>Section calls      | 3-5  |
|                                                 | 3-7  |
| System's management concepts                    | 3-10 |
| ASSEMBLY LANGUAGE                               | 4-1  |
| Source line format                              | 4-2  |
| Basic character set                             | 4-2  |
| Symbols                                         | 4-2  |
| Constants                                       | 4-3  |
| Expressions                                     | 4-4  |
| ADDRESSING MODES                                | 5-1  |
|                                                 | 5-1  |
| Symbolic representation of the instruction      |      |
| Addressing mode representation                  | 5-2  |
| PSEUDO-INSTRUCTIONS                             | 6-1  |
| Source text segmentation                        | 6-1  |
| Assembly pseudo-instructions                    | 6-6  |
| Page pseudo-instruction                         | 6-14 |
|                                                 |      |

© compagnie internationale pour l'informatique 1973

| Con | tents |
|-----|-------|
|-----|-------|

| INSTRUCTIONS                                                                                                                                      | 7-1                                                                                                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| General                                                                                                                                           | 7-1                                                                                                                                  |
| Symbolic notations                                                                                                                                | 7 -2                                                                                                                                 |
| Load and store instructions                                                                                                                       | 7 -6                                                                                                                                 |
| LBL                                                                                                                                               | 7 -8                                                                                                                                 |
| SBL                                                                                                                                               | 7-9                                                                                                                                  |
| LBR                                                                                                                                               | 7-10                                                                                                                                 |
| SBR                                                                                                                                               | 7-10                                                                                                                                 |
| LBX                                                                                                                                               | 7-12                                                                                                                                 |
| LDA                                                                                                                                               | 7-13                                                                                                                                 |
| STA                                                                                                                                               | 7 - 1 4                                                                                                                              |
| LDE                                                                                                                                               | 7 - 1 5                                                                                                                              |
| STE                                                                                                                                               | 7 - 1 6                                                                                                                              |
| LDX                                                                                                                                               | 7-17                                                                                                                                 |
| STX                                                                                                                                               | 7-18                                                                                                                                 |
| LDR                                                                                                                                               | 7-19                                                                                                                                 |
| STR<br>LEA<br>SPA                                                                                                                                 | 7-17<br>7-20<br>7-21<br>7-22                                                                                                         |
| STS                                                                                                                                               | 7-23                                                                                                                                 |
| DLD                                                                                                                                               | 7-24                                                                                                                                 |
| DST                                                                                                                                               | 7-25                                                                                                                                 |
| Fixed-point arithmetic                                                                                                                            | 7-25                                                                                                                                 |
| ADD                                                                                                                                               | 7-26                                                                                                                                 |
| ADM                                                                                                                                               | 7-27                                                                                                                                 |
| SUB                                                                                                                                               | 7-28                                                                                                                                 |
| MUL                                                                                                                                               | 7-29                                                                                                                                 |
| DIV                                                                                                                                               | 7-30                                                                                                                                 |
| Logical operations                                                                                                                                | 7-31                                                                                                                                 |
| IOR                                                                                                                                               | 7-31                                                                                                                                 |
| EOR                                                                                                                                               | 7-32                                                                                                                                 |
| AND                                                                                                                                               | 7-33                                                                                                                                 |
| CMP                                                                                                                                               | 7-34                                                                                                                                 |
| Register incrementation and decrementation                                                                                                        | 7-35                                                                                                                                 |
| ICX                                                                                                                                               | 7-35                                                                                                                                 |
| DCX                                                                                                                                               | 7-36                                                                                                                                 |
| ICL                                                                                                                                               | 7-37                                                                                                                                 |
| DCL                                                                                                                                               | 7-37                                                                                                                                 |
| Shift operations<br>SHR<br>SLLS<br>SRCS<br>SAD<br>SLCD<br>SLCD<br>SLCS<br>SAS<br>SRLS<br>SRCD<br>SHC<br>SLLD<br>SHC<br>SLLD<br>SRLD<br>PTY<br>NLZ | 7-38<br>7-40<br>7-41<br>7-42<br>7-43<br>7-44<br>7-45<br>7-46<br>7-47<br>7-48<br>7-47<br>7-48<br>7-49<br>7-51<br>7-52<br>7-53<br>7-54 |
|                                                                                                                                                   |                                                                                                                                      |

#### Contents

|    | Inter-register operations         | 7-55          |
|----|-----------------------------------|---------------|
|    | SRG                               | 7-56          |
|    | XAE                               | 7-57          |
|    | XAX                               | 7-57          |
|    |                                   |               |
|    | XEX                               | 7-58          |
|    | XAA                               | 7-58          |
|    | CCE                               | 7-59          |
|    | ACE                               | 7-59          |
|    | CCA                               | 7-60          |
|    | AEE                               | 7-60          |
|    | CNX                               | 7-61          |
|    | AIE                               | 7-61          |
|    | AAE                               | 7-62          |
| ¥. |                                   |               |
|    | LNE                               | 7-62          |
|    | CNA                               | 7-63          |
|    | СМХ                               | 7-63          |
|    | Floating-point arithmetic         | 7-64          |
|    | FAD                               | 7-66          |
|    | FSU                               | 7-67          |
|    | FMU                               |               |
|    | FDV                               | 7-68<br>7-69  |
|    | FDV                               | 7-07          |
|    | Byte string processing            | 7-70          |
|    | M∨S                               | 7-70          |
|    | CPS                               | 7-71          |
|    | TRS                               | 7-72          |
|    | Branch instructions               | 7-73          |
|    | BRU                               | 7-74          |
|    | BRX                               | 7-75          |
|    |                                   |               |
|    | BCT                               | 7-76          |
|    | BOT                               | 7-77          |
|    | BCF                               | 7-78          |
|    | BOF                               | 7-79          |
|    | BAZ                               | 7-80          |
|    | BAN                               | 7-81          |
|    | BE                                | 7-82          |
|    | BZ                                | 7-83          |
|    | BL                                | 7-84          |
|    | BLZ                               | 7 <b>-</b> 85 |
|    |                                   |               |
|    | BNE                               | 7-86          |
|    | BNZ                               | 7-87          |
|    | BGE                               | 7-88          |
|    | BPZ                               | 7-89          |
|    | System communication instructions | 7-90          |
|    | CLS                               | 7-90          |
|    | RTS                               | 7-93          |
|    | CSV                               | 7-94          |
|    | RS∨                               | 7-96          |
|    |                                   |               |
|    |                                   | 7-97          |
|    | DITR                              | 7-100         |
|    | Control instructions              | 7-101         |
|    | TES                               | 7-102         |
|    | STM                               | 7-103         |
|    | CLM                               | 7-103         |
|    |                                   |               |

| 4 | 0 | 5 | 7 |
|---|---|---|---|
|   |   |   |   |

#### Contents

| RD<br>WD<br>LDP                                                                                                                                     | 7-104<br>7-104<br>7-105                  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| INPUT/OUTPUT CONTROL SYSTEM<br>Input/output system organization<br>Input/output interface<br>Transfers<br>Operational labels<br>Handler utilization | 8-1<br>8-1<br>8-1<br>8-6<br>8-11<br>8-14 |
| LIST OF PSEUDO-INSTRUCTIONS                                                                                                                         | A-1                                      |
| LIST OF INSTRUCTIONS                                                                                                                                | B-1                                      |
| ADDRESSING MODES                                                                                                                                    | C-1                                      |
| ASSEMBLER OPERATION                                                                                                                                 | D-1                                      |

## 1. General

#### I-1. INTRODUCTION

MITRA 15 is a real time computer relying on a modular design and advanced micro-programmed structure for an efficient approach to numerous application fields, such as process control, scientific computation, remote-processing or transaction management.

The system includes up to four processing units specialized through read-only micro-programmed memories (ROM) and arranged around a planar structure core memory. According to their micro-programs, these units become CPU's, IOP's or special-purpose units. Each processing unit is provided with a "MINIBUS" for connecting a comprehensive range of peripheral units.

MITRA 15 is available in two fully compatible models which only differ by their processing capacity and the range of connectable peripheral units. Thus, each user can select the model and configuration best suited to its specific requirements.

#### I-2. MITRA 15 MAIN FEATURES

#### I-2.1. Core memory

MITRA 15's memory is a lithium-ferrite core random access memory organized in 16-bit words with 2 additional bits, 1 for parity and 1 for protection. The very short 800 nanoseconds word read/write cycle provides an outstanding transfer rate of 2.5 Mbytes per second (millions of bytes/second).

Memory contents are adressable on a byte basis and alterable on a byte, half-word or word basis.

The memory is made up of 4 096-word blocks (i.e. 8 192 bytes) up to a maximum of eight. Its capacity can thus be extended from 4 096 words to 32 768 words per 4 096-word increments.

Dynamic memory protection

This feature provides full protection to any memory area against unwanted attemps to alter its contents. The protection its assigned on a dynamic basis (LDP instruction).

A 1-bit protection "lock" is associated with every memory word. Besides, an indicator of the program status acts as a "key" : when this indicator is set to 1, the program is able to gain access to all memory locations; otherwise the program can only gain access to unprotected areas.

Parity

Full parity ckeck is provided both in the memory an during I/O operations.

#### 1-2.2. Processing units

The functions available in a conventional computer are shared between a wired module, indentical for all processing units, the so-called "micro-processor", and the contents of a ready-only control memory which "specializes" the micro-processor to provide the functions of a CPU, IOP or special-purpose unit.

A processing unit comprises a fast register block, five program indicators, a micro-programmed read-only memory, an operator and an interrupt/suspension system.

#### ■ Fast register memory

This memory is implemented in MSI bipolar integrated circuit registers which are organized in eight 16-bit program-adressable register blocks. The capacity of each processing unit can be extended from two to eight 8-register blocks per 2-block modules. Access time : 60 nanoseconds per word.

In the CPU, the first block (block 0) is assigned to the program context, the remaining blocks being available for peripheral transfers.

Program context

In an IOP, all block are available for peripheral transfers.



#### Block 0 of CPU

- Program indicators
- C Carry or operation test
- O Overflow or operation test
- MS Mode : master/slave
- MA Interrupt Mask
- PR Memory protection

For detailed description of indicators see chapter II.

Instructions

MITRA 15 has a set of 86 instructions including :

- 40 memory reference instructions,
- 29 register instructions,
- 12 shift instructions,
- 5 special instructions.
- All instructions have a fixed format :

| 3    | 5        | 8            |
|------|----------|--------------|
| Mode | Function | Displacement |
| 4    | 4        | 8            |
| Mode | Function | Displacement |

They operate on bytes (half-words), words, double-words or unlimited length byte strings.

Addressing modes :

- immediate addressing for operands which can be coded in one byte;
- direct, indirect and indexed addressing with respect to the local base;
- direct, indirect and indexed addressing with respect to the general base.
- Micro-programmed read-only memory

This non-destructive read out permanent memory is pre-recorded. Each 16-bit word contains one microinstruction. The memory is implemented in MSI bipolar IC's and its access time is 60 nanoseconds. Its capacity is 512 or 1024 words per processing unit.

Three different versions are available for the following functions :

- MC1 : executes the basic instruction code and the coupling functions for peripherals which are connectable to CPU's Minibus only.
- MC2 : executes the complementary code (optional instructions) and the coupling functions for peripherals which are connectable to the Minibus of either the CPU or an IOP.
- MC3 : executes the coupling for peripherals which are connectable to an IOP's Minibus.
- Interrupts (IT)

32 priority interrupt levels are available which can be armed, masked or triggered by program. They provide up to 112 discrete external interrupts by grouping.

When an interrupt is triggered, the program context is automatically swapped in 30 µs.

For a special high speed interrupt level, this swapping is effected in 5 us only, by register block switching.

Suspensions

MITRA 15 also offers 32 suspension levels organized on a priority basis for micro-program coupling of peripherals requiring urgent or frequent transfers.

The maximum response time is 300 µs.

Minibus

Each processing unit is provided with a Minibus for device controllers connection. This Minibus is implemented as a printed circuit located in the chassis wiring and provides non-specialized plug-in locations for all controller cards.

#### 1-3. MODELS MITRA 15/20, MITRA 15/30

#### MITRA 15/20

- MITRA 15/20 CPU comprising, as standard :
- 512-word micro-programmed ROM (MC1),
- 64 fast access registers,
- Basic code providing for 77 instructions,
- Priority interrupt system.

Core memory

4K to 32K 16-bit words per 4K increments.

- Performance
- Addressing mode : direct, indirect, indexed, relative, immediate, local and general.
- 1 index, 2 bases.
- 77 instructions, including 33 memory reference instructions.
- Load, store or add word in 2.1 µs.
- Main options
- Up to 3 direct memory accesses (DMA)
- Additional micro-programmed ROM (MC2)
- Up to 32 priority interrupt levels per 1 or 4 levels modules.
- Wired MUL/DIV (7 and 8  $\mu s)$  .
- Floating point operator (O $\lor$ F).
- Power failure protection.
- Software
- MITRAS 1 Assembler; MITRAS 2 Extended Assembler; LP 15; BASIC; FORTRAN IV.
- Linkage editor.
- 2 Monitors : Basic Monitor MOB and Real-Time Monitor MTR.
- Libraries.
- Basic peripherals (Range I)
- Console typewriter (with paper tape reader/punch),
- 300 char./sec. paper tape reader,
- 60 char./sec. paper tape punch,
- Logging slow printer (15 char./sec.),
- 2 to 128 16-bit digital input lines for logical levels, or filtered, or relayed,
- 2 to 64 16-bit digital output lines for logical levels or relayed,
- Counter inputs; real-time clock,
- Analog inputs.

4 K 4 K 4 K 4 K 4 K 4 K 4 K 4 K words words words words words words words words DMA CPU DMA DMA CPU MINIBUS ٨U Typewriter DIV Paper Tape reader/punch Logging Real time clock digital inputs digital outputs analog inputs counter inputs interrupts

CORE MEMORY

MITRA 15/20 general layout

#### MITRA 15/30

- MITRA 15/30 CPU comprising, as standard :
- 1024-word micro-programmed ROM,
- 32 fast access registers,
- Extended operation code for 86 instructions,
- Priority interrupt system,
- Wired MUL/DIV,
- Power failure protection.
- Core memory

4K to 32K 16-bit words per 4K increment

- Performance
- Addressing modes : direct, indirect, indexed, relative, immediate, local and general.
- 1 index, 2 bases
- 86 instructions, including 40 memory reference instructions
- Load, read, write or add word in 2.1 µs
- MUL/DIV in 7 and 8  $\mu s$  , respectively.
- Main options
- Up to 3 direct memory accesses (DMA)
- Up to 3 input/output processors (IOP)
- Extension to 128 fast access registers per processing unit (64-level modules)
- 32 priority interrupt levels per 1 or 4 level modules
- Floating-point operator (OVF)
- 🕿 Software

- MITRAS 1 Assembler; MITRAS 2 Extended Assembler; Macro-generator; LP 15; BASIC; FORTRAN IV; Librarian; File management system.

- 3 Monitors : Basic Monitor MOB; Real-Time Monitor MTR; Disk Real-Time Monitor MTRD.

- Peripherals
- Range I (Model 20)
- Range II :

- One head per track fixed-disks; average access time 10 ms, transfer rate 150 kbyte/sec, capacity 100 to 1600 kbytes.

- Movable head disk-pack units; average access time 60 or 90 ms; transfer rate 100 or 150 kbyte/sec; capacity 2.5 to 5 Mbytes or 6.2 to 24.8 Mbytes.

- Card reader : 200 or 600 cpm.
- Card punch : 20 or 40 cpm.

•

CORE MEMORY



MITRA 15/30 general layout

- Line printers: 132 columns; 200, 400 or 600 lpm.
- Communication controller for 1 synchronous data link, full duplex, 1200/4800 bauds
- Communication controller for 2 asynchronous data links, full duplex, 50 to 1200 bauds.
- Range III :

- OCTET interface for connecting all CII 10 000 or IRIS Series peripherals : (card readers, printers, tape handlers, etc...).

#### 1-4. MITRA 15 OPERATING SYSTEM

Depending on the availability of a fast access disk unit, the software is offered in two different versions : the resident system and the disk system.

- The resident system provides :
- 2 Monitors : the Basic Monitor MOB and the Real-time Monitor MTR
- Assemblers : MITRAS and LP 15; Compilers : BASIC and FORTRAN and a Macro-generator.
- The disk system provides :
- The real-time Monitor MTRD
- The resident system processors, a librarian and a linkage module.

In addition, the software includes :

- Debugging commands available as extension of each monitor.
- A comprehensive library of "real-time" mathematical programs, and a file management system.
- MITRA 15 Simulators available for use on CII 10 070, IRIS 50, IRIS 80, IBM 360, etc.

#### MITRAS I Assembler

Translates the symbolic MITRAS language generates in one single pass a relocatable binary object-listing and a list of error diagnostics.

Both source and relocatable binary programs are normally on paper tape; memory requirement : 4K words.

#### MITRAS 2 Extended Assembler

Translates the symbolic MITRAS language; has a larger set of pseudo-instructions than MITRAS I. Memory requirement : 8K words.

#### LINKAGE EDITOR

Operates in two passes for converting binary relocatable programs generated during various assembly or compilation runs, into a relocatable memory image format which can be loaded for execution by the Basic Monitor.

The linkage editor also provides a memory map of the relative location of the various modules and a listing of the common sub-routines which are called. Memory requirement : 4K words.

#### BASIC MONITOR MOB

Perform computer control and handles user's communications with the system and the basic processors. Its main functions are :

- trap processing,
- internal interrupt control,
- program loading,
- input/output control,
- program execution control.

Memory requirement : 4K words.

#### REAL-TIME MONITOR MTR

Handles simultaneously interrupt-dependent batched jobs in core. Controls and supervises all privileged operations, such as I/O handling or memory protection, and provides operator communication. Memory requirement : 8K words.

|                                             | 4 Kwords                                               | 8 Kwords                                                  | 12 Kwords         | 16 Kwords           | Simulation                                             |
|---------------------------------------------|--------------------------------------------------------|-----------------------------------------------------------|-------------------|---------------------|--------------------------------------------------------|
| OPERATING<br>SYSTEM<br>resident<br>system   | Basic Monitor<br>MOB                                   | Real-time<br>Monitor MTR                                  |                   |                     | control command<br>analyz <del>er</del><br>interpreter |
| disk<br>system                              |                                                        | disk real-time<br>Monitor MTRD                            | linkage<br>module |                     |                                                        |
| PROGRAM<br>GENERATION<br>resident<br>system | MITRAS I<br>linkage editor<br>loader-editor            | MITRAS 2<br>BASIC                                         | LP 15             | FORTRAN IV          | Assembler<br>linkage editor                            |
| disk<br>system                              |                                                        | MITRAS 2<br>linkage editor<br>BASIC<br>LP 15<br>Librarian | FORTRAN IV        | Macro-<br>generator | LP 15                                                  |
| LIBRARY                                     | Mathematical pro<br>programs commun<br>file management | ication programs                                          |                   |                     |                                                        |

| Structure | of MITRA | 15 standard | software |
|-----------|----------|-------------|----------|
|           | •••••••• |             |          |

#### DISK REAL-TIME MONITOR MTRD

This disk-oriented version of the MTR Monitor has additional capabilities for overlay control and user's libraries management, as well as for automatic linking of batched programs (compile-link, load-and-go); requires 8K words memory and a fast access disk unit.

#### LOADER - LINKAGE EDITOR

Operates in one pass for loading binary relocatable programs for immediate execution.

This processor can only accept binary programs generated by MITRAS I. Memory requirement : 4K words.

#### LP 15

This assembler type language has a syntax which is closely related to that of sophisticated languages such as ALGOL, but with the feature of direct access to MITRA 15's registers.

The binary object programs thus generated have an efficiency which is practically equivalent to that of assembled programs. Memory requirement : 12K words without a disk unit.

#### BASIC

This conversational compiler provides for time-shared operation and alphanumerical data processing. Memory requirement : 8K words.

#### FORTRAN IV

This compiler generates in one single pass a relocatable binary object-program in the format required by the linkage editor. May call sub-routines written in another language and translated in relocatable binary format; compatible with CII 10 020, IRIS 45 and IRIS 50. Memory requirement : 16K words or 12K words with a disk unit.

#### AMAP EXTENSION (DEBUGGING AIDS)

An AMAP extension available with every monitor as a debugging aid and provides instruction execution records, halt on address, memory dumps and contents alteration, through special monitor commands.

#### LINKAGE MODULE

Provides for automatic linking of batched programs in the deffered processing area with concurrent realtime programs.

This processor is controlled by the disk real-time monitor MTRD; requires 12K memory words and a fast access disk unit.

#### MACRO-GENERATOR

Translation program using user-defined procedures. It provides in one pass a program in assembly or compilation language. Memory requirement : 16K words.

#### LIBRARIAN

Provides for handling the system library constitutive files through commands such as : insert, replace, copy, load, dump on external medium... Memory requirement : 8K words and a fast access disk unit.

#### UTILITY PROGRAMS

These programs are available for :

- Updating and correcting source programs on sequential access media (paper tape, magnetic tape, etc.).
- Handling and updating library programs on sequential access media. Memory requirement : 4K words.

#### MITRA 15 SIMULATORS

These simulation programs are available for CII 10 070, IRIS 50, IRIS 80, IBM 360, etc. computers and include :

- a MITRA 15 interpreter,
- MITRAS Assembler and Linkage editor,
- a system generator,
- LP 15 Compiler.

They perform assembly, linkage edition and debugging functions on programs intended for later exploitation on any MITRA 15 configuration.

#### I-5. APPLICATIONS

| LABORATORIES           | Spectrometry<br>Gazeous chromatography<br>Cristallography |  |  |  |
|------------------------|-----------------------------------------------------------|--|--|--|
| MEDECINE               | Chemical analysis                                         |  |  |  |
|                        | Electrocardiography                                       |  |  |  |
| ENGINEERING            | Components testing                                        |  |  |  |
|                        | Seismography                                              |  |  |  |
|                        | Ranging                                                   |  |  |  |
| INDUSTRY               | Chemicals                                                 |  |  |  |
| Monitoring             | Oil and derivates                                         |  |  |  |
| Automation             | Steel industry                                            |  |  |  |
| Process control        | Mechanical engineering, aerospace, etc.                   |  |  |  |
| REMOTE PROCESSING      | Deconcentrated companies                                  |  |  |  |
| Front-end computers    | Public Administrations                                    |  |  |  |
| Satellite stations     | Universities                                              |  |  |  |
| Front ends             |                                                           |  |  |  |
| SCIENTIFIC COMPUTATION | Education                                                 |  |  |  |
| Time-sharing           | Design office                                             |  |  |  |
| Data centers           | Private companies                                         |  |  |  |
| TRANSACTION PROCESSING | Insurance companies                                       |  |  |  |
| Data collection        | Banks                                                     |  |  |  |
| File management        | Public services                                           |  |  |  |
|                        |                                                           |  |  |  |

## 2. General layout

MITRA 15 is built around a planar structure core memory the capacity of which can be extended modularly by 4K 16-bit words blocks. This core memory has four access ports for connecting up to four processing units or direct memory access controllers.

Each processing unit includes a micro-programmed read-only memory (ROM); a specific micro-program prerecorded in this memory specializes the associated processing unit for performing the functions of :

- a central processing unit (CPU),
- an input/output processor (IOP), or
- a special-purpose unit for a particular process.

Each processing unit controls a so-called MINIBUS which is a peripheral bus designed for direct connection of peripheral controllers.

#### II-1. CORE MEMORY

The core memory is basically organized in 18-bit words each comprising 16 data bits, 1 parity bit and 1 memory protection bit.

Read/write operations are executed in two separate half-cycles. A read cycle includes a destructive readout half-cycle followed by a rewrite half-cycle. A write cycle includes a clear half-cycle followed by a write half-cycle.

Memory access time is 400 ns (1/2 cycle) and a full read/write cycle lasts 800 ns.

Though memory transfers are performed on a word basis, micro-commands allow the programmer to operate on bytes, i.e. on half-words. Thus, all MITRA 15 addresses point to byte locations, even-numbered addresses corresponding to word locations.

The memory is built up with 4096-word modules, i.e. 8192 bytes. MITRA 15 is designed for a maximum of eigh modules corresponding to a maximum capacity of 32 768 words (or 65 536 bytes).

The control logic supplies the timing signals required for operating the memory proper (half-cycles timing control), and the transfer signals for data exchanges with the processing units; in addition it deals with the four accesses relative priorities.

#### **11-2. PROCESSING UNITS**

The operation of a MITRA 15 processing unit, and more specifically of the CPU, may be described at two fully distinct levels :

A first level corresponding to what may be termed "user-level" and the knowledge of which is sufficient for programming an application on MITRA 15.

It includes the following features :

- the standard instruction set detailed in chapter VII;
- six general registers of block 0;
- the five program indicators;
- the interrupt system.

■ A second level corresponding to what may be termed "micro-processor" level

This micro-processor includes the following features :

- a set of about forty hardware-implemented basic micro-instructions;

- a read-only memory implemented on module boards and which contains the sub-routine set, (also called "micro-programs") defining MITRA 15's standard instructions set and peripheral coupling functions;

- operational registers;

- micro-processor status indicators;

- a so-called "suspension system" corresponding, for the second level, to the interrupt system of the first level.

The following sections describe the various components of a processing unit, viz :

- micro-programmed ROM

- S and M memory transfer registers
- fast-access register blocks
- status indicators
- interrupt and suspension systems.

#### 11-3. MICRO-PROGRAMMED ROM (OR MICRO-PROCESSOR)

This non-destructive ROM is pre-recorded in factory and implemented in integrated circuits (access time : 60 ns per word).

Each memory word is 16 bits long and contains one micro-instruction.

The control ROM of a processing unit contains either 512 words (MC1), or 1024 words (MC1 + MC2).

Any micro-instruction is executed in 300 ns.

The address of the currently executed micro-instruction is contained in a 10-bit register called T-register. A micro-instruction has the following format :

| 0 1 | 2  | 6 | 7 | 9  | 10 |    | 15 |
|-----|----|---|---|----|----|----|----|
| м   | OP |   |   | сс |    | AD |    |

Each micro-instruction has a dual purpose :

1) It controls a number of functions, viz.:

- memory control (2 bits : M-field)

- basic operation code (generally 5 bits : OP-field)

- complementary operation code (3 bits : CC-field) defining for instance a general register address

2) It defines the address of the next micro-instruction (through a 6-bit modifier : AD-field), by updating T-register contents.

In fact, micro-instructions are not stored sequentially.

No indexing adder is associated with T-register, since its contents is not incremented by one unit from a micro-instruction to the next, as in a sequential addressing scheme.

CPU's and IOP's are differenciated by the kind and contents of their respective control memories.

In the CPU, MC1 control memory (512 words) executes the basic operation code and the coupling functions for peripherals which are connectable to its Minibus only (Range I).

MC2 control memory provides for executing the complementary operation code (optional instructions) and the coupling functions for peripherals which are connectable either to the Minibus of the CPU, or to the Minibus of an IOP (Range II).

The CPU's control memory then includes 1024 words (MC1 + MC2).

MC3 control memory executes the coupling functions for peripherals which are connectable to the Minibus of an IOP only (Range III).



CORE MEMORY

Processing unit layout

#### II-4. REGISTERS

#### 11-4.1. Memory transfer registers

S-register is a 15-bit address register, though actual addresses are 16 bits long. The rightmost bit of an address, which specifies the desired byte within the addressed word, is in fact ignored by the memory logic.

M-register is an 18-bit data register receiving the transferred memory words. Two of these bits are reserved for parity and protection tests; the 16 other bits are used for date exchanges with U-register.

#### 11-4.2. Fast-access registers

A standard MITRA 15 processing unit includes eight register blocks each comprising eight 16-bit integrated circuit registers numbered 0 through 7. Eight optional blocks are available on 15/30 model.

These registers have different assignments in the CPU and in an IOP.

In the CPU, the first block (block 0) is reserved for program execution; its first six registers have the following functions :

- A Accumulator,
- E Accumulator extension,
- P Program counter,
- X Index register,
- L Local base register,
- G General base register,

the last two registers, V and W ared used by micro-programs.

The other blocks are normally assigned to peripheral transfers through the suspension system (channel memories).

In an IOP, all register blocks are available for peripheral transfers.

Each register has a unique address form 0 to 63 (or 127). In the micro-programs, a general register address is generated from :

- the contents of the corresponding field of the micro-instruction format (3 bits).

- the contents of J-register.

It will be seen in section II-8. that a high-speed interrupt causes an automatic switching of the register block. In the new block, the registers have then the same assignment as in block 0, but for other programs.

#### 11-5. LOGICAL AND ARITHMETICAL OPERATOR

The logical and arithmetical operator includes a universal register, or U-register, and a dual-input operator. The 16-bit U-register cannot be directly accessed by the instructions, but constitutes an accumulation register for the micro-processor. In this respect it can contain one operand of a micro-instruction and/or store the result. Both operands of a micro-instruction may also be provided by :

- a general register (operand 2)

- M-register in connection with the core memory (operand 1)
- the I/O interface (operand 2)
- the control memory (operand 2)

- the stack (operand 2)
- the indicators (operand 2)

The results of the operation are stored in the following devices :

- U-register (universal)
- M-register (data)
- S-register (address)

for core memory transfers

- a general register
- the indicators

#### **II-6. INDICATORS**

MITRA 15's central processor includes nine indicators :

Four indicators reserved for micro-processor use :

B-indicator : assigned to U-register overflows

Tz-indicator : for a zero micro-instruction result

To-indicator : for the sign of a micro-instruction result

Ao-indicator : address of the processed byte.

Five program-accessible indicators

C = Carry

This indicator has two different meanings according to the last instruction by which it is set.

• Carry/borrow (arithmetic type instruction)

- When a positive number is added (negative number subtracted), if the result is obtained without becoming zero, C is reset (C = 0).

- When a positive number is added (negative number subtracted), if the result is obtained after becoming zero, C is set (C = 1).

- When a negative number is added (positive number subtracted), if the result is obtained without becoming zero, C is set (C = 1).

- When a negative number is added (positive number subtracted), if the result is obtained after becoming zero, C is reset (C = 0).

• For other instructions using C-indicator, the status C-indicator, the status C = 1 after execution denotes a zero value in a register or, in the case of a comparison, equality of two values.

#### O = Overflow

This indicator also has two different meanings according to the last instruction executed.

• For arithmetic type instructions, O-indicator is used for overflow. More precisely, when both operands have the same sign, if the result is of the opposite sign, O is set (O = 1). Otherwise, O is reset (O = 0).

• For other instructions using O-indicator, the status O = 1 after execution denotes a negative value in a register (leftmost bit set) or, in the case of a comparison, that A-register value is less than the addressed word value.

#### MS = Master/Slave mode

For programs executed in Master mode, this indicator is set to 1, otherwise the program is executed in normal or "slave" mode.

See chapter VII "Instructions" for detailed description of the above three indicators for every instruction.

#### MA = Interrupt mask indicator

This indicator is set to 1 for masked interrupts, otherwise MA = 0.

#### PR = Memory protection "key"

When PR = 1, the program is able to gain access to any memory location.

When PR = 0, the program is only allowed to gain access to unprotected memory areas ("protection lock" cleared).

These five indicators are included in the context of a specific program.

#### 11-7. COMMUNICATION WITH THE ENVIRONMENT

The processing unit is coupled to the peripheral controllers via a so-called MINIBUS which is accessible through micro-instructions. The interface includes :

- for data : 16 output bit lines and 16 input bit lines;
- three function bit lines;
- for addresses : 6 bit lines or 10 bit lines in particular cases;
- a sync line;
- a reset line.

The peripheral Minibus, on which the peripheral controllers are connected, includes 16 unidirectional data lines, both for input and output, an address and peripheral control bus, as well as interrupt and suspension lines.

#### II-8. INTERRUPTS - SUSPENSIONS - TRAPS

II-8.1. Interrupts

The interrupt system operates when :

- an interrupt signal occurs;
- a special micro-instruction, located by definition at specific "interrupt point", occurs;
- interrupts are unmasked;
- the priority level of the current program is lower than that of the incoming interrupt.

There are 32 interrupt levels (IT levels). Each of these levels has an associated memory address containing the context pointer of a program specifically assigned to this level. These 32 context pointers are stored in a table pointed to by the contents of memory address 10.

When an interrupt condition occurs :

- the condition is stored in a flip-flop (one per signal),
- its IT-level is hardware-coded and compared with that of the task currently processed (register 8),

- if the interrupt is accepted, its specific IT-level (0 through 32) is stored in the hardware of the microprocessor when the interrupt test micro-instruction is executed,

- then, the micro-program performs the following operations :

. Storage of the interrupted task context at an address depending on its rank (the latter being stored in register 8).

. Loading of the interrupting task context from an address depending on its rank.

. Call of the first instruction of the interrupting task. (See "Communication with the micro-processor" page 11-8).

When the task is over or must wait for the occurence of a specific event, it releases the processing unit through an interrupt de-activation and context swapping instruction DIT which :

- acknowledges the interrupt calling for the task,

- stores the task's context, and

- calls for the next task waiting at the same IT-level, or, if there is no such task, for a task waiting at the next lower IT-level.

If no task is waiting, the computer executes a wait loop until an external event occurs at the lowest level.

The total number of interrupt levels is 32, 4 internal and 28 external. Besides, up to 4 interrupts may be on a same level, providing a total number of multiplexed external interrupts equel to 112 (28 × 4).

As a rule, standard peripheral controllers use one interrupt level each.

Internal interrupt levels are assigned to the following tasks :

- operator's console interrupt request,
- power turn on,
- power shut down,
- program (level 0).

#### High-speed interrupt

Optionally, one external IT-level may be of the "high-speed" type, i.e. may call for a task the context of which is stored in a register block other than block 0, which contains the interrupted task context. Consequently, the task switching only requires that the indicators be transferred in block 0; it lasts about 2 µs.

When this "high-speed task" is acknowledged, the control is returned to the interrupted task (the context of which is still in block 0) through a special DITR instruction by-passing the usual context swapping in block 0.

#### 11-8.2. Suspensions

The suspension system is able to interrupt the current micro-program at the end of every micro-instruction, and to launch a special micro-program. The suspension request is either issued by a peripheral or internal to the micro-processor (processing unit).

On occurence of a suspension, the micro-processor's status, i.e. the contents of U-, J-, T-registers and of B, Tz, To, Ao indicators are transferred in a stack. The suspension micro-program is then executed.

At the end of the suspension program, the initial contents of U-, J-, T-... registers are restored from the values previously saved in the stack.



Communication with the micro-processor

The stack has a capacity of four suspensions, i.e. the number of suspension levels is four. The number of suspension signals is 32, or 8 per level, assigned as follows :

- 5 internal suspensions :

. traps (1)

. interrupts (2)

. control panel (1)

. power failure (1)

- 27 external suspensions associated with peripherals.

#### 11-8.3. Traps

The origin of a trap is an abnormal condition detected at the end of a micro-instruction.

The trap processing micro-program :

- protects bytes 4 to 9 of the memory which contain L- and P-register values and the indicators status of the context of the instruction which initiated the trap;

- signals the cause of the trap by setting a bit in memory word 2;

- performs a call to supervisor section 0.

The following abnormal conditions initiate a standard trap :

- non-existing memory address : the user has specified an address exceeding the available memory.

- memory protection violation : the user attempts to write in a protected memory area with a zero PR-key.
- parity fault in core memory read-out signals.

Other traps may be initiated by the following causes :

- operating mode violation : attempt to use priviledged instructions in a slave mode program.
- invalid instruction : incorrect OP-code specified.
- "watch-dog" timer runout.

In all these situations :

- the current instruction is aborted,
- the micro-processor's stack is not triggered,
- a special micro-program generates a supervisor call.

The operations performed by the standard monitors in response to a trap condition are described in the corresponding utilization manuals. The trap status word is described in "Communication with the micro-processor" diagram page 11-8.

#### 11-9. MODE AND PROTECTION

#### 11-9.1. Operating modes

- Normal or "slave" mode.

In this mode, priviledged instructions cannot be executed and any attempt to execute such an instruction causes a "mode violation" trap. MS indicator is reset (MS = 0).

- Priviledged or "master" mode.

In this mode all instructions, whether priviledged or not, are executable. MS indicator is set (MS = 1).

The various supervisor modules are examples of programs which must be executed in master mode. (See CSV and RSV instructions).

It should be noted that addressing modes are different in master and slave modes (see Chapter V "Addressing modes") to provide absolute addressing capability in master mode.

#### 11-9.2. Memory protection system

The protection system becomes operative whenever PM key-switch is turned on the control panel.

The operation is as follows :

- a 1-bit protection "lock" is associated with each memory word and may be set by a LDP instruction (LoaD Protection).

- the program status includes a PR-indicator which acts as a "key".

If key value is 1 (override key), the program may gain access to all memory locations.

If key value is 0, the program may only gain access to memory locations whose lock value is 0.

#### PR-key loading

The PR indicator is loaded with the program context.

It is preserved before being forced to 1 during any supervisor call SVC and restored to its previous value when the supervisor returns the control to the calling program.

#### Protection violation

If a "zero key" program attemps an access to any location having a 1 lock value, the protection system operates and initiates a "protection violation" trap.

Memory protection and operating mode are independent.

## 3. Structure of a program

#### III-1. DEFINITION OF MODULARITY

In programming art, as in other techniques, the modularity consists in breaking down a system in to smaller elements with standard interfaces.

Since the introduction of the "sub-program" concept, modularity is an acomplished fact in programmation. As a main program may also be considered as a module, we rather call them "sections". The following advantages are due to modularity :

- easier system specification,
- easier software writing, by sharing the work between a number of programmers,
- identical sections may be used in different system without rewriting,
- easier debugging and assistance on software products.

#### **III-2. DEFINITION OF A SECTION**

A section mainly comprises an instruction sequence called a program segment. The purpose of these instructions is to process data which are either assigned to the section, or shared between a number of sections.

Data which pertain to a section in proper make up a "local data segment" (LDS).

Data which are common to several sections make up a "common data section" (CDS).

Accordingly a section is either the common data section CDS, or a local data segment (LDS) plus an executable program segment (Local Program Segment = LPS).

The CDS is accessible from any point in the program.

More particularly, the CDS may be accessed from a LDS in general addressing mode (direct, indirect or indexed indirect).

Symbols and labels defined in the CDS are applicable to the whole program.

A LDS is accessed from the associated LPS in local addressing mode (direct, indirect or indexed indirect).

Symbols and labels defined in a LDS are applicable to the section only. Nevertheless, they may be referenced in the CDS. A program segment is exclusively made up of unalterable items (instructions), and this improves relocatability and simplifies writing of re-entrant sub-routines.

#### III-3. SECTION AND SEGMENT BASES

#### • General base G

General base G is uniquely assigned to the program; it constitutes an implicit base to which every address referenced by this program is related. Accordingly, the micro-processor automatically adds this base value to all addresses specified in the instructions.

#### Local base L

Local base L is the implicit base value for all local data contained in a local data segment (LDS).

Program base P

Program base P is assigned to a local program segment (LPS).

Initially, base P is the starting address of the section and from there on acts as a program counter for the currently executed section (see Chapter III-2.).

The actual values of L- and P-bases may be unknown at the time a program is written. At linkage edition time, they are automatically generated in relative value with respect to the general base of the program and stored in the associated PRT.

#### 111-4. CONSEQUENCES OF MODULARITY ON MITRA 15 PROGRAMS

From the hardware viewpoint, modularity implies the existence of special instructions for section calls and returns.

From the software viewpoint, program modularity is a fundamental concept of the assembly language which includes so-called "segmentation" pseudo-instructions :

- CDS : Common Data Section
- LDS : Local Data Segment
- LPS : Local Program Segment
- FIN : End of segment or section (LDS, LPS or CDS)
- IDS : Indirect Data Segment.

We shall call "program module" the result of an assembly or compilation processing. When a module is written in assembly language it is rather called "assembly module". Every assembly module must conclude with an END pseudo-instruction. A program may be built up from modules of various origins (differing by their source language, author, creation date, etc.).

The linkage editor interconnects the various modules into a complete executable program.

Remark :

To facilatate the programming, particularly in the case of re-entrant sub-routines, the assembler recognizes so-called "dummy data segments" which are images of later-defined data or of data belonging to another LDS (or CDS) than the LDS in which the dummy area is defined.

These dummy segments are treated as formal parameters, in particular for defining relative displacements with respect to the beginning of the segment (description of dynamic data blocks, index values, etc.) but generate no object code.

Example 1 : Typical organization of a program



| LOCP  | LDS    |       |         |           |
|-------|--------|-------|---------|-----------|
|       | RES    | 2     |         | ١         |
| U     | DATA,1 | 28    | local   |           |
| V     | DATA,1 | 31    | da ta   |           |
| TAB   | DATA   | ATAB  | section |           |
| ATAB  | RES    | 1024  |         | 1         |
|       | FIN    |       |         |           |
|       |        |       |         | Section 2 |
| PRINC | LPS    | LOCP  |         |           |
| INIT  | LDA    | U     |         |           |
|       | ADD    | = C1  |         |           |
|       | STA    | TAB   | program |           |
|       | CLS    | SPROG | section |           |
|       | CSV    | MEXIT |         |           |
|       | FIN    | INIT  |         | 1         |
|       | END    | PRINC |         |           |

Example 1 : Typical organization of a program (continued)

End of file code (%EOD on card and paper tape).

| PROG | CDS<br>:<br>FIN         |              |                                                                                                                                                                                                 |
|------|-------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPSI | LPS<br>:<br>FIN<br>EN D | PROG<br>LPS1 | This LPS having no associated LDS cannot use<br>the local addressing mode; it must use the<br>general addressing mode                                                                           |
|      | CDS<br>: .<br>FIN       |              |                                                                                                                                                                                                 |
| LDS1 | LDS<br>:<br>FIN         |              |                                                                                                                                                                                                 |
| LPSI | LPS<br>:<br>FIN         | LDSI         | These two LPS are both associated with the<br>same LDS. The local symbols are deleted at<br>the beginning of the next LDS. Nevertheless,                                                        |
| LPS2 | LPS<br>:<br>FIN<br>END  | LDS1         | there are two distinct sections (two items in<br>the PRT).<br>The local base L being initially the same for<br>both sections, no mutual calls are allowed<br>(through CLS pseudo-instructions). |

۲

|      | CDS<br>:<br>FIN        |      |                                                                                                                                         |
|------|------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------|
| LDS1 | LDS<br>:<br>FIN        |      | This LPS having no associated LPS, it is only accessible through indirect addressing via an item of the CDS.                            |
| LDS2 | LDS<br>:<br>FIN        |      |                                                                                                                                         |
| LPS2 | LPS<br>:<br>FIN<br>END | LPS2 | This LPS cannot refer to the LDS called LDS2,<br>since local symbols are deleted after every<br>occurence of an LDS pseudo-instruction. |

### Example 2 : Other possible special organizations (continued)

Example 3 :

| Fi                                 | st modu                                                 | le                                     | Seco                               | ond mod                                                  | ule                                  | Th                                 | ird mod                                                 | ule          | Remarks                                                                                                                                                                                                                                           |
|------------------------------------|---------------------------------------------------------|----------------------------------------|------------------------------------|----------------------------------------------------------|--------------------------------------|------------------------------------|---------------------------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PROG<br>C1<br>C2<br>C3<br>C4<br>C5 | CDS<br>RES<br>DATA<br>RES<br>DATA<br>RES<br>DATA<br>FIN | 4<br>D1<br>2                           | PROG<br>C1<br>C2<br>C3<br>C4<br>C5 | C DS<br>RES<br>DATA<br>RES<br>DATA<br>RES<br>DATA<br>FIN | DUM<br>16<br>2<br>4<br>D1<br>2<br>C2 | PROG<br>C1<br>C2<br>C3<br>C4<br>C5 | CDS<br>RES<br>DATA<br>RES<br>DATA<br>RES<br>DATA<br>FIN | 4<br>D1<br>2 | These CDS reflet each others.<br>The dummy CDS DUM do not<br>generate any object code.<br>They use to satisfy the general<br>addressing modes and the refe-<br>rences. Also they enable each<br>program to have in clear the<br>elements it uses. |
| LDS1<br>D1<br>LPS1<br>DEB1         | LDS<br>RES<br>DATA<br>FIN<br>LDS<br>LDA                 | 2<br>C1<br>LDS1<br>D1                  |                                    |                                                          |                                      |                                    |                                                         |              |                                                                                                                                                                                                                                                   |
|                                    | CLS<br>CLS<br>CSV<br>FIN<br>END                         | LPS2<br>LPS3<br>M:EXIT<br>DEB1<br>LPS1 |                                    |                                                          |                                      |                                    |                                                         |              |                                                                                                                                                                                                                                                   |

| 4057 | U |
|------|---|
|      |   |

#### Example 3 :

| First module | Sec                             | cond ma                                                                                           | odule | T                      | hird mo                                                                                           | dule | Remarks                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|---------------------------------|---------------------------------------------------------------------------------------------------|-------|------------------------|---------------------------------------------------------------------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | D2<br>D3<br>D4<br>LPS2<br>DE B2 | LDS<br>RES<br>DATA<br>RES<br>DATA<br>DATA<br>FIN<br>LPS<br>LDA<br>LDX<br>STA<br>RTS<br>FIN<br>END |       | LDS2<br>D2<br>D3<br>D4 | LDS<br>RES<br>DATA<br>RES<br>DATA<br>DATA<br>FIN<br>LDS<br>LDA<br>LDX<br>STA<br>RTS<br>FIN<br>END |      | The two program segments<br>LPS2 and LPS3 are linked to<br>the same data segment LDS2.<br>They are separely assembly,<br>but one of the two references<br>a dummy segment DUM which<br>also uses to satisfy the local<br>addressing modes and allows<br>the programmer to have in<br>clear the elements he uses.<br>The DUM segment do not<br>generate any object code. |
|              |                                 |                                                                                                   |       |                        |                                                                                                   |      |                                                                                                                                                                                                                                                                                                                                                                         |

After these three modules be linked, a executable IMT of the following forme will be obtain.

| CDS<br>PROG | LDS<br>LDS1 | LPS<br>LPS1 | LDS<br>LDS2 | LPS<br>LPS2 | LPS<br>LPS3 |
|-------------|-------------|-------------|-------------|-------------|-------------|
| Running     |             |             |             |             |             |
| section     |             |             |             |             |             |

#### 111-5. CONSTITUENTS OF A PROGRAM

#### Task Working Block (TWB)

The first sixteen words of the CDS are called the "Task Working Block" or TWB.

This 16-word area is reserved to the Monitor which may store therein the return address to the calling task, as well as the caller's local data base (L) and the program indicators.

The Monitor may maintain in the TWB a pointer to the system's common data area (ZC).

All programs which require Monitor Calls must reserve 16 words at the beginning of their respective CDS.

This feature allows for monitor sections re-entry, the latters operating in the calling program.

#### Program Relocation Table (PRT)

The sections are assigned through a section relocation double-word (SRD), which contains the initial values of L and P with respect to G :

The PRT is made up of all the SRD of the program sections.

This PRT is stored in the locations immediately preceding G-address, thus the SRD of section no.  $\underline{n}$  has an address given by :

G - 4n

This table is built at linkage edition time.

Note :

The Monitor's PRT is pointed to by the contents of a fixed address as that of the micro-processor (address 12).

The PRT is the communication area between the different sections of a same program or between a program and the Monitor (for the Monitor's PRT).



Structure of a program

Remark :

The CDS, which is accessible from any section of a program, constitutes an implicit communication area between the sections.

De-activation word table or DeVice Table (DVT)

This 32-word table precedes in core memory the Context Pointer Table (CPT) which is also 32-word long.

A DVT word has the following format :



Bits 3 to 15 are also called "interrupt configuration".

The interrupt system and the DVT are described in Chapter II.

#### Context (CTX)

The context is the communication area between a priority level and an associated program. It groups seven words :

- Word 1 : Status indicators
- Word 2 : Initial X value
- Word 3 : Initial E value
- Word 4 : Initial A value
- Word 5 : Initial G value
- Word 6 : Initial L value
- Word 7 : Initial P value

The context is used for initializing and restarting a task, and for protecting its status when the corresponding level is activated or de-activated.

When activated, a task level defines in the context table (CTX) the specific pointer fo the associated context. P-, L-, G-, A-, E- and X-registers, as well as the status indicators are loaded from the context area and program execution begins at address P.

Conversely, when a level is interrupted by a higher priority level, or when it is acknowledged, the current contents of P-, L-, G-, A-, E- and X-registers and of the status indicators are stored in the context area.

For further details, see DIT instruction description (Chapter VII).

#### III-6. SECTION CALLS

There are two kinds of sections :

- sections pertaining to a given program, accessible through a CALL SECTION (CLS).

- sections available to all programs : supervisor section or common library section, accessible through a CALL SUPERVISOR (CSV).

Program section call (CLS instruction)

During the execution of a CLS instruction, the processor :

- stores the contents of P (program address) and L (local data base) in the first two words of the called section's local area (after subtracting G-base). These elements are required for "returning" to the task and therefore must be saved.

- Loads P- and L-registers with the starting address and the local data segment address, respectively, of the called section which may then be executed.

During the execution of a RTS (ReTurn Section), the processor :

- Restores in P- and L-registers the values which had been saved at the beginning of the called section's local segment.

#### Note :

When several sections of a program are separately assembled, if one contains a call to another, it is not necessary to declare that the calling section is external to the module. This declaration is implicit and the linkage editor performs the necessary checks.

The transfer diagram is given in the description of CLS instruction (Chapter VII "Instructions").

#### Supervisor call (CSV instruction)

The supervisor sections and the sections constitued by common sub-programs make up the "resident operating system".

Hereafter, we shall call "system section" a section of the operating system.

A "system section" :

a) remains at the calling program's priority level;

b) processes both the calling task's data and its own local data;

c) is automatically executed in master mode.

Moreover, since a task is identified by its G-base value it is logical to associate the call with this base rather than L-base.

In the CALL SUPERVISOR, i.e. in a system section, G has the same function as L in the CALL SECTION.

Paragraph (c) above, which is associated with class 0 addressing modes (see chapter V), implies paragraph (b) since a system section may :

- access its own data in LD, LI and LIX addressing modes, it being understood that these data have absolute addresses and, therefore, system sections are resident with an implicit zero local base. (In this respect, the operating system is a single program).

- access the calling task data in GD and GIX addressing modes, since the general base G remains that of the calling task.

When executing a RETURN SUPERVISOR instruction (RSV), the processor restores in L- and P-registers the values which had been previously saved in the calling program's TWB.

The mode of the calling program is automatically re-established by RSV instruction.

The communication diagram of a supervisor call is given in the description of CSV instruction (Chapter VII).

#### Example of re-entrant section programmation

M:MOVE module of MOB Monitor for moving a byte string.

• Main program

| PRINC                                                        | CDS<br>RES<br>FIN                                                  | 16                                                 | <b>TWB</b>                                                                                                                                                                                                   |
|--------------------------------------------------------------|--------------------------------------------------------------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LDS1<br>CH1<br>CH2                                           | LDS<br>TEXT<br>RES,1<br>FIN                                        | "ABCDEFGHIJ<br>12                                  | KL"                                                                                                                                                                                                          |
| LPS1<br>DEB                                                  | LPS<br>LEA<br>XAX<br>LEA<br>LDE<br>CSV<br>FIN<br>END               | LDS1<br>CH2<br>CH1<br>=12<br>M:MOVE<br>DEB<br>LPS1 | Parameters loading                                                                                                                                                                                           |
| <ul> <li>M:MOVE re−e</li> </ul>                              | entrant module                                                     |                                                    |                                                                                                                                                                                                              |
| FICTIV<br>T0<br>T1<br>T2<br>T3<br>T4<br>T5<br>T6<br>T7<br>N3 | CDS<br>RES<br>RES<br>RES<br>RES<br>RES<br>RES<br>RES<br>RES<br>RES | DUM 4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1          | Dummy TWB. Generates no object code.<br>Used for proper generation of instruction displacements<br>in the LPS.<br>Since a CSV does not alter G-base value, M:MOVE<br>will operate in the main program's TWB. |
| N2<br>N1<br>N0                                               | RES<br>RES<br>RES<br>FIN                                           |                                                    |                                                                                                                                                                                                              |
| SUPER                                                        | LDS<br>FIN                                                         |                                                    |                                                                                                                                                                                                              |
| M:MO∨E                                                       | LPS<br>SPA<br>BRU<br>RSV                                           | SUPER<br>ĦN0<br>\$+2                               | Entry point of the module for the CSV.                                                                                                                                                                       |
| R:MO∨E                                                       | XEX<br>DST                                                         | <i>#</i> / T0                                      | Entry point of the module for a branch instruction                                                                                                                                                           |
| c                                                            | DCX<br>BCF<br>LBR<br>SBR<br>BRU                                    | =1<br>O<br>a #/T1,X<br>a #/T0,X<br>C               |                                                                                                                                                                                                              |

| 0 | LDA | # Tl   |
|---|-----|--------|
|   | BRU | a # N0 |
|   | FIN |        |
|   | END |        |

#### III-7. SYSTEM'S MANAGEMENT CONCEPTS

#### Functions of the Supervisor

- Task management : connection at interrupt levels, queuing and "distribution" functions.

- Input/Output management : initialization on user's call, checking of interrupt-initiated transfers termination, etc...

- Resource management : reservation and release on user's call.
- Event management.
- Delay management.
- Etc...

#### Operation and re-entrance of Supervisor calls



\_\_\_\_\_ Supervisor's processing at task's level

The Supervisor operates at the level of the calling task and this provides supervisor context protection at this level.

Besides, for full re-entrance capability, variable data operated upon by the Supervisor must be stored in an area specified by the calling task : this is the purpose of the TWB described in paragraph III-5.

#### Data area management

#### • System common data area

In order that a relative address may always be positive with respect to any G-base value, this area is located in the upper portion of the memory.

It comprises a group of fixed-length blocks which are dynamically assigned on user's request.

To have the program relocatable with respect to this area, it is the address ZC of the whole common area which the Supervisor stores in G + 6, in relative value with respect to G, the address of the actually assigned block being provided in a register (preferably X) as a relative value with respect to ZC. This address is assigned by the Loader. The task will address this block in GIX mode with :

- D = 6,

- -(G + 6) = ZC,
- (X) = Block address with respect to ZC.

To progress in the block, the task increments or decrements X-register.

This procedure has an obvious advantage :

When a program is dynamically relocated, e.g. after a swapping, the only action of the system is to update (G + 6) contents with the new ZC relative address to provide the connection with its data, without any attention from the user.

Thus, the main purpose of this area is :

- to provide communication between separate programs,
- to allow for dynamic relocatability of the programs.
- Program common data area

Every program includes a common data section (CDS) accessible in general addressing mode. This addressing mode. This addressing being always relative to G-base, the actual location of the program may be unknown to the user without any influence on the programmation.

• Local data areas

Since every program section may have a local data area, the corresponding base must be updated at the beginning of the section (when a called section is entered) or upon return to the calling section.

This updating is automatic and requires no attention from the programmer who needs only state the name of the section to be executed.

The linkage editor builds a relative location table in which every section is defined by the relative addresses of its entry point and local data segment.

Some programs may require a direct access to more than 256 bytes in a data segment; this is provided for by instructions for incrementing and decrementing L-base, where by the direct access area is shifted. The Assembler is made aware of such shifting by a BASE pseudo-instruction.

# <u>mitra 15</u>

# 4. Assembly language

The Assembler is a language translation processor which converts a source program, written in "symbolic assembly language", into an object program.

The programmer is assisted in its task by the following convenient features :

- assembly "pseudo-instructions" for generating data of various kinds,

- possibility of sharing the job between several programmers (program divided into segments and sections),

- possibility of easily writing re-entrant sub-routines owing to full separation of data and work areas.

The source program is processed in a single assembly pass during which :

- every source line is read,

- symbols are entered into tables,

- relative addresses are assigned at the beginning of declared segments,

- pseudo-instructions are executed,

- the "relocatable binary" (RB) object text is edited along with a directory of satisfied references, the object listing and a list of errors which have been detected at this level,

- "forward" or downstream references, which cannot be solved by the Assembler, are actually processed by the Linkage Editor.

MITRAS 1 Assembler requires the following minimum hardware resources :

- 4 K-words of core memory (including I/O processing), and

- a console typewriter (Teletype ASR33).

MITRAS 2 Extended Assembler requires an additional 4 K-word memory module.

Remarks :

1. Hereafter the features which are available with MITRAS 2 only are distinctly pointed out by a vertical dotted line in the margin.

Pseudo-instructions which are not accepted by MITRAS I are underlined.

2. MITRAS 1 Assembler requires about 4800 bytes (without label table) thus leaving, under MOB basic monitor, about 1000 bytes of table space, i.e. 100 common labels.

Source language instructions are of two kinds :

- Machine code instructions, which are each converted into a single machine word specifying an instruction executable by MITRA 15's internal logic. In the following they will be called "instructions".

- Assembly instructions which are command statements controlling the assembler either for assembly procedure, or for data or text generation. In the following they will be called "pseudo-instructions".

## IV-1. SOURCE LINE FORMAT

IV-1.1. Instruction or pseudo-instruction line

An instruction or pseudo-instruction line has a maximum of four fields :

- a label field :

Always beginning at column 1 and containing a 1 to 6-character symbol beginning with an alpha character and ending with a blank column.

- a command field :

Beginning at the first non blank column after the label field (or at the first non blank column after column 1 when the label field is unused) and ending with a blank column. This field must contain a command statement both for an instruction and a pseudo-instruction.

- an argument field :

Beginning at the first non blank column after the command field and ending with a blank column, except if the first non blank column contains a special character "\*" in which case this field is ignored as such.

The argument field cannot extend beyond column 57 with MITRAS I and column 72 with MITRAS 2.

– a comment field :

Beginning at the first column after the special character "\*".

#### IV-1.2. Comment lines

A comment line is a line the first non blank character of which is a special character "\*". These lines are ignored by the Assembler but appear in the object listing.

IV-1.3. Blank lines

Blank lines are accepted and treated as empty comment lines.

#### IV-2. BASIC CHARACTER SET

The Assembler accepts all the following characters :

- alphabetic characters : letters A through Z and ":".

- numeric characters : digits 0 through 9.

-- special characters : blank + - \* / . , () " = # \$ % & a etc.

Furthermore it accepts all characters recognized by the peripherals. These characters make up a subset of EBCDIC.

No check is performed on the characters which are included in a comment field or a byte string.

#### IV-3. SYMBOLS

A symbol is an identifiable group of up to 6 alphanumerical characters, the first of which is alphabetical. No blank or special characters are allowed.

A symbol is defined when it appears in the label field of a source line.

in all cases, a symbol identifies the source line to which it belongs.

4057 U

It may also identify the memory address of the code generated by the source line. In such a situation, a numerical value is assigned to the symbol and is equal to the most significant byte memory address.

IV-3.1. Pseudo-instructions prohibiting assignment of a value to the label

Those are :

GOTO, BASE, BND, DEF, REF, FIN, END, PAGE

A symbol may appear in the label field, but no value is assigned to it.

Its only purpose is to mark the corresponding line in the argument field of a GOTO pseudo-instruction.

#### IV-3.2. Commands for assigning an address value to the label

- Assignment commands :

the EQU pseudo-instruction provides for assigning a numerical value to the symbol in a label field.

- Generation commands :
- . Machine instructions
- . Generation of pseudo-instructions :

RES, DATA, GEN, TEXT, DO.

. Segmentation pseudo-instructions :

CDS, LDS, IDS, LPS, BASE.

Any symbol appearing in the label field of such a command is entered into the assembly symbol table and an address value is assigned to it.

The address value is always relative to the beginning of the segment which contains the symbol in a label field.

An address value specified in operand field of DATA and <u>GEN</u> pseudo-instructions will be relocated, at linkage edition time, by the value of L or P base of the segment in which it has been defined, so as to become relative to the general base G of the program.

In resident programs declared in Master Mode, the loader will generally relocate the address values by the general base G, since, in that case, local mode indirect addresses must be absolute.

However, in a LDS, it is possible to force a label expression to remain relative to the base, even for a program executable in Master Mode.

For this, the label expression must be preceded by the special character "#".

This procedure is allowed in a CDS, though it is basically ineffective.

#### IV-4. CONSTANTS

Data may be directly entered in assembly language as alphanumerical constants. Three types of constants are permitted in statements :

IV-4.1. Decimal integer constants

A decimal integer constant is represented by a decimal integral number of 5 digits or less, with or without a sign :

۵ 🍅

Example: +75 75 -75

The maximum absolute value for an unsigned number is  $2^{16} - 1 = 65,535$ .

The constant generated by the Assembler is in pure binary form (in two's complement for negative values) and occupies the area specified in the generation pseudo-instruction.

# IV-4.2. Hexadecimal constants

A hexadecimal constant is represented by an integral hexadecimal number of 4 digits or less, preceded by the special character "&".

Example : &1A &E3FF

## IV-4.3. Character string constants

A character string constant is a sequence of alphabetical, numerical or special characters in quotation marks. The internal representation of normalized characters is "EBCDIC".

A translation module included in all standard monitors provides for automatic translation ASCII-EBCDIC and EBCDIC-ASCII, should they be required; this translation is performed by the input-output system.

Example : "CHARACTER STRING"

A quotation mark is represented in the string by two consecutive quotation marks.

```
Example :
"NEXT""CHARACTER" represents : NEXT"CHARACTER
```

# IV-5. EXPRESSIONS

An expression is made up of one or several symbols or constants combined through arithmetic operators

An expression is represented by a single value which is computed by the Assembler or by the Linkage Editor according to the rules specified in section IV-3.2.

An expression is said to be computable when its value may be determined at the first encounter; therefore, it must contain no forward or external references.

#### IV-5.1. Operators

The Assembler accepts the following operators :

"Minus" unary operator (example : -3)

Subtraction operator (example : A-3)

#### + Addition operator

When the unary minus operator is followed by a constant, the Assembler generates the latter in pure binary two's complement form.

# (V-5) 2 Expression evaluation

Two kinds of expressions are to be considered :

- label expression :

A symbol identifying a specific memory location whose address is the value of the label.

Such a symbol may be reduced to the special character \$ in which case it specifies the current location counter value.

- Predefined symbol :

A predefined symbol specifies no memory location; its value is absolute and defined by EQU pseudo-instructions preceding its utilization.

- (Forward) reference

A forward reference is a symbol which has not yet been defined. It may be defined later on either by a label, or through an EQU or REF pseudo-instruction.

- Conventional representations :

Elements of assembly language syntax are represented by their denominator contained between square brackets (e.g. : < expression>).

The definition is given as an identity relation the lefthand portion of which is the representation of the elements to be defined. The identity symbol is ": : =" and the righthand portion specifies the various compositions of the elements to be defined. When this portion contains several elements in succession, the latters must appear in the same order. However, when such elements are separated by "slash marks" (/), one must select one or the other.

## Example 1 :

<ab> :: = - <value>/<value>

In this case, "ab" may be indentical with "-value" or "value".

## Example 2 :

<value> :: = <term>/<value><sign><term>

In this case, "value" may be identical with "term" or "value" followed by "sign" followed by "term". This is equivalent to the statement that "value" is a sequence of "term" separated by a "sign".

## MITRAS | Version

<Term > :: = < constant>/<predefined symbol>

<Constant> :: = <integral decimal constant>/<integral hexadecimal constant>

<Label expression> :: = < label>/<label> <sign> < term>

<Reference expression> :: = < reference >/< reference > < sign> < term>

< Sign> :: = + / -

<Predefined expression> :: = < term>/-<term>/<label expression>

Predefined expressions are always computable by the Assembler. Some expressions may be computable at linkage edition time only.

# MITRAS 2 Version

< Constant> :: = < integral decimal constant>/< integral hexadecimal constant>

<Term> :: = < constant>/<predefined symbol>

< Displacement> :: = < label>- < label>

<Value> :: = <term>/<displacement>/<value>+<displacement>/<value><sign><term>

<Label expression> :: = <label>/<label><sign><value>

<Reference expression> :: = < reference>/<reference><sign> <value>

<Predefined expression> :: = <value>/-<value>/<label expression>

<Expression> : same structure as for "predefined expression", but any label may be replaced by an address reference.

Predefined expressions are always computable by the Assembler. Some expressions may be computable at linkage edition time only.

Remark :

A label may be reduced to the special character \$ (current value of the location counter) but only as the first term of an expression.

# Example of such label expressions :

\$ + 2 valid

2 + \$ invalid

# 5. Addressing modes

# V-1. SYMBOLIC REPRESENTATION OF THE INSTRUCTIONS

## V-1.1. Representation conventions

Hereafter the following representation conventions will be used :



One of the terms between braces may be specified and excludes all others (possible terms are stacked vertically).



The term between square brackets may be omitted being either optional or implicit.

- . . .

The expression bounded by the end separator immediately preceding the ellipsis mark and the associated begin separator may be repeated.

Examples :

 $\left\{ \begin{array}{c} A \\ B \\ C \end{array} \right\} \left[ \begin{array}{c} , D \end{array} \right]$ 

One term out of A, B and C must be specified, D is optional.

 $\left\{ \begin{bmatrix} A \\ B \\ C \end{bmatrix} \right\}$ 

One term out of A, B and C must be specified, but A may be omitted when selected.

$$\left\{\begin{array}{cc} A & [,B] \dots, C \\ D & \end{array}\right\} \dots$$

The expression between braces may be repeated; in the first possible term, B element is optional but may be repeated.

# V-1.2. Instruction representation

All instructions are represented in accordance with the following format :

$$\begin{bmatrix} |abel] OP \\ \begin{bmatrix} \\ a \\ b \end{bmatrix} = \begin{bmatrix} \\ a \\ b \end{bmatrix}$$

Wherein :

| OP  | : Operation code                                                |
|-----|-----------------------------------------------------------------|
| D   | : Displacement                                                  |
| =   | : Immediate addressing (parameter) operand value = displacement |
| ລ   | : Indirect addressing                                           |
| #   | : Relative addressing with respect to general base (CDS)        |
| , X | : Indexing                                                      |

#### Remark :

For instructions or pseudo-instructions whose name has four characters, the first three only are used for operation code recognition purpose.

## V-2. ADDRESSING MODE REPRESENTATION

#### V-2.1. Addressing class

MITRA 15 addressing capabilities are adapted according to the various instruction operation codes.

Addressing functions may be classified into three main groups corresponding to three instruction classes :

## Class 0 instructions

These instructions control the following operations

- register load and store operations
- fixed-or floating-point arithmetic operations
- logical operations
- byte string operations
- comparaison
- Class 2 instructions

These are conditional or unconditional branch instructions.

- Class 1 instructions
- shift operations
- index operations
- base operations
- section or supervisor calls
- input/output operations
- register operations
- interrupt and interrupt masking operations

These three groups make up a very comprehensive instruction set which will be discussed later on after a brief description of addressing forms pertaining to each type.

The following conventions are used in the dicussion :

- L Local base
- G General base
- G' General base in slave mode or zero in master mode
- X Index register
- P Program base
- D Displacement
- () Contents of
- Class 0 addressing

| Mode                              | Assembly<br>language | Addressed data                                                                                                                        | Addressing<br>function |
|-----------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| Direct, Local<br>DL               | IDENT                | Byte, word or double-word<br>located in the first 256 bytes<br>of the local segment.                                                  | Y=(L)+D                |
| Indirect, Local<br>IL             | a ident              | Byte, word or double-word<br>located anywhere and pointed<br>at through the local segment.                                            | Y=G'+((L)+D)           |
| Indirect, Local, Indexed<br>ILX   | <sup>a</sup> ident,x | Element of a byte, word or<br>double-word array located<br>anywhere and pointed at<br>through the local segment.                      | Y=G'+((L)+D)+(X)       |
| Direct, General<br>DG             | ₩ IDENT              | Byte, word or double-word<br>located in the first 256 bytes<br>of the common segment.                                                 | Y=(G)+D                |
| Indirect, General, Indexed<br>IGX | _ â#IDENT,X          | Element of an array pointed<br>at through the common<br>segment.                                                                      | Y=(G)+((G)+D)+(X)      |
| Parameter or immediate<br>P       | =OPERAN D            | A 1-byte operand is specified<br>in the instruction. This byte<br>may be extended on the left<br>by 8 leading zeroes, if<br>required. | (Y) = D<br>Y = (P)     |

# Example of class 0 addressing

Common segment

Local segment



| I   | nstruction | Operand |
|-----|------------|---------|
| LDA | #CSCAL     | INFO 6  |
| DLD | a#CTAB, X  | INFO 5  |



| ł | In  | struction       | Operand |
|---|-----|-----------------|---------|
|   | LDA | SCAL            | INFO 1  |
|   | LDA | <b>@POINT</b>   | INFO 2  |
|   | LBR | a <b>tab,</b> Χ | INFO 3  |

| Ins | Operand  |        |
|-----|----------|--------|
| LDA | = INFO 4 | INFO 4 |

# Class 1 addressing

This class includes :

- either instructions without actual operand, i.e. register contents swapping, section end, etc...

- or instructions whose operand is generally known (possibly through an unknown modifier) at programmation time : shift, increment, index, etc.

The following modes are permitted :

| Mode                        | Assembly<br>Language | Operand                                                      | Addressing<br>function |
|-----------------------------|----------------------|--------------------------------------------------------------|------------------------|
| Parameter or immediate<br>P | =PARAM.              | Operand defined by displacement value                        | (Y)=D<br>Y=(P)         |
| Parameter, Indexed<br>PX    | =PARAM,X             | Operand defined by value plus X-register contents.           | (Y)=D+(X)<br>Y=(P)     |
| Direct, Local<br>DL         | IDENT                | Operand located in the first 256 bytes of the local segment. | Y=(L)+D                |

#### Remark 1 :

To simplify program writing, a number of symbolic instruction codes recognized by the Assembler specify both the operation code and the displacement.

For example SRG, which is a register instruction, is specified through its displacement :

| SRG         | = 02                   | exchange A and E          |
|-------------|------------------------|---------------------------|
| SRG         | = 04                   | A and X                   |
| SRG         | = 06                   | E and X                   |
| •           |                        |                           |
| SRG         | = 1 C                  | -A A                      |
| •           |                        |                           |
| •<br>etc.   |                        |                           |
| In actual p | ractice, for the Assem | bler,                     |
| XAE         |                        | is equivalent to SRG = 02 |
| XAX         |                        | SRG = 04                  |
| XEX         |                        | SRG = 06                  |
| •           |                        | :                         |
| CNA         |                        | $\dot{SRG} = 1C$          |
| :           |                        | -                         |
| •<br>etc.   |                        |                           |

In addition, MITRAS 2 Assembler recognizes 14 shift instruction mnemonics which specialize the two operation codes SHR and SHC.

| Exam | ples : |  |
|------|--------|--|
|      |        |  |

| SHR = &23 | equivalent to | SRCS = 3  | (shift, right, circular, single) |
|-----------|---------------|-----------|----------------------------------|
| SHR = &E8 | equivalent to | SRCD = 8  | (shift, right, circular, double) |
| SHC = &OB | equivalent to | SLLD = 11 | (shift, left, logical, double)   |
| SHC = &4E | equivalent to | SRLD = 14 | (shift, right, logical, double)  |

Remark 2 :

Instructions CLS and CSV may be used in two different ways :

a) The operand is a LPS name; the Assembler generates a blank word and the Linkage Editor determines, one the one hand, if the instruction to be generated is a CLS or a CSV according to the section type (monitor or user section) and, on the other hand, the corresponding section number.

This is the normal case wherein the user is not concerned with the section number.

b) The operand is not a LPS name. These instructions are treated as any class 1 instruction, the three addressing modes being available.

Example for a program module

|   |        |                   |                | T            |
|---|--------|-------------------|----------------|--------------|
|   | PROG   | CDS<br>RES<br>FIN | 16             |              |
|   | LI     | LDS<br>FIN        |                |              |
|   | Pl     | LPS<br>RTS        | LI             |              |
|   |        | FIN               | Pl             |              |
| ſ | L2     | LDS<br>FIN        |                |              |
|   | P2     | LPS<br>RTS        | L2             |              |
|   |        | FIN               | P2             |              |
|   | L3     | LDS<br>FIN        |                |              |
|   | P3     | LPS<br>RTS        | L3             |              |
|   |        | FIN               | P3             |              |
|   | L4     | LDS<br>RES        | 3              |              |
|   | NUMSEC | DATA<br>FIN       | 3              |              |
|   | P4     | LPS               | L4             |              |
|   | DEB    | CLS               | S1             | Call S1      |
|   |        | CLS               | = 2            | Call S2      |
|   |        | LDX               | = 1            |              |
|   |        | CLS               | = 2, X.        | ← Call S3    |
|   |        | CLS               | NUMSEC         |              |
|   |        | CSV               | M:EXIT         | Call monitor |
|   |        | FIN<br>END        | DEB<br>P4      |              |
| Ĺ |        |                   | ſ <del>4</del> | J.           |

These utilizations require the knowledge of the section number in the program's PRT

Note : CLS NUMSEC is not available with MITRAS 1.

# Class 2 addressing

Normally, instructions pointed at by a branch instruction belong to the same section as the branch instruction. However program section length is unlimited.

Four addressing modes are permitted :

| Mode                             | Mode Assembly Branch instruction |                                                        | Addressing<br>function |
|----------------------------------|----------------------------------|--------------------------------------------------------|------------------------|
| Relative downstream<br>(plus) RP | LABEL                            | Any instruction within 512 bytes downstream            | Y=(P)+2D               |
| Relative upstream<br>(minus) RM  | LABEL                            | Any instruction within 512 bytes upstream              | Y=(P)-2D               |
| Indirect, Local<br>IL            | ູລLABEL                          | Any instruction pointed at through the local segment.  | Y=G'+((L)+D)           |
| Indirect, General<br>IG          | ◎#LABEL                          | Any instruction pointed at through the common segment. | Y=G'+((G)+D)           |

In addition, an indexed unconditional branch instruction is also available. For indirect branch instructions, the index is used for pre-indexation (more convenient for "Branch table" processing), contrary to data indexation which is a post-indexation (more convenient for accessing element of an array).

# Examples :



# V-2.2. Permitted expressions

```
    Class 0
```

Predefined or reference expression

- Class 1
- P : value
- PX : value
- DL : predefined or reference expression

# Class 2

- RP : reference expression
- RM : label expression
- DL : predefined or reference expression
- DG : predefined or reference expression

# 6. Pseudo-instructions

# VI-1. SOURCE TEXT SEGMENTATION

## VI-1.1. General

The source text is translated by the Assembler into an object module in "relocatable binary" format (RB). The Assembler can only satisfy the reterences to symbols of the assembled source text.

The Assembled modules are converted by the Linkage Editor into a complete program represented by a "relocatable memory image" (RMI). All external references (section names) between program modules are then satisfied.

The RMI is loaded into core by the Loader starting from a general base address G which is only defined at loading time.

#### VI-1.2. Source text

The source text is the assembly unit. It comprises one or several segments and must be terminated by an END pseudo-instruction.



# VI-1.3. Common data section

If the assembly module is to include an actual or dummy common data section (CDS), the latter must always be declared before any other segment of the assembly module.

## VI-1.4. Sections

Every section must include an executable local program segment (LPS) which defines the section. A local data segment (LDS) is normally associated with a LPS.

When such a LDS is actually defined in the same module as the LPS, it must precede the latter in the source text. Several LPS may be associated with a single LDS and the number of sections is equal to the number of LPS.

## VI-1.5. Identifier scopes

Identifiers may be classified into internal labels defined within the assembly module, and external labels declared through DEF and REF pseudo-instructions.

## Internal labels

#### • Labels defined in the CDS

These labels are defined for the whole assembly module and may be referenced from any segment. However, they connot be redefined as local labels without causing a "double definition" error.

#### • Labels defined in a LDS

These labels are defined until the appearance of another LDS pseudo-instruction.

They may be referenced from the CDS, from the LDS itself and from any LPS following the LDS in which the label is defined, up to a new LDS.

#### • Labels defined in a LPS

They may be referenced from LPS itself, from the CDS or from the associated LDS (which normally precedes the LPS).

#### External labels

A label is said to be "external" when it has a meaning outside the assembly module in which it has been defined (where it appears in label field).

Thus, being known at linkage edition time, it provides a convenient link to other modules without resorting to a CDS (actual or dummy) or to a Call Section.

A label is external when declared through a DEF pseudo-instruction which must appear in the segment in which the label has been defined.

The external label may be referenced in another module provided that it is declared in the latter module through a REF pseudo-instruction. The REF pseudo-instruction must appear in the segment where the external label is used.

The "external" status does not modify the notions of "common" or "local" labels, for the Assembler.

When a label belonging to the CDS is to be declared in a REF pseudo-instruction, it must be preceded by a "#" special character.

Example :

REF #LAB1, #LAB2, #LAB3

Do not confuse external labels and segment names. The latters, though known outside the assembly module at linkage edition time, are only accessible through Call Section or Call Supervisor.

Example :

| PROG<br>ETIQ0               | CDS<br>DEF<br>RES<br>DATA<br>FIN                  | ETIQ0<br>16<br>1                   |
|-----------------------------|---------------------------------------------------|------------------------------------|
| LDS1<br>ETIQ1               | LDS<br>RES<br>DEF<br>REF<br>DATA<br>DATA<br>FIN   | 8<br>ETIQ1<br>ETIQ3<br>2<br>ETIQ3  |
| LPS1<br>Z                   | LPS<br>REF<br>LDA<br>FIN<br>END                   | LDS1<br>ETIQ2<br>ETIQ2<br>Z        |
| LDS2<br>X<br>ETIQ2<br>ETIQ3 | LDS'<br>REF<br>REF<br>DATA<br>DATA<br>DATA<br>FIN | ETIQ1<br>₩ETIQ0<br>ETIQ1<br>0<br>4 |
| LPS2<br>Y                   | LPS<br>LDA<br>STA<br>LDA<br>FIN                   | LDS2<br>#ETIQ0<br>X<br>ETIQ1<br>X  |

Remark :

It is important to remember that, for local external labels, the displacement is generated relative to the LDS of the section containing the corresponding DEF but used relative to the LDS of the section containing the corresponding REF.

#### VI-1.6. Location counter

The location counter contents is a byte address with a maximum value of  $2^{16}$  - 1 = 65 535.

The location counter is symbolically represented by the special character "\$".

This counter is reset to zero at every segment declaration, so that all references calculated at assembly time are always relative to the starting address of the declared segment.

## VI-1.7. Segmentation pseudo-instructions

These pseudo-instructions define the assembly module structure in terms of sections and segments.

They are :

- Common data section : CDS
- Local data segment : LDS
- Indirect data segment : IDS
- Executable local program segment : LPS
- ~ End of segment : FIN
- End of module : END

Every segment opened by a segmentation pseudo-instruction must conclude with a FIN pseudo-instruction.

## CDS/FIN pseudo-instruction

This pseudo-instruction identifies the common data section CDS.

Format :

| Label              | Command | Argument |
|--------------------|---------|----------|
| <name></name>      | CDS     | [DUM]    |
| [ <label>]</label> | FIN     |          |

Result :

- The location counter is reset.
- All labels may be referenced form the module declared sections.
- If DUM option is specified, no code is generated and the section is dummy.

■ LDS/FIN pseudo-instruction

This pseudo-instruction identifies a local data segment LDS.

Format :

| Label              | Command  | Argument |
|--------------------|----------|----------|
| <name></name>      | LDS<br>: | [סטא]    |
| [ <label>]</label> | FIN      |          |

Result :

- The location counter is reset.
- "Name" defined in label field is an implicit external definition.
- If DUM option is specified, no code is generated and the segment is dummy.

# ■ IDS/FIN pseudo-instruction

This pseudo-instruction identifies an indirect access data segment within a LDS or CDS. This segment is such that any label located between the IDS pseudo-instruction and the associated FIN pseudo-instruction is defined in relative value within the declared indirect segment.

# Format :

| Label              | Command | Argument |
|--------------------|---------|----------|
| <name></name>      | IDS     | [DUM]    |
|                    |         |          |
| [ <label>]</label> | FIN     |          |

# Result :

- The location counter is reset, but its current value is saved.

When the indirect segment IDS has been terminated by a FIN pseudo-instruction, the location counter is restored to its previous value incremented by its current relative value (zero if the IDS is dummy).

- If the DUM option is used, no code is generated and the segment is dummy.

- A label defined in an IDS pseudo-instruction is treated as a normal LDS label for an actual IDS, or as a zero value for a dummy IDS.

# ■ LPS/FIN pseudo-instruction

This pseudo-instruction identifies an executable program segment LPS and thus a program section.

# Format :

| Label              | Command | Argument            |
|--------------------|---------|---------------------|
| <name-1></name-1>  | LPS     | <name-2></name-2>   |
|                    |         |                     |
| [ <label>]</label> | FIN     | <label-2></label-2> |

# Result :

- The location counter is reset.

- < Name-1> identifies the LPS and the section; this is an external implicit definition.

The name referenced in a CALL SECTION is the corresponding external implicit reference.

- < label-2> is the effective starting address for section execution.

- <Name-2> references the associated LDS.

# END pseudo-instruction

This pseudo-instruction marks the end of an assembly module.

# Format :

| Label              | Command | Argument                       |
|--------------------|---------|--------------------------------|
| [ <label>]</label> | END     | [ <section name="">]</section> |

# Result :

- The assembly of the module is terminated.

- < section name> specified in argument field defines the first section executed after program loading. This label constitues an implicit external reference.

- At linkage edition time, only one END pseudo-instruction may be encountered and its argument field must declare a section name.

# Processing of %EOD

It should be noted that the Assembler's symbolic input file is a source file terminated by a standard end-of-file record (%EOD).

This file end marker is not strictly necessary for program end recognition, however the absence of %EOD will cause an undetermined operation sequence, particularly under linking module control.

An %EOD record detected before an END pseudo-instruction (i.e. in the course of a program) is indicated by a third level error causing immediate assembly abortion.

# VI-2. ASSEMBLY PSEUDO-INSTRUCTIONS

These statements are used either to direct common or local data assembly or executable program segment assembly.

Assembly pseudo-instructions are classified as follows :

| Pseudo-instruction                         | Data<br>Segment | Program<br>Segment |
|--------------------------------------------|-----------------|--------------------|
| 1. <u>Addressing</u><br>RES<br>BND<br>BASE | x<br>x          | x<br>x             |
| 2. <u>Symbol definition</u><br>EQU         | x               | x                  |
| 3. Assembly control<br>GOTO<br>DO<br>PAGE  | x<br>x          | x<br>x             |
|                                            |                 |                    |

| Pseudo-instruction                    | Data<br>Segment | Program<br>Segment |
|---------------------------------------|-----------------|--------------------|
| 4. Data generation                    |                 |                    |
| DATA                                  | X               |                    |
| TEXT                                  | X               |                    |
| GEN                                   | X               | X                  |
| 5. External definition identification |                 |                    |
| DEF                                   | X               | x                  |
| REF                                   | ×               | x                  |

# VI-2.1. Assembly of a data segment

- Addressing statements
- RES pseudo-instruction

Reservation of a memory area.

Format :

| Label              | Command  | Argument        |
|--------------------|----------|-----------------|
| [ <label>]</label> | RES [,1] | <value></value> |
| τοτο               | RES      | 3               |
|                    | RES,1    | 5               |

# Result :

- The [,1] option specified in the command field, indicates that the reservation unit is the byte, otherwise it is the word.

- If the selected unit is the word, the location counter is first advanced to the word boundary.

- The value which is assigned to the symbol defined in label field points at the first address of the reserved area.

# • BND pseudo-instruction

The location counter is advanced to a word boundary.

| Label              | Command | Argument |
|--------------------|---------|----------|
| [ <label>]</label> | BND     |          |
| τοτο               | BND     |          |

# Result :

The location counter is advanced to an even value, i.e. a word boundary.

# Symbol definition statement : EQU pseudo-instruction

## Format :

| Label | Command | Argument                                                                                                                       |
|-------|---------|--------------------------------------------------------------------------------------------------------------------------------|
| Name  | EQU     | <predefined expression=""><br/>/"<character>"<br/>/"<character> <character> "</character></character></character></predefined> |
| ZON   | RES     | 4                                                                                                                              |
| τοτο  | EQU     | ZON                                                                                                                            |
| ΤΑΤΑ  | EQU     | ZON+2                                                                                                                          |
| τυτυ  | EQU     | 5                                                                                                                              |
| ТІТІ  | EQU     | "A B"                                                                                                                          |

# Result :

- An expression specified an argument field defines the symbol which is declared in label field. No forward reference is allowed in the expression.

- One or two alphanumeric characters between quotes (") may appear in argument field.
- The \$ symbol representing the current value of the location counter is allowed in argument field.
- Any symbol specified in label field of an EQU pseudo-instruction cannot be redefined.
- No string is allowed with MITRAS I.
- Assembly control statements
- GOTO pseudo-instruction

| Label           | Command        | Argument               |
|-----------------|----------------|------------------------|
| <lapel></lapel> | <u>GOTO</u> ,k | <label 1=""> ,</label> |
|                 |                | <label 2="">,</label>  |
|                 |                | <label n=""></label>   |
| тото            | GOTO ,2        | BR1, BR2, BR3,, BRn    |
| NN              | EQ U2          |                        |
| ΤΑΤΑ            | GOTO,NN        | BR1,BR2,BR3            |

Result :

- The assembler jumps to the source line whose label field contains the K label declared in argument field of the GOTO pseudo-instruction.

- K is a "value" type expression (see page IV-6 and IV-7) which may be calculated when the GOTO pseudo-instruction is processed.

- All labels declared in argument field must refer to source lines following the GOTO pseudo-instruction.

- When K is not comprised between 1 and n, an error message is edited and assembly is resumed at the line following the GOTO pseudo-instruction.

- If an END pseudo-instruction appears before the selected label is reached, the assembly process is interrupted and an error message is issued.

## • DO pseudo-instruction

Iterative assembly of an instruction.

Format :

| Label              | Command | Argument        |
|--------------------|---------|-----------------|
| [ <label>]</label> | DO      | <value></value> |
| τοτο               | DO      | 7               |
|                    | DATA    | &78A2           |

## Result :

- The absolute expression declared in argument field must be computable and provides an integral value less than 128 representing the number of iterative assemblies of the next line in sequence.

- The iteration index is symbolically represented by the special character "%" and may be included in the line to be assembled. At each iteration step it is replaced by the iteration counter contents.

- The iteration counter is initially set to 1 during the first loop.

- When the iteration is over, the assembly process is normally resumed at the second line after the DO pseudo-instruction.

- If the absolute expression is negative or zero, or if it is not computable (in the second case, an error message is issued), the Assembler directly steps to the second line after the DO pseudo-instruction.

- When a label is specified in label field, it is associated with the first generated byte.

Data and text generation statements

# • DATA pseudo-instruction

Data generation.

| Label              | Command        | Argument                                       |
|--------------------|----------------|------------------------------------------------|
| [ <label>]</label> | DATA [,1]      | [#] < exp 1> [,[#] <exp 2="">]</exp>           |
| τοτο               | DATA<br>DATA,1 | ETIQ1,#ETIQ2,ETIQ1-ETIQ2,3,&8AF2<br>7,&8E, 5+4 |

Result :

- A DATA pseudo-instruction generates data items having the values of "i-expressions".

- An "i-expression" is an expression as defined in IV-5.2. or a string of 1 or 2 characters. (The string is not allowed with MITRAS I).

- Every generated data item is right justified on one or two bytes, according to the selection or omission of [,1] option in command field.

- When a label is specified in label field, it is associated with the first generated byte.

- If  $\langle \exp 1 \rangle$  is preceded by a # symbol, the corresponding expression must be left relative to G during a master mode loading.

Remark :

Under MITRAS 2, operational labels (standard and user's) are common explicit symbols. Thus, an operational label may be specified in an I/O control block just by writing :

DATA,1 M:BI

in the case of M:BI operational label.

Under MITRAS I the operational number must be either specified directly or defined through an EQU pseudoinstruction.

For further information on operational labels, see chapter 8 "Input/Output control system".

Example :

| MITRAS 2    |                  |           |
|-------------|------------------|-----------|
|             | CDS              |           |
|             | •                |           |
|             | :<br>FIN         |           |
| LDS1        | LDS              | •         |
| СВ          |                  | 0<br>&80  |
|             | DATA,1<br>DATA,1 | M:EO      |
|             | DATA, I<br>DATA  | # STRING  |
|             | DATA             | 8         |
| STRING      | TEXT             | "WRITING" |
|             | FIN              |           |
| LPSI        | LPS              | LDSI      |
| DEB         | LEA              | СВ        |
|             | CSV              | M:10      |
|             | LEA              | СВ        |
|             | CSV              | M:WAIT    |
|             | CSV              | M:EXIT    |
|             | FIN              | DEB       |
|             | END              | LPSI      |
| END OF FILE |                  |           |

#### MITRAS 1

|             | CDS<br>:<br>FIN                                      |                                                             | M:EO        | CDS<br>EQU<br>FIN                                    | 6                                                           |
|-------------|------------------------------------------------------|-------------------------------------------------------------|-------------|------------------------------------------------------|-------------------------------------------------------------|
| LDS1<br>CB  | LDS<br>DATA<br>DATA,1<br>DATA,1<br>DATA<br>DATA      | 0<br>&80<br>6<br># STRING<br>8                              | LDS1<br>CB  | LDS<br>DATA<br>DATA,1<br>DATA,1<br>DATA<br>DATA      | 0<br>&80<br>M:EO<br># String<br>8                           |
| STRING      | TEXT<br>FIN                                          | "WRITING"                                                   | STRING      | TEXT<br>FIN                                          | "WRITING"                                                   |
| LPS1<br>DEB | LPS<br>LEA<br>CSV<br>LEA<br>CSV<br>CSV<br>FIN<br>END | LDS1<br>CB<br>M:IO<br>CB<br>M:WAIT<br>M:EXIT<br>DEB<br>LPS1 | LPS1<br>DEB | LPS<br>LEA<br>CSV<br>LEA<br>CSV<br>CSV<br>FIN<br>END | LDS1<br>CB<br>M:IO<br>CB<br>M:WAIT<br>M:EXIT<br>DEB<br>LPS1 |
| END OF FILE |                                                      |                                                             | END OF FIL  | E                                                    |                                                             |

# END OF FILE

- GEN pseudo-instruction
- Value generation

# Format :

| Label              | Command                | Argument        |
|--------------------|------------------------|-----------------|
| [ <label>]</label> | <u>GEN</u> , area list | Expression list |
|                    | GEN, 4, 2, 2           | 7,1,1           |
| τοτο               | GEN,1,1,3,8,2,1        | 0,1,2,&F2,3,1   |

# **Result :**

- The GEN pseudo-instruction generates a byte or word having a specific binary configuration.

- "Area list" is a sequence of term-type expressions each specifying the length (in bits) of an area to be generated. The generated areas must have a total length of 8 or 16 bits, and no zero-length area is allowed.

- "Expression list" a sequence of expressions of the same type as those which are defined by a DATA pseudoinstruction, defining the contents of every generated area. At assembly time, the listed values are inserted in the corresponding areas on a rank basis from left to right (first value in first area, and so on).

All values are right justified in their respective areas. The first area contains the most signifiant value.

The items of area list and expression list are separated by commas.

• TEXT pseudo-instruction

Generation of a character string.

Format :

| Label              | Command | Argument                             |
|--------------------|---------|--------------------------------------|
| [ <label>]</label> | TEXT    | " <character string="">"</character> |
| τοτο               | TEXT    | "CHARACTER STRING"                   |

Result :

- The character string is assemblied in EBCDIC format in an area beginning at the current address of location counter and ending at an address corresponding to the last generated character.

- The first character of the string is stored in the first byte of the area, and so on.
- If a label is specified in label field, it is associated with the first generated byte.

# • DEF pseudo-instruction

Format :

| Label                  | Command | Argument            |
|------------------------|---------|---------------------|
| [ <label-1>]</label-1> | DEF     | <label-2></label-2> |
|                        | DEF     | ETIQ                |

Result :

- Labels are declared as external definitions.
- Labels are defined in the current section.
- A label must be declared as external definition prior to being used in the section.
- REF pseudo-instruction

Format :

| Label              | Command | Argument            |
|--------------------|---------|---------------------|
| [ <label>]</label> | REF     | [#] <label></label> |
| ETIQ1              | REF     | ETIQI               |
|                    | REF     | ₩ ETIQ2             |

Result :

- Labels are declared as external definitions.

- The labels must be defined prior to being used in the current section and will be defined later on at assembly time.

- A label belonging to the CDS must be preceded by the symbol # .

# VI-2.2. Program segment assembly

# Addressing statements

# • RES pseudo-instruction

Reservation of a memory area (see section VI-2.1. page VI-7).

# BASE pseudo-instruction

Directs relative addressing.

Format :

| Label              | Command      | Argument           |
|--------------------|--------------|--------------------|
| [ <label>]</label> | BASE         | [ <label>]</label> |
| ETIQ               | BA SE        |                    |
| ETIQI              | <b>BA SE</b> | ETIQ2              |

# Result :

- The label declared in argument field is a LDS label.

- All LDS labels referenced in the program segment between two BASE pseudo-instructions are generated in relative value with respect to the address specified in argument field.

- A BASE pseudo-instruction without label declaration in argument field simply terminates the relative addressing specified by the preceding BASE pseudo-instruction.

- A new relative addressing requires another BASE pseudo-instruction with a label declaration in argument field.

- A BASE pseudo-instruction with label declaration in argument field terminates the relative addressing of the preceding BASE pseudo-instruction and opens a relative addressing on the new label declared in argument field.

- A BASE pseudo-instruction with label declaration is closed either by a new BASE pseudo-instruction or by a FIN pseudo-instruction which terminates the assembly of the program segment.

# Symbol definition statement : EQU pseudo-instruction

See section VI-2.1. page VI-7.

Assembly control statements

GOTO pseudo-instruction

Conditional assembly branch (see section VI-2.1. page VI-8).

•••••

Instruction generation statements

# • GEN pseudo-instruction

Generates a value. (See section VI-2.1. page VI-11).

This pseudo-instruction used in an executable program area allows to generates non-standard instructions specific to a special configuration.

If, after GEN pseudo-instruction, the incremented location counter is not on a word boundary (generation of an odd number of bytes), the Assembler signals an error, generates a zero value byte and steps the location counter by one unit.

- External definition identification statements
- DEF pseudo-instruction

See section VI-2.1. page VI-12.

• REF pseudo-instruction

See section VI-2.1. page VI-12.

# VI-3. PAGE PSEUDO-INSTRUCTION

This pseudo-instruction asks for printing the assembly listing on the next page, when the output device is a printer.

| Label                       | Command             | Argument |
|-----------------------------|---------------------|----------|
| [ <label>]<br/>ETIQ</label> | <u>PAGE</u><br>PAGE |          |

# 7. Instructions

# VII-1. GENERAL

This chapter describes MITRA 15's instruction set which is divided into eleven functional categories :

- Load and store instructions
- Fixed-point arithmetic operations
- Logical operations
- Register incrementation
- Shift operations
- Inter-register operations (SRG or set register)
- Floating-point arithmetic operations
- String processing instructions
- Branch instructions
- System communication instructions
- Control instructions

In addition, every instruction has three fundamental attributes :

• <u>Class</u> : indicating the permitted addressing modes and thus the exact meaning of the calculated address in each case.

| Class | Perm    | itted addressing modes     |
|-------|---------|----------------------------|
| 0     | DL<br>P | Direct, Local<br>Parameter |
|       | DG      | Direct, General            |
|       | IL      | Indirect, Local            |
|       | IGX     | Indirect, General, Indexec |
|       | ILX     | Indirect, Local, Indexed   |
| 0'    | DL      | Direct, Local              |
|       | DG      | Direct, General            |
|       | IL      | Indirect, Local            |
|       | IGX     | Indirect, General, Indexed |
|       | ILX     | Indirect, Local, Indexed   |
| 1     | DL      | Direct, Local              |
|       | PX      | Parameter, Indexed         |
|       | Р       | Parameter                  |

| Class | Per                  | mitted addressing modes                                                   |
|-------|----------------------|---------------------------------------------------------------------------|
| 2     | RP<br>RM<br>IL<br>IG | Relative, Plus<br>Relative, Minus<br>Indirect, Local<br>Indirect, General |

The functions of these addressing modes are described in chapter V.

However, as regards addressing a few instructions have a particular behavior which will be described individually. These instructions are BRX and TES.

• Mode : indicates the operational mode(s) of the CPU in which the instruction may be executed. A socalled "priviledged" instruction is executable in master mode only. These instructions give rise to an additional trap condition : "mode violation".

• Option. Some "optional" instructions are not standard on all CPUs. They give rise to an additional trap condition : "non-implemented instruction".

However SHC, DIV, FAD, FSU, FMU and FDV may be simulated by a special monitor module (TRAP module).

## VII-2. SYMBOLIC NOTATIONS

- Used in instruction function description
- A Accumulator register
- (Ā) Logical complement of A
- A<sub>0-7</sub> Most signifiant byte of A
- A<sub>8-15</sub> Least signifiant byte of A
- C Carry indicator
- D Displacement value (rightmost byte in the instruction format extended to the left by a zero value byte). Thus :

xxxxxxxxyyyyyyy - Instruction

0000000yyyyyyy - Displacement

- E Accumulator extension register
- E, A Extended accumulator : juxtaposition of E and A in this order. Most signifiant word in E.
- G General base value
- G' In Master mode G' = GIn Slave mode G = 0
- L Local base value
- MA Interrupt mask indicator
- MS Mode indicator (Master/Slave)
- N Calculated operand (Contents of Y-address word)
- N<sub>11-15</sub> Contents of bits 11-15 of calculated operand

- O Overflow indicator
- P Program base value
- PR Memory protection indicator
- Rn n-number general register
- X Index register
- Y Calculated memory address (Displacement value processed according to addressing mode function)
- Y<sub>2</sub> Word address corresponding to y

If Y is even:  $Y_2 = Y$ If Y is odd:  $Y_2 = Y - 1$ 

- α Current rank in a byte or word string processed by an instruction; the first byte or word in the string is rank zero.
- bp Protection bit
- r Contents of R-register
- rn Contents of Rn-register
- y Y-address byte
- y<sub>2</sub> Y<sub>2</sub> -address word
- () Contents of ... E.g.  $y_2 = (Y_2)$ N = (Y\_2)
- ---- Replaces
- --- Exchanged
- # Altered but non-signifiant
- Exclusive OR
- ∧ Logical AND
- ∨ Logical OR
- Used in examples

The purpose of this chapter is to familiarize the user with assembly language writing, thus with every instruction examples are given to show various possibilities which will enable him to program without a complete knowledge of Assembler capabilities.

The following conventions will be used in order to simplify example representation :

Identifiers include four letters followed by a serial number. These letters have the following meaning :

| 1st letter | E<br>S | Label<br>Symbol (defined through an EQU pseudo-instruction) |
|------------|--------|-------------------------------------------------------------|
|            |        | Predefined<br>Anticipated                                   |
|            |        | Defined in a data segment<br>Defined in a program segment   |
| 4th letter | C<br>L | Common<br>Local                                             |

Example :

EPDC27 denotes a predefined label of the common data.

Thus all examples are written relatively to a CDS and a LDS having the following form :

| EXEMPL           | CDS    |              |
|------------------|--------|--------------|
| EPDC1            | DATA   | 7            |
| EPDC2            | DATA   | EPDCI        |
| EPDC3            | DATA   | EPDC4        |
| EPDC4            | RES    | 20           |
| EPDC5            | DATA,1 | &FF,00       |
| EPDC6            | DATA   | EPDC5        |
| EPDC7            | DATA   | EPDC8        |
| EPDC8            | RES,1  | 10           |
| EPDC9            | DATA   | "A B"        |
|                  | DATA   | "CD"         |
| EPDC10           | DATA   | EPDC9        |
| EPDC11           | DATA   | 6            |
| EPDC12           | DATA   | &82          |
| EPDC13           | DATA   | EPPL2        |
| EPDC14           | DATA   | EPPL3        |
| EPDC15           | DATA   | EPPL1        |
|                  | DATA   | EPPL2        |
|                  | DATA   | EPPL3        |
|                  | DATA   | EPPL4        |
| EPDC16           | TEXT   | "ABCDEFGHIJ" |
|                  | DATA   | EPDC16       |
| EPDC17<br>EPDC18 | DATA,1 | "A"          |
| EPUCIO           | •      | "E"          |
|                  | DATA,1 | "X"          |
|                  | DATA,1 |              |
| EPDC19           |        | EPDC18       |
| EPDC20           |        | EPDC21       |
|                  |        | EPDC21 + 2   |
|                  |        | EPDC21 + 4   |
| EPDC21           |        | 3            |
|                  |        | 4            |
|                  | DATA   | 5            |
| EPDC22           |        | EPDC23       |
|                  | DATA   | EPDC23 + 2   |
|                  |        | EPDC23 + 4   |
|                  |        | EPDC23 + 6   |
| 5 5 5 6 6 A      | DATA   | EPDC23 + 8   |
| EPDC23           | RES    | 10           |
| EPDC24           | DATA   | EPDC25       |
|                  | DATA   | EPDC25 + 1   |
|                  | DATA   | EPDC25 + 2   |
|                  | DATA   | EPDC25 + 3   |
| EPDC25           | RES,1  | 5            |
| EPDC26           | DATA   | &30A2        |
|                  |        | &400B        |
|                  |        | &40FA        |
|                  |        | &BF01        |
| EPDC27           |        | EPD26        |
|                  | DATA   | EPDC26 + 4   |
| EPDC28           | RES    | 5            |
| EPDC29           | DATA   | EPDC28       |
| SPDC1            | EQU    | EPDLI        |
| SPDC2            | EQU    | 3            |

| SPDC3<br>SPDC4   | EQU<br>EQU<br>FIN | SPL2<br>EPDL14           |
|------------------|-------------------|--------------------------|
| LDSI             | LDS               |                          |
| EPDL1            | DATA              | 7                        |
| EPDL2            | DATA              | EPPLI                    |
| EPDL3            | DATA              | EPDL4                    |
| EPDL4            | RES               | 20                       |
| EPDL5            | DATA,1            | &FF,00                   |
| EPDL6            | DATA              | EPDL5                    |
| EPDL7            | DATA              | EPDL6                    |
| EPDL8            | RES,1             | 10                       |
| EPDL9            | DATA              | "A B "                   |
| 500110           | DATA              | "CD"                     |
| EPDL10<br>EPDL11 | DATA<br>DATA      | EPDL9<br>6               |
| EPDL12           | DATA              | 8<br>&82                 |
| EPDL13           | DATA              | EPPL2                    |
| EPDL14           | DATA              | EPPL3                    |
| EPDL15           | DATA              | EPPLI                    |
|                  | DATA              | EPPL2                    |
|                  | DATA              | EPPL3                    |
|                  | DATA              | EPPL4                    |
| EPDL16           | TEXT              | "ABCDEFGHIJ"             |
| EPDL17           | DATA              | EPDL16                   |
| EPDL18           | DATA,             | "A"                      |
|                  | DATA,1            | "E"<br>"X"               |
|                  | DATA,1<br>DATA    | EPDLT8                   |
| EPDL19<br>EPDL20 | DATA              | EPDL21                   |
|                  | DATA              | EPDL21 + 2               |
|                  | DATA              | EPDL21 + 4               |
|                  | DATA              | 3                        |
|                  | DATA              | 4                        |
|                  | DATA              | 5                        |
| EPDL22           | DATA              | EPDL23                   |
|                  | DATA              | EPDL23 + 2               |
|                  | DATA              | EPDL23 + 4               |
|                  | DATA<br>DATA      | EPDL23 + 6<br>EPDL23 + 8 |
| EPDL23           | RES               | 10                       |
| EPDL23           | DATA              | EPDL25                   |
|                  | DATA              | EPDL25 + 1               |
|                  | DATA              | EPDL25 + 2               |
|                  | DATA              | EPDL25 + 3               |
| EPDL25           | RES,1             | 5                        |
| EPDL26           | DATA              | &30A2                    |
|                  | DATA              | &400B                    |
|                  | DATA              | &40FA                    |
| 500107           |                   | &BF01                    |
| EPPL27           | DATA<br>DATA      | EPPL26<br>EPPL26 + 4     |
|                  | DATA              | LFFL20 T 4               |

| <u>4057 U</u> |              |        |
|---------------|--------------|--------|
|               |              |        |
| EPDL28        | RES          | 5      |
| EPDL29        | DATA         | EPDL28 |
| SPDLI         | EQU          | EPDL1  |
| SPDL2         | EQU          | 3      |
| SPDL3         | EQU          | SPDL2  |
| SPDL4         | EQU          | EPDL14 |
|               | FIN          |        |
| LPSI          | LPS          | LDS1   |
|               | •            |        |
|               | •            | ,      |
|               | . Instructio | ons    |
|               | •            |        |
|               | •            |        |
|               | FIN          | EPPL1  |
|               | END          | LPS1   |

# VII-3. LOAD AND STORE INSTRUCTIONS

# VII-3.1. Introduction

The following table contains the load and store instruction which are individually described hereafter.

| Γ         | В       | yte   | w    | / or d | Double word |       |  |
|-----------|---------|-------|------|--------|-------------|-------|--|
|           | Load    | Store | Load | Store  | Load        | Store |  |
| Data      | LBL     | SBL   | LDA  | STA    | DLD         | DST   |  |
|           | L BR    | S BR  | LDE  | STE    |             |       |  |
|           | LBX     |       | LDX  | STX    |             |       |  |
|           |         |       | LDR  | STR    |             |       |  |
| Address   |         |       | LEA  | SPA    |             |       |  |
| Selective | <u></u> |       |      | STS    |             |       |  |

# VII-3.2. Description

These instructions are described in the following order :

| Byte | LBL<br>SBL<br>LBR<br>SBR<br>LBX                             | Load Byte Left in A<br>Store Byte Left in A<br>Load Byte Right in A<br>Store Byte Right in A<br>Load Byte right in X         |
|------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| Word | LDA<br>STA<br>LDE<br>STE<br>LDX<br>STX<br>LDR<br>STR<br>LEA | Loa D A<br>STore A<br>Loa D E<br>STore E<br>Loa D X<br>STore X<br>Loa D Register<br>STore Register<br>Load Effective Address |

NAME : Load Byte Left in A

Non-priviledged

Standard

LBL

Instruction format :

|   | Addres | S |   |   |   |   |   |   |   | D  | isplac | ement |    |    |    |
|---|--------|---|---|---|---|---|---|---|---|----|--------|-------|----|----|----|
|   |        |   | 0 | 1 | 1 | 0 | 1 |   |   |    |        |       |    |    |    |
| 0 | 1      | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11     | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (su) |
|-----------------|------------------|---------------------|
| DL              | 0 D              | 2,6                 |
| Р               | 2 D              | 3                   |
| DG              | 4D               | 2,6                 |
| IL              | 6D               | 3,6                 |
| IGX             | 8 D              | 3,6                 |
| ILX             | AD               | 3,6                 |

$$\frac{\text{Function}: y \longrightarrow (A_{0-7})}{(A_{8-15}) \text{ unaffected}}$$

Y-address operand loaded in leftmost byte of A-register. Rightmost byte of A-register unaffected.

Modified elements :

Registers : A<sub>0-7</sub>
 Memory locations

- Indicators : C-O

Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | (A) > 0        |
| 0 | 1 | (A) < 0        |
| 1 | 0 | (A) = 0        |

Trap conditions : standard

Examples :

| EPDL1 + 1         |
|-------------------|
| = 0               |
| ₩ EPDC1           |
| ລ EPDL6           |
| $a \neq EPDC7, x$ |
| a EPDL7,×         |
|                   |

#### NAME : Store Byte Left in A

Non-priviledged

Standard

SBL

Instruction format :

| / | Addres | s |   |   |   |   |   |   |   | D  | isplac | ement |    |    |    |
|---|--------|---|---|---|---|---|---|---|---|----|--------|-------|----|----|----|
|   |        |   | 1 | 0 | 1 | 0 | 0 |   |   |    |        |       |    |    |    |
| 0 | 1      | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11     | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (us) |
|-----------------|------------------|---------------------|
| DL              | 14               | 2,5                 |
| DG              | 54               | 2,5                 |
| IL              | 74               | 3,5                 |
| IGX             | 94               | 3,5                 |
| ILX             | B4               | 3,5                 |

# $\frac{\text{Function}}{\text{(A) unaffected}} : (A_{0-7}) \longrightarrow y$

Leftmost byte of A-register stored at Y-address in core memory.

Modified elements :

- Memory locations : y

Trap conditions : standard

| SBL | EPDL8            |
|-----|------------------|
| SBL | $\neq$ EPDC8 + 3 |
| SBL | බEPDL24          |
| SBL | ଇ# EPDC24,×      |
| SBL | aEPDL24,×        |

#### NAME : Load Byte Right in A

Non-priviledged

Standard

LBR

Instruction format :

|   | Addres | S |   |   |   |   |   |   |   | D  | isplac | ement |    |    |    |
|---|--------|---|---|---|---|---|---|---|---|----|--------|-------|----|----|----|
|   |        |   | 0 | 1 | 1 | 1 | 0 |   |   |    |        |       |    |    |    |
| 0 | 1      | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11     | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | OE               | 2,6                 |
| Р               | 2E               | 3                   |
| DG              | 4E               | 2,6                 |
| IL              | 6E               | 3,6                 |
| IGX             | 8E               | 3,6                 |
| ILX             | AE               | 3,6                 |

Function: 
$$y \longrightarrow (A_{8-15})$$
  
0  $\longrightarrow (A_{0-7})$ 

Y-address operand loaded in rightmost byte of A-register. Leftmost byte of A-register cleared.

#### Modified elements :

- Register : A
- Memory locations
- Indicators : C-O

Indicators :

| с | 0      | Upon execution |
|---|--------|----------------|
| 0 | ×<br>0 | (A) > 0        |
| 1 | 0      | (A) = 0        |

#### Trap conditions : standard

| LBR  | SPDL4     |
|------|-----------|
| LBR  | =SPDL2    |
| LBR  | ≠ EPDC1   |
| LBR  | ລ EPDL6   |
| L BR | a⊭EPDC7,× |
| LBR  | ລEPDL7,×  |

#### NAME : Store Byte Right in A

Class : 0'

Non-priviledged

Standard

SBR

Instruction format :

| Address |   |    |       |     |      |         | D     | isplacer | nent                |  |
|---------|---|----|-------|-----|------|---------|-------|----------|---------------------|--|
|         | 1 | 0  | 1     | 0   | 1    |         |       |          |                     |  |
| 0 1 2   | 3 | 4  | 5     | 6   | 7    | 89      | 10    | 11       | 12 13 14 15         |  |
|         |   | Ad | dress | ing | mode | Hexadeo | cimal | code     | Execution time (µs) |  |
|         |   | DL |       |     | 15   |         |       | 2,5      |                     |  |
|         |   | DG |       |     | 55   |         |       | 2,5      |                     |  |
|         |   | IL |       |     | 75   |         |       | 3,5      |                     |  |
|         |   |    | IC    | ΞX  |      | ç       | 75    |          | 3,5                 |  |
|         |   |    | ١L    | .X  |      | l       | B5    |          | 3,5                 |  |

# $\frac{\text{Function}: (A_{8-15}) \longrightarrow y}{(A) \text{ unaffected}}$

Rightmost byte of A-register stored at Y-address in core memory.

#### Modified elements :

- Memory locations : y

#### Trap conditions : standard

| SBR | EPDL8 + 3          |
|-----|--------------------|
| SBR | ₩ EPDC8            |
| SBR | ລ EPDL7            |
| SBR | $a \neq EPDC24, x$ |
| SBR | a⊭EPDL24,×         |

#### NAME : Load Byte Right in X

Class : 0

Non-priviledged

Standard

**LBX** 

Instruction format :

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | OF               | 2,6                 |
| Р               | 2F               | 3                   |
| DG              | 4F               | 2,6                 |
| IL              | 6F               | 3,6                 |
| IGX             | 8F               | 3,6                 |
| ILX             | AF               | 3,6                 |

$$\frac{\text{Function}}{0} : y \longrightarrow (X_{8-15})$$
$$0 \longrightarrow (X_{0-7})$$

Y-address operand loaded in rightmost byte of X-register. Leftmost byte of X-register cleared.

#### Modified elements :

- Register : X
- Memory locations
- Indicators : C-O

Indicators :

| с | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | (X) > 0        |
| 1 | 0 | (X) = 0        |

#### Trap conditions : standard

| LBX | EPDL5        |
|-----|--------------|
| LBX | =]           |
| LBX | # EPDC5      |
| LBX | ର EPDL6      |
| LBX | a == EPDC7,× |
| LBX | aEPDL7,×     |
|     |              |

NAME : Loa D A

Class : 0

Non-priviledged

Standard

LDA

Instruction format :

| Address |   |   |   |                 |     |     |        |       | D    | isplacer            | nent |    |         |    |
|---------|---|---|---|-----------------|-----|-----|--------|-------|------|---------------------|------|----|---------|----|
|         |   |   | 0 | 0               | 0   | 0   | 0      |       |      |                     |      |    |         |    |
| 0       | 1 | 2 | 3 | 4               | 5   | 6   | 7      | 89    | 10   | 11                  | 12   | 13 | 14      | 15 |
|         |   |   |   | Addressing mode |     |     | Hexade | cimal | code | Execution time (µs) |      |    | ne (µs) |    |
|         |   |   |   |                 | DL  |     |        |       | 2,3  |                     |      |    |         |    |
|         |   |   |   |                 | Р   |     |        |       | 20   |                     | 2,5  |    |         |    |
|         |   |   |   |                 | DG  |     |        |       | 40   |                     | 2,2  |    |         |    |
|         |   |   |   |                 | IL  |     |        |       | 3,4  |                     |      |    |         |    |
|         |   |   |   |                 | IGX |     |        |       | 3,4  |                     |      |    |         |    |
|         |   |   |   |                 |     | ILX |        |       | 3,4  |                     |      |    |         |    |

<u>Function</u> :  $y_2 \longrightarrow (A)$ 

A-register loaded with  $Y_2$  -address operand.

Modified elements :

- Register : A

- Memory locations

- Indicators : C-O

Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | (A) > 0        |
| 0 | 1 | (A) < 0        |
| 1 | 0 | (A) = 0        |

#### Trap conditions : standard

| LDA | EPDL1               |
|-----|---------------------|
| LDA | =7                  |
| LDA | ₩ EPDC1             |
| LDA | a EPDL2             |
| LDA | a <i>#</i> EPDC3, × |
| LDA | a EPDL3, ×          |

NAME : STore A

Class : 0'

Non-priviledged

STA Standard

Instruction format :

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 11               | 2,2                 |
| DG              | 51               | 2,2                 |
| IL              | 71               | 3,2                 |
| IGX             | 91               | 3,2                 |
| ILX             | B1               | 3,2                 |

# $\frac{\text{Function}: (A) \rightarrow y_2}{(A) \text{ unaffected}}$

A-register contents stored at  $Y_2$  -address in core memory.

#### Modified elements :

- Memory locations : y<sub>2</sub>

Trap conditions : standard

| STA | EPDL23 + 4         |
|-----|--------------------|
| STA | # EPDC23           |
| STA | a EPDL3            |
| STA | $a \neq EPDC22, x$ |
| STA | a EPDL22,×         |

#### <u>4057 U</u>

NAME : Loa D E

Class : 0

Non-priviledged

Standard

LDE

Instruction format :

| / | Addres | SS |   |   |   |     |   |   |   | C  | isplac | ement |    |    |    |
|---|--------|----|---|---|---|-----|---|---|---|----|--------|-------|----|----|----|
|   |        |    | 0 | 0 | 0 | . 0 | 1 |   |   |    |        |       |    |    |    |
| 0 | 1      | 2  | 3 | 4 | 5 | 6   | 7 | 8 | 9 | 10 | 11     | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 01               | 2,3                 |
| Р               | 21               | 2,5                 |
| DG              | 41               | 2,3                 |
| IL              | 61               | 3,4                 |
| IGX             | 81               | 3,4                 |
| ILX             | A1               | 3,4                 |

### <u>Function</u> : $y_2 \rightarrow (E)$

 $Y_2$  -address operand loaded in E-register.

Modified elements :

- Registers : E
- Memory locations
- Indicators : C-O

Indicators :

| С | 0 | Upon execution        |
|---|---|-----------------------|
| 0 | 0 | (E) > 0               |
| 0 | 1 | (E) <sub>&lt;</sub> 0 |
| 1 | 0 | (E) = 0               |

#### Trap conditions : standard

| LDE | SPDL1      |
|-----|------------|
| LDE | =&FF       |
| LDE | ₩ SPDC1    |
| LDE | aepdl3     |
| LDE | a⊭ EPDC3,× |
| LDE | aEPDL3,×   |

#### 4057 U

NAME : STore E

Class : 0'

Non-priviledged

Standard

STE

Instruction format :

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 12               | 2,2                 |
| DG              | 52               | 2,2                 |
| IL              | 72               | 3,2                 |
| IGX             | 92               | 3,2                 |
| ILX             | B2               | 3,2                 |

# $\frac{\text{Function}}{\text{(E)}}: \begin{array}{c} \text{(E)} & \longrightarrow & y_2 \\ \text{(E)} & \text{unaffected} \end{array}$

E-register contents stored at  $Y_2$  -address memory location.

Modified elements :

- Memory locations : y<sub>2</sub>

Trap conditions : standard

| STE | EPDL4          |
|-----|----------------|
| STE | ₩EPDC4 + 2     |
| STE | ລ EPDL3        |
| STE | a $≠$ EPDC22,× |
| STE | םEPDL22,×      |

#### 4057 U

NAME : Loa D X

Class : 0

Non-priviledged

Standard

LDX

Instruction format :

|   | Addres | s |   |   |   |   |   |   |   | D  | isplac | ement |    |    |   |
|---|--------|---|---|---|---|---|---|---|---|----|--------|-------|----|----|---|
|   |        |   | 0 | 0 | 0 | 1 | 0 |   |   |    |        |       |    |    |   |
| 0 | 1      | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11     | 12    | 13 | 14 | 1 |

| Addressing mode | Hexadecimal code | Execution time (us) |
|-----------------|------------------|---------------------|
| DL              | 02               | 2,3                 |
| Р               | 22               | 2,5                 |
| DG              | 42               | 2,3                 |
| IL              | 62               | 3,4                 |
| IGX             | 82               | 3,4                 |
| ILX             | A2               | 3,4                 |

### <u>Function</u> : $y_2 \rightarrow (X)$

Y<sub>2</sub> -address operand loaded in X-register.

#### Modified elements :

- Registers : X
- Memory locations :
- Indicators : C-O

#### Indicators :

| с | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | (X) > 0        |
| 0 | 1 | (X) < 0        |
| 1 | 0 | (X) = 0        |

#### Trap conditions : standard

| LDX | EPDL2      |
|-----|------------|
| LDX | =4         |
| LDX | ₩EPDC1     |
| LDX | a EPDL3    |
| LDX | ଇ⊭ EPDC3,× |
| LDX | @EPDL3,×   |

#### 4057 U

NAME : STore X

Class : 0'

Non-priviledged

Standard

**STX** 

Instruction format :

| , | Addres | S |   |   |   |   |   |   |   | D  | isplac | ement | t  |    |    |
|---|--------|---|---|---|---|---|---|---|---|----|--------|-------|----|----|----|
|   |        |   | 1 | 0 | 0 | 1 | 1 |   |   |    |        |       |    |    |    |
| 0 | 1      | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11     | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |  |  |  |
|-----------------|------------------|---------------------|--|--|--|
| DL              | 13               | 2,2                 |  |  |  |
| DG              | 53               | 2,2                 |  |  |  |
| ١L              | 73               | 3,2                 |  |  |  |
| IGX             | 93               | 3,2                 |  |  |  |
| ILX             | A 3              | 3,2                 |  |  |  |

 $\frac{\text{Function}}{(X)} : \begin{array}{c} (X) & \longrightarrow & y_2 \\ (X) & \text{unaffected} \end{array}$ 

X-register contents stored at  $Y_2$ -address memory location.

Modified elements :

- Memory location : y<sub>2</sub>

Trap conditions : standard

| STX | EPDL23 + 6          |
|-----|---------------------|
| STX | <b># EPDC23 + 2</b> |
| STX | a EPDL22            |
| STX | ଇ#EPDC22,×          |
| STX | a EPDL22,×          |

NAME : LoaD Register

#### Class : 1

Non-priviledged

Standard

LDR

Instruction format :

|   | Add | ress |   |   | Displacement |   |   |   |   |    |    |    |    |    |    |
|---|-----|------|---|---|--------------|---|---|---|---|----|----|----|----|----|----|
|   |     |      |   | 1 | 0            | 0 | 1 |   |   |    |    |    |    |    |    |
| 0 | 1   | 2    | 3 | 4 | 5            | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 39               | 3,7                 |
| PX              | E9               | 3,7                 |
| Р               | F9               | 3,7                 |

 $\frac{\text{Function}}{(R_n)} : (R_n) \longrightarrow A$ (R\_n) unaffected

with 
$$n = (Y)$$

A-register loaded with the contents of n-register (n = register no.).

Modified elements :

- Registers : A

- Indicators : C-O

Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | (A) > 0        |
| 0 | 1 | (A) < 0        |
| 1 | 0 | (A) = 0        |

#### Trap conditions : standard

| LDR | EPDL1 |
|-----|-------|
| LDR | =0,×  |
| LDR | =22   |

#### NAME : STore Register

Class : 1

Priviledged

Standard

STR

Instruction format :

| Address |   |   |   |   |   |   | D  | isplace | ement |    |    |    |
|---------|---|---|---|---|---|---|----|---------|-------|----|----|----|
|         | 1 | 0 | 1 | 0 |   |   |    |         |       |    |    |    |
| 0 1 2 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11      | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |  |  |
|-----------------|------------------|---------------------|--|--|
| DL              | 3A               | 4                   |  |  |
| PX              | EA               | 4                   |  |  |
| Р               | FA               | 4                   |  |  |

 $\frac{\text{Function}}{(A)}: (A) \xrightarrow{} (R_n)$ (A) unaffected with n = (Y)

A-register contents stored in n-register (n = register no.).

Modified elements :

- Registers : R

Trap conditions :

- Standard and mode violation

#### Miscellaneous :

This instruction is executable in master mode only since it alters the contents of a given register (specifically I/O registers). Normally reserved for monitor or operating system use.

| STR | EPDLI |
|-----|-------|
| STR | =2,×  |
| STR | =4    |

#### NAME : Load Effective Address

3

4

1

5

0

6

0

7

0

Non-priviledged

Displacement

12

13

14

15

11

Standard

LEA

Instruction format :

1

2

| Addressing mode | Hexadecimal code                       | Executio | on time (ys) |
|-----------------|----------------------------------------|----------|--------------|
| DL              | 04                                     | 2,7      | 3,3          |
| Р               | 24                                     | 3,1      | 3,7          |
| DG              | 44                                     | 2,7      | 3,3          |
| IL              | 64                                     | 3,7      | 4,3          |
| IGX             | 84                                     | 3,7      | 4,3          |
| ILX             | A 4                                    | 3,7      | 4,3          |
|                 | •••••••••••••••••••••••••••••••••••••• | Master   | Slave        |

10

9

8

mode mode

Function : Y - (G) - A

G-register contents subtracted from computed address. Result, representing the actual address, stored in A-register.

Modified elements :

- Registers : A

Trap conditions : standard

| LEA | EPDC7       |
|-----|-------------|
| LEA | =&2F        |
| LEA | ₩ EPDL11    |
| LEA | aEPDC2      |
| LEA | a⊭ EPDC22,× |
| LEA | @EPDL22     |

#### NAME : Store Program Address

Non-priviledged

Standard

**SPA** 

Instruction format :

| / | Addres | SS |   |   |   |   |   |   |   | D  | isplac | ement |    |
|---|--------|----|---|---|---|---|---|---|---|----|--------|-------|----|
|   |        |    | 1 | 1 | 0 | 0 | 0 |   |   |    |        |       |    |
| 0 | 1      | 2  | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11     | 12    | 13 |

| Addressing mode | Hexadecimal code | Executio | on time (µs) |
|-----------------|------------------|----------|--------------|
| DL              | 18               | 3,1      | 3,4          |
| DG              | 58               | 3,1      | 3,4          |
| IL              | 78               | 4,2      | 4,5          |
| IGX             | 98               | 4,2      | 4,5          |
| ILX             | B8               | 4,2      | 4,5          |

Master Slave

14

15

mode mode

#### <u>Function</u>: (P) + G' $\rightarrow$ y<sub>2</sub>

This instruction is normally followed by an indirect branch to a sub-routine. Therefore, the current address incremented by four (P-register contents + 4) is stored in A-register. This new address is generally the sub-routine return address.

Modified elements :

- Registers
- Memory locations : y<sub>2</sub>

– Indicators

Trap conditions : standard

#### Examples :

|     |            | 1    | Return     |
|-----|------------|------|------------|
| SPA | EPDL28     |      |            |
| BRU | ລ          | BR U | aEPDL28    |
| •   | •          |      | •          |
| SPA | # EPDC28   | •    | •          |
| BRU | a          | BR U | â⊭ EPDC28  |
| •   | •          |      | •          |
| SPA | ۵EPDL29    | •    | •          |
| BRU | a          | BR U | a EPDL29   |
| •   | •          | •    | •          |
| SPA | a∦EPDC29,× | •    | •          |
| BRU | ລ          | BR U | ⓐ # EPDC29 |
| •   |            | •    | •          |
| SPA | ◎EPDL29,×  | •    | r •        |
| BRU | ລ          | BR U | @EPDL29    |

VII-22

#### NAME : STore Selective in A

Non-priviledged

Standard

STS

Instruction format :

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 19               | 3,4                 |
| DG              | 59               | 3,4                 |
| IL              | 79               | 4,4                 |
| IGX             | 99               | 4,4                 |
| ILX             | B9               | 4,4                 |

 $\begin{array}{c} \underline{ Functions}: \hspace{0.2cm} y_{2} \hspace{0.2cm} \wedge \hspace{0.2cm} \overline{(E)} \hspace{0.2cm} \vee \hspace{0.2cm} (A) \hspace{0.2cm} \wedge \hspace{0.2cm} (E) \hspace{0.2cm} \longrightarrow \hspace{0.2cm} y_{2} \hspace{0.2cm} \\ \hspace{0.2cm} (A) \hspace{0.2cm} and \hspace{0.2cm} (E) \hspace{0.2cm} unaffected \end{array}$ 

The bits of A-register which correspond to set bits in E-register are stored into corresponding position of  $y_2$  memory address. Remaining bits of the memory word are not modified. Thus, for instance :

$$\underbrace{[0,0,1,0,0,0,0,0],0],[1,0,0,0,0,0]}_{[1,1,0,0,0,0,0]} y_{2} \\ \underbrace{[1,1,0,0,0,1,0,0],0],[1,1,1,0,0,0,1,1]}_{[0,1,1,1,0,0,0,0,0,0]} E \\ Before execution \\ \underbrace{[0,1,1,1,0,0,1,0,0],0],[1,1,0,0,0,0]}_{[0,1,1,1,0,0,0,0]} y_{2} \\ Upon execution$$

Modified elements :

- Registers
- Memory locations : y<sub>2</sub>
- Indicators : C-O

Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | Result > 0     |
| 0 | 1 | Result < 0     |
| 1 | 0 | Result = 0     |

#### Trap conditions : standard

| Examples : |            |
|------------|------------|
| STS        | EPDL4      |
| STS        | # EPDC23   |
| STS        | ລEPDL3     |
| STS        | a⊭EPDC22,× |
| STS        | a EPDL22,× |

NAME : Double LoaD of A and E

Class : 0'

0

Non-priviledged

Standard

DLD

Instruction format :

| Address |   |   |       |      |      |        | Di    | splace | nent  |           |      |
|---------|---|---|-------|------|------|--------|-------|--------|-------|-----------|------|
|         | 1 | 0 | 0     | 0    | 0    |        |       |        |       |           |      |
| 1 2     | 3 | 4 | 5     | 6    | 7    | 89     | 10    | 11     | 12 13 | 14 15     |      |
|         |   | A | ddres | sing | mode | Hexade | cimal | code   | Execu | tion time | (us) |
|         |   |   |       | DL   |      |        | 10    |        |       | 3,6       |      |
|         |   |   |       | DG   |      |        | 50    |        |       | 3,6       |      |
|         |   |   |       | ۱L   |      |        | 70    |        |       | 4,8       |      |
|         |   |   |       | IGX  | ζ.   |        | 90    |        |       | 4,8       |      |
|         |   |   |       | ILX  |      |        | BO    |        |       | 4,8       |      |

# $\frac{\text{Function}}{(Y_2 + 2)} \stackrel{(F)}{\longrightarrow} (A)$

E-register loaded with the contents of  $Y_2$  memory address and A-register loaded with the contents of  $Y_2$  + 2 memory address.

Modified elements :

- Registers : E-A

- Memory locations

- Indicators : C-O

Indicators :

| с | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | (E) > 0        |
| 0 | 1 | (E) < 0        |
| 1 | 0 | (E) = 0        |

#### Trap conditions : standard

| DLD | EPDL9            |
|-----|------------------|
| DLD | ₩ EPDC9          |
| DLD | a EPDL10         |
| DLD | ର≠EPDC3,×        |
| DLD | <b>∂EPDL3,</b> × |

#### NAME : Double STore of A and E

Class : 0'

Non-priviledged

13

14

15

Standard

DST

Instruction format :

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 16               | 3,6                 |
| DG              | 56               | 3,6                 |
| IL              | 76               | 4,7                 |
| IGX             | 96               | 4,7                 |
| ILX             | B6               | 4,7                 |

 $\frac{\text{Function}}{(A)} : \begin{array}{c} (E) & \longrightarrow (Y_2) \\ (A) & \longrightarrow (Y_2 + 2) \\ (A) \text{ and } (E) \text{ unaffected} \end{array}$ 

E-register contents stored at  $Y_2$  -memory address and A-register contents stored at  $Y_2$  + 2 memory address.

Modified elements :

- Registers
- Memory locations :  $(Y_2)$  and  $(Y_2 + 2)$
- Indicators

Trap conditions : standard

Examples :

| DST | EPDL4                 |
|-----|-----------------------|
| DST | ₩ EPDC4               |
| DST | ລ EPDL3               |
| DST | $a \neq EPDC22, x$    |
| DST | <sup>ଇ</sup> EPDL22,× |
|     |                       |

#### VII-4. FIXED-POINT ARITHMETIC

VII-4.1. Introduction

Operands are signed numbers on one or two words.

| mantissa | on 1 | 5 | bits |
|----------|------|---|------|
|----------|------|---|------|

mantissa on 31 bits

\_\_\_\_\_

Sign

L

Negative numbers are represented by two's complement of their absolue value.

#### VII-4.2. Description

Sign

Fixed-point arithmetic instructions perform the four operations and are described in the following order :

| ADD | ADDition in A | MUL | MULtiply integer |
|-----|---------------|-----|------------------|
| ADM | ADd to Memory | DIV | DIVide integer   |
| SUB | SUBtract      |     |                  |

NAME : ADDition in A

#### Class : 0

Non-priviledged

Standard

ADD

Instruction format :

| Add | dress |   |   |   |     |   |   |   | D  | isplac | ement |    |    |    |
|-----|-------|---|---|---|-----|---|---|---|----|--------|-------|----|----|----|
|     |       | 0 | 0 | 1 | . 0 | 1 |   |   |    |        |       |    |    |    |
| 0 1 | 2     | 3 | 4 | 5 | 6   | 7 | 8 | 9 | 10 | 11     | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 05               | 2,3                 |
| Р               | 25               | 2,5                 |
| DG              | 45               | 2,3                 |
| ١L              | 65               | 3,4                 |
| IGX             | 85               | 3,4                 |
| ILX             | A5               | 3,4                 |

<u>Function</u>: (A) +  $y_2 \rightarrow$  (A)

 $Y_2$  -address operand added with A-register contents; result in A.

#### Modified elements :

- Registers : A
- Memory locations
- Indicators : C-O

#### Indicators :

| с | 0 | Upon execution |
|---|---|----------------|
| 1 | - | Carry          |
| - | 1 | Overflow       |

#### Trap conditions : standard

| EPDL12                   |
|--------------------------|
| =122                     |
| ⊭ EPDC12                 |
| a EPDL2                  |
| $^{a}$ <i>#</i> EPDC20,× |
| <b></b> aEPDĻ20,×        |
|                          |

NAME : ADd to Memory

Non-priviledged

Standard

**ADM** 

Instruction format :

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 17               | 2,6                 |
| DG              | 57               | 2,6                 |
| iL              | 77               | 3,7                 |
| IGX             | 97               | 3,7                 |
| ILX             | B7               | 3,7                 |

<u>Function</u> :  $y_2 + (A) \longrightarrow Y_2$  and A

A-register contents added to  $Y_2$  -address contents; result in A and at  $Y_2$  -address.

#### Modified elements :

- Registers : A
- Memory locations: y<sub>2</sub>
- Indicators : C-O

#### Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| - | 1 | Carry          |
| 1 | - | Overflow       |

#### Trap conditions : standard

| ADM | EPDL4              |
|-----|--------------------|
| ADM | ₩ EPDC4            |
| ADM | a EPDL3            |
| ADM | $a \neq EPDC20, x$ |
| ADM | a EPDL20,×         |

NAME : SUBtract in A

Class : 0

Non-priviledged

Standard

**SUB** 

Instruction format :

| _ |   |       |       |                                                     |                                                            |                                                                       |                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                               |
|---|---|-------|-------|-----------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |       |       |                                                     |                                                            | D                                                                     | isplacen                                                                                                                                                                                                                                                                                                                                                                              | nent                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                       | _                                                                                                                                                                                                                                                                                                                                                                             |
| 0 | 0 | 1     | 1     | 0                                                   |                                                            |                                                                       |                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                               |
| 3 | 4 | 5     | 6     | 7                                                   | 89                                                         | 10                                                                    | 11                                                                                                                                                                                                                                                                                                                                                                                    | 12 13                                                                                                                                                                                                                                                                                                                     | 14 15                                                                                                                                                                                                                                                                 | _                                                                                                                                                                                                                                                                                                                                                                             |
|   | A | ddres | ssing | mode                                                | Hexado                                                     | ecimal                                                                | code                                                                                                                                                                                                                                                                                                                                                                                  | Execu                                                                                                                                                                                                                                                                                                                     | tion time (                                                                                                                                                                                                                                                           | (µs)                                                                                                                                                                                                                                                                                                                                                                          |
|   |   |       | DL    |                                                     |                                                            | 06                                                                    |                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                           | 2,3                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                               |
|   |   |       | Ρ     |                                                     |                                                            | 26                                                                    |                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                           | 2,5                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                               |
|   |   |       | DG    |                                                     |                                                            | 46                                                                    |                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                           | 2,3                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                               |
|   |   |       | IL    |                                                     |                                                            | 66                                                                    |                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                           | 3,4                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                               |
|   |   |       | IGX   |                                                     |                                                            | 86                                                                    |                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                           | 3,4                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                               |
|   |   |       | ILX   |                                                     |                                                            | A6                                                                    |                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                           | 3,4                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                               |
|   |   | 3 4   | 3 4 5 | 3 4 5 6<br>Addressing<br>DL<br>P<br>DG<br>IL<br>IGX | 3 4 5 6 7<br>Addressing mode<br>DL<br>P<br>DG<br>IL<br>IGX | 3 4 5 6 7 8 9<br>Addressing mode Hexade<br>DL<br>P<br>DG<br>IL<br>IGX | 0         0         1         1         0           3         4         5         6         7         8         9         10           3         4         5         6         7         8         9         10           Addressing mode         Hexadecimal           DL         06           P         26           DG         46           IL         66           IGX         86 | 0         0         1         1         0           3         4         5         6         7         8         9         10         11           Addressing mode         Hexadecimal code           DL         06         9         26           DG         46         1L         66           IGX         86         86 | 3       4       5       6       7       8       9       10       11       12       13         Addressing mode       Hexadecimal code       Execut         DL       06       06         P       26       06         IL       66       66         IL       66       16X | 0       0       1       1       0         3       4       5       6       7       8       9       10       11       12       13       14       15         Addressing mode       Hexadecimal code       Execution time (         DL       06       2,3         P       26       2,5         DG       46       2,3         IL       66       3,4         IGX       86       3,4 |

<u>Function</u>: (A) -  $y_2 \rightarrow$  (A)

 $Y_2$  -address operand subtracted from A-register contents; result in A.

#### Modified elements :

- Registers : A
- Memory locations
- Indicators : C-O

#### Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 1 | - | Carry          |
| - | 1 | Overflow       |

#### Trap conditions : standard

| SUB | EPDL11             |
|-----|--------------------|
| SUB | =2                 |
| SUB | ₩ EPDC11           |
| SUB | ©EPDL20            |
| SUB | $a \neq EPDC20, x$ |
| SUB | aEPDL20,×          |
|     |                    |

#### NAME : MULtiply integer

Class : 0

Non-priviledged

Standard

MUL

Instruction format :

Displacement Address 0 1 1 0 0 11 12 13 7 10 2 3 4 5 6 8 9 0 1

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 0C               | 8,1 38,4+0,9 n      |
| Р               | 2C               | 8,5 38,8+0,9 n      |
| DG              | 4C               | 8,1 38,8+0,9 n      |
| IL              | 6C               | 9,1 39,4+0,9 n      |
| IGX             | 8C               | 9,1 39,4+0,9 n      |
| ILX             | AC               | 9,1 39,4+0,9 n      |

Wired Micro-programmed

14

15

n = no. of set bits in multiplier

Function : (A)  $\times$  y<sub>2</sub>  $\longrightarrow$  (E, A)

 $Y_2$  -address operand multiplied algebraically by A-register contents; result in E and A.

The most significant portion of the result is stored in E, the least significant in A.

#### Modified elements :

- Registers : E-A
- Memory locations
- Indicators : C-O

Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | E > 0          |
| 0 | 1 | E < 0          |
| 1 | 0 | E = 0          |

Trap conditions : standard

| MUL | EPDL11            |
|-----|-------------------|
| MUL | =&2E              |
| MUL | ₩ EPDC1           |
| MUL | aEPDL20           |
| MUL | a≠EPDC20,×        |
| MUL | <b>αEPDL20,</b> × |

NAME : DIVide integer

Class: 0

Non-priviledged

Optional

DIV

Instruction format :

|   | Addres | s |   | Displacement |   |   |   |   |   |    |    |    |    |    |    |
|---|--------|---|---|--------------|---|---|---|---|---|----|----|----|----|----|----|
|   |        |   | 0 | 1            | 0 | 0 | 0 |   |   |    |    |    |    |    |    |
| 0 | 1      | 2 | 3 | 4            | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 08               | 9,1 42 +0,3 n       |
| Р               | 28               | 9,5 42,4+0,3 n      |
| DG              | 48               | 9,142+0,3n          |
| IL              | 68               | 10,143+0,3n         |
| IGX             | 88               | 10,1 43 +0,3 n      |
| ILX             | A 8              | 10,1 43 +0,3 n      |

Wired Micro-programmed

n = no. of set bits in the quotient.

<u>Function</u>: (E,A): y<sub>2</sub> --- (A) remainder --- E Remainder sign same as dividend sign (except when zero, in which case the sign is +).

Extended accumulator contents (least significant portion of the dividend in A, most significant portion in E) divided by  $Y_2$  -address operand (divisor). Quotient in A, remainder in E.

The remainder is of the same sign as E-register initial contents, except when there is no remainder, in which case the sign is +.

Modified elements :

- Registers : E-A (unaffected if divisor = 0 or if an overflow occurs).

- Memory locations

- Indicators : C-O

Indicators :

| С | 0 | Upon execution           |
|---|---|--------------------------|
| # | 1 | Overflow or zero divisor |

Trap conditions : standard and non-implemented instruction

| DIV | EPDL1       |
|-----|-------------|
| DIV | =5          |
| DIV | ⊭ EPDC11    |
| DIV | aEPDL2      |
| DIV | a⊭ EPDC20,× |
| DIV | aEPDL20,×   |
|     |             |

#### VII-5. LOGICAL OPERATIONS

| IOR | Inclusive OR |
|-----|--------------|
| EOR | Exclusive OR |
| AND | AND          |
| CMP | CoMPare      |

#### NAME : Inclusive OR

Class : 0

### Non-priviledged

Standard

**IOR** 

#### Instruction format :

|   | Addres | S |   |   | Displacement |   |   |   |   |    |    |    |    |    |    |  |
|---|--------|---|---|---|--------------|---|---|---|---|----|----|----|----|----|----|--|
|   |        |   | 0 | 0 | 1            | 1 | 1 |   |   |    |    |    |    |    |    |  |
| 0 | 1      | 2 | 3 | 4 | 5            | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |  |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 07               | 2,3                 |
| Р               | 27               | 2,5                 |
| DG              | 47               | 2,3                 |
| IL              | 67               | 3,4                 |
| IGX             | 87               | 3,4                 |
| ILX             | A7               | 3,4                 |

### <u>Function</u>: (A) $\lor$ y<sub>2</sub> $\longrightarrow$ (A)

Inclusive ORing between  $Y_2$  -address operand and A-register contents; result in A .

#### Modified elements :

- Registers : A
- Memory locations
- Indicators : C-O

Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | (A) > 0        |
| 0 | 1 | (A) < 0        |
| 1 | 0 | (A) = 0        |

#### <u>Trap conditions</u> : standard

| Examples : |             |
|------------|-------------|
| IOR        | EPDL21      |
| IRO        | =&01        |
| IOR        | ₩EPDL9      |
| IOR        | aEPDL20     |
| IOR        | a⊭ EPDC20,× |
| IOR        | aEPDL20,×   |

NAME : Exclusive OR

Class : 0

Non-priviledged

Standard

EOR

Instruction format :

| Address |   |     |       |      |      | Displacen        | nent                |
|---------|---|-----|-------|------|------|------------------|---------------------|
|         | 0 | . 0 | 0     | 1    | 1    |                  |                     |
| 1 2     | 3 | 4   | 5     | 6    | 7    | 8 9 10 11        | 12 13 14 15         |
|         |   | A   | ddres | sing | mode | Hexadecimal code | Execution time (µs) |
|         |   |     |       | DL   |      | 03               | 2,3                 |
|         |   |     |       | Ρ    |      | 23               | 2,5                 |
|         |   |     |       | DG   |      | 43               | 2,3                 |
|         |   |     |       | IL   |      | 63               | 3,4                 |
|         |   |     |       | IGX  |      | 83               | 3,4                 |
|         |   |     |       | ILX  |      | Α3               | 3,4                 |

<u>Function</u>: (A)  $\oplus$  y<sub>2</sub>  $\longrightarrow$  (A)

Exclusive ORing between  $Y_2$  -address operand and A-register contents; result in A.

Modified elements :

- Registers : A
- Memory locations
- Indicators : C-O

Indicators :

| с | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | (A) > 0        |
| 0 | 1 | (A) < 0        |
| 1 | 0 | (A) = 0        |

#### Trap conditions : standard

| EOR | EPDL1              |
|-----|--------------------|
| EOR | =&80               |
| EOR | ₩ EPDC1            |
| EOR | aEPDL2             |
| EOR | $a \neq EPDC20, x$ |
| EOR | aEPDL20            |

NAME : Logical AND

Class : 0

Non-priviledged

Displacement

11

12

13

14

15

Standard

AND

Instruction format :

|   | Addre | ess |   |   |   |     |   |   |   |
|---|-------|-----|---|---|---|-----|---|---|---|
|   |       |     | 0 | 1 | 0 | . 0 | 1 |   |   |
| 0 | 1     | 2   | 3 | 4 | 5 | 6   | 7 | 8 | 9 |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 09               | 2,3                 |
| Р               | 29               | 2,5                 |
| DG              | 49               | 2,3                 |
| ۱L              | 69               | 3,4                 |
| IGX             | 89               | 3,4                 |
| ILX             | Α9               | 3,4                 |

10

### <u>Function</u>: (A) $\land$ y<sub>2</sub> — (A)

Logical ANDing (intersection) between  $Y_2$  -address operand and A-register contents; result in A.

#### Modified elements :

- Registers : A
- Memory locations
- Indicators : C-O

#### Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | (A) > 0        |
| 0 | 1 | (A) < 0        |
| 1 | 0 | (A) = 0        |

#### Trap conditions : standard

| AND | EPDL1       |
|-----|-------------|
| AND | =&0F        |
| AND | ₩ EPDC1     |
| AND | aEPDL20     |
| AND | a⊭ EPDC20,× |
| AND | aEPDL20,×   |

#### NAME : CoMpare

Class : 0

Non-priviledged

Standard

**CMP** 

Instruction format :

| <i>F</i> | Addre | ss |   |   |   |   |   |   |   | D  | isplac | ement |    |    |
|----------|-------|----|---|---|---|---|---|---|---|----|--------|-------|----|----|
|          |       |    | 0 | 1 | 0 | 1 | 1 |   |   |    |        |       |    |    |
| 0        | 1     | 2  | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11     | 12    | 13 | 14 |

| Addressing mode | Hexadecimal code | Execu | tion ti | me (us) |
|-----------------|------------------|-------|---------|---------|
|                 |                  | >     | <       | =       |
| DL              | ОВ               | 4,1   | 4,5     | 3,2     |
| Р               | 2 B              | 4,5   | 5       | 3,6     |
| DG              | 4B               | 4,1   | 4,5     | 3,2     |
| IL              | 6 B              | 5,1   | 5,6     | 4,2     |
| IGX             | 8 B              | 5,1   | 5,6     | 4,2     |
| ILX             | AB               | 5,1   | 5,6     | 4,2     |

<u>Function</u>: Algebraic comparaison between (A) and y<sub>2</sub> Result in indicators

A-register contents compared to  $Y_2$  -address operand; result of comparaison in Carry and Overflow indicators.

A-register contents is treated as the first term of the comparaison,  $Y_2$  -address operand as the second.

Modified elements :

- Indicators : C-O

Indicators :

| с | 0 | Upon execution           |
|---|---|--------------------------|
| 0 | 0 | $(A) > y_2$ $(A) < y_2$  |
| 1 | 0 | $(A) = y_2$<br>(A) = y_2 |

Trap conditions : standard

| СМР | EPDL1      |
|-----|------------|
| СМР | =3         |
| СМР | ₩ EPDC1    |
| СМР | a EPDL2    |
| СМР | a⊭EPDC20,× |
| CMP | ∂EPDL20,×  |
|     |            |

#### VII-6. REGISTER INCREMENTATION AND DECREMENTATION

ICX InCrement X DCX DeCrement X ICL InCrement L DCL DeCrement L

#### NAME : InCrement X

Class : 1

Non-priviledged

#### Instruction format :

|   | Addı | ress |   |   |   |   |   |   |   | D  | isplace | ement |    |    |    |
|---|------|------|---|---|---|---|---|---|---|----|---------|-------|----|----|----|
|   |      |      |   | 0 | 0 | 1 | 0 |   |   |    |         |       |    |    |    |
| 0 | 1    | 2    | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11      | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 32               | 2,2                 |
| PX              | E2               | 2,2                 |
| Р               | F2               | 2,2                 |

#### <u>Function</u>: $(X) + y_2 \longrightarrow (X)$

X-register contents incremented by  $Y_2$ -address operand; result in X-register.

#### Modified elements :

- Registers : X

- Indicators : C-O

Indicators :

| с | 0 | Upon execution |
|---|---|----------------|
| 1 | - | Carry          |
| - | 1 | Overflow       |

Trap conditions : standard

Examples :

| ІСХ | EPDL11 |                    |
|-----|--------|--------------------|
| ICX | =&1A,× |                    |
| ICX | =22    |                    |
| ICX | =0,X   | X multiplied by 2. |



Standard

NAME : DeCrement X

#### Class : 1

Non-priviledged

Standarð

DCX

Instruction format :

| Address |   |      |       |      | Displacem         | ent                 |
|---------|---|------|-------|------|-------------------|---------------------|
|         | 0 | 0    | 1     | 1    |                   |                     |
| 1 2 3   | 4 | 5    | 6     | 7    | <b>8</b> 97 10 11 | 12 13 14 15         |
|         | A | ddre | ssing | mode | Hexadecimal code  | Execution time (µs) |
|         |   |      | DL    |      | 33                | 2,2                 |
|         |   |      | ΡΧ    |      | E3                | 2,2                 |
|         |   |      | Р     |      | F3                | 2,2                 |

## <u>Function</u>: $(X) - y_2 \longrightarrow (X)$

X-register contents decremented by  $Y_2$  -address contents; result in X-register.

Modified elements :

- Registers : X
- Indicators : C-O

#### Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 1 | - | Carry          |
| - | 1 | Overflow       |

#### Trap conditions : standard

| DCX | EPDL1 |
|-----|-------|
| DCX | =3,×  |
| DCX | =9    |

NAME : InCrement L

ß

Non-priviledged

Non-priviledged

Standard

ICL

Instruction format :

| Address<br>1 2 3 | 0               | Displacement<br>1 0 1<br>5 6 7 8 9 10 11 12 13 14 15 |   |      |                  |                     |  |  |  |
|------------------|-----------------|------------------------------------------------------|---|------|------------------|---------------------|--|--|--|
|                  | Addressing mode |                                                      |   | mode | Hexadecimal code | Execution time (µs) |  |  |  |
|                  | DL              |                                                      |   |      | 35               | 2,2                 |  |  |  |
|                  | PX              |                                                      |   |      | E5               | 2,2                 |  |  |  |
|                  |                 |                                                      | Р |      | F5               | 2,2                 |  |  |  |

<u>Function</u>: (L) +  $y_2 \rightarrow$  (L)

L-register contents incremented by  $Y_2$  -address operand; result in L-register.

#### Modified elements :

- Registers : L

Trap conditions : standard

#### Examples :

| ICL | EPDL5 |
|-----|-------|
| ICL | =50,× |
| ICL | =255  |

#### NAME : DeCrement L

Class : 1

#### Instruction format :

| Address |    |                 |   |    |     |                  | D  | isplacem | ent |     |                     |    |  |  |
|---------|----|-----------------|---|----|-----|------------------|----|----------|-----|-----|---------------------|----|--|--|
|         | 0  | 1               | 1 | 0  |     |                  |    |          |     |     |                     |    |  |  |
| 0 1 2 3 | 4  | 5               | 6 | 7  | 8   | 9                | 10 | 11       | 12  | 13  | 14                  | 15 |  |  |
|         | A  | Addressing mode |   |    | Hex | Hexadecimal code |    |          |     |     | Execution time (µs) |    |  |  |
|         |    | DL              |   |    |     | 36               |    |          |     |     | 2,2                 |    |  |  |
|         | PX |                 |   | E6 |     |                  |    | 2,2      |     |     |                     |    |  |  |
|         |    | Р               |   |    | F6  |                  |    |          |     | 2,2 |                     |    |  |  |

<u>Function</u>: (L) -  $y_2 \rightarrow$  (L)

L-register contents decremented by  $Y_2$  -address contents; result in L-register.

### Modified elements :

- Registers : L

Trap conditions : standard

## DCL

Standard

VII-37

Examples :

| DCL | EPDL5 |
|-----|-------|
| DCL | =5,×  |
| DCL | =&1F  |

VII-7. SHIFT OPERATIONS

VII-7.1. Introduction

There are two basic shift instructions : SHR (SHift Register) and SHC (SHift speCial). Both use a word located at  $Y_2$  memory address to specify the shift type and the number of shift steps.

| Address Code Displacement      |                              |
|--------------------------------|------------------------------|
|                                | (P)-address word             |
|                                | Y <sub>2</sub> -address word |
| Shift No. of<br>type positions |                              |

In most cases, the addressing mode is parameter (immediate) and these two words are obviously identical.

For the sake of clarity, each instruction derived from SHR and SHC will be described separately.

Their mnemonics are recognized by MITRAS II.

#### Remark 1 :

A particular case of the SHC family, DITR, is not a shift instruction. Though mentionad with SHC derivates, it will be fully described with system branch instructions.

#### Remark 2 :

"Direct, Local" addressing is only applicable to SHR and SHC themselves, since it is meaningless for their derivates (SLLS..., SLLD...).

11 <sup>32</sup>

#### VII-7.2. Description

|               | SHR<br>SLLS<br>SRCS<br>SAD<br>SLCD<br>SLCS<br>SAS<br>SRLS<br>SRCD | SHift Register<br>Shift Left Logical Single (A)<br>Shift Right Logical Single (A)<br>Shift Arithmetic Double (E, A)<br>Shift Left Circular Double (E, A)<br>Shift Left Circular Single (A)<br>Shift Arithmetic Single (A)<br>Shift Right Logical Single (A)<br>Shift Right Circular Double (E, A) |
|---------------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SHC derivates | SHC<br>SLLD<br>SRLD<br>PTY<br>NLZ                                 | SHift speCial<br>Shift Left Logical Double (E, A)<br>Shift Right Logical Double (E, A)<br>compute PariTY (A)<br>NormaLiZe length (E, A)                                                                                                                                                           |

The following notation will be used in the description of the hexadecimal code of SHR and SHC families.

xx y - n no. of shift steps additional code in hexadecimal hexadecimal code of SHR or SHC instruction

Example :

SRLS = 5

| Γ | Address | 0 | 0 | 0 | 0 | 1 | 1 | 0  | 0  | 0 | 1 | 0 | 1  |
|---|---------|---|---|---|---|---|---|----|----|---|---|---|----|
| 0 | 3       | 4 |   |   | 7 | 8 |   | 10 | 11 |   |   |   | 15 |

E0 C-n  $n=5 \Longrightarrow E0$  C5

NAME : SHift Register

#### Class : 1

Non-priviledged

Standard

Ľ

Instruction format :



| Addressing mode | Hexadecimal code |  |  |  |  |  |
|-----------------|------------------|--|--|--|--|--|
| DL              | 30               |  |  |  |  |  |
| PX              | EO               |  |  |  |  |  |
| Р               | FO               |  |  |  |  |  |

Execution time depending on operation type.

Function : r shifted  $\rightarrow$  r (r denoting A or E, A)

- arithmetic shift :  $r_0$  repeated at each shift step - circular shift :  $r_0$  considered as following r

 $N_{11-15}$  number of shift steps ( $0 \le N_{11-15} \le 31$ )

N<sub>8-10</sub> shift type

| - 0 | Left, Logical, single (A)      | SLLS |
|-----|--------------------------------|------|
| - 1 | Right, circular, single (A)    | SRCS |
| - 2 | Arithmetic, double (E, A)      | SAD  |
| - 3 | Left, circular, double (E, A)  | SLCD |
| - 4 | Left, circular, single (A)     | SLCS |
| - 5 | Arithmetic, single (A)         | SA S |
| - 6 | Right, logical, single (A)     | SRLS |
| - 7 | Right, circular, double (E, A) | SRCD |

#### Modified elements :

- Registers : A (and E for double length shifts)
- Memory locations
- Indicators : C-O

Indicators :

| с   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | ¥ | Last bit shifted out of r |
| #   | # | lf step no. = zero        |

#### Trap conditions : standard

| SHR | EPDL5 (equivalent to SRCD = 31)              |
|-----|----------------------------------------------|
| SHR | =11, x (if (x) = 0, equivalent to SLLS = 11) |
| SHR | = &41 (equivalent to SAD = 1)                |

#### NAME : Shift Left, Logical, Single

.

Class : 1

Non-priviledged

Standard

**SLLS** 

Instruction format :

|   | Addr | ress |   |   |   |   |   |   |   |    | N  | umber | of sh | ift ste | ps |
|---|------|------|---|---|---|---|---|---|---|----|----|-------|-------|---------|----|
|   |      |      |   | 0 | 0 | 0 | 0 | 0 | 0 | 0  |    |       |       |         |    |
| 0 | 1    | 2    | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12    | 13    | 14      | 15 |

| Addressing mode | Hexadeo | cimal code | Execution time (µs) |  |  |  |  |
|-----------------|---------|------------|---------------------|--|--|--|--|
| PX              | EO      | 0-n        | 4,3 + 1,2 n         |  |  |  |  |
| Р               | F0      | 0-n        | 4,3 + 1,2 n         |  |  |  |  |
| Leos            | L       |            | <b>L</b>            |  |  |  |  |

n = number of shift steps

 $\frac{\text{Function}}{n = ((P))_{11-15}} = N_{11-15}$ 

Contents of A-register shifted n positions to the left. Lower order bits replaced by 0's.

Modified elements :

#### - Registers : A

Indicators :

| с   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | ¢ | Last bit shifted out of A |
| #   | # | lf initial shift = 0      |

#### Trap conditions : standard

| SLLS | =SPDL3,× |                        |
|------|----------|------------------------|
| SLLS | =2       |                        |
| SLLS | =2       | equivalent to SLLS = 6 |
| SLLS | =4,×     | equivalent to SLLS - 6 |

#### NAME : Shift Right, Circular, Single

Class : 1

0

Non-priviledged

Standard

SRCS

Instruction format :

| Addre | ss |   |                 |   |   |                  |    |     |    | Nun                 | nber of sh | ift step | )S |
|-------|----|---|-----------------|---|---|------------------|----|-----|----|---------------------|------------|----------|----|
|       |    |   | 0               | 0 | 0 | 0                | 0  | 0   | 1  |                     |            |          |    |
| 1     | 2  | 3 | 4               | 5 | 6 | 7                | 8  | 9   | 10 | 11                  | 12 13      | 14       | 15 |
|       |    |   | Addressing mode |   |   | Hexadecimal code |    |     |    | Execution time (ys) |            |          |    |
|       |    |   | PX              |   |   |                  | EO | 2-n |    | 4,3 + 1,5 n         |            |          |    |
|       |    |   | Р               |   |   |                  | EO | 2-n |    | 4,3 + 1,5 n         |            |          |    |

#### n = number of shift steps

<u>Function</u>: (A) shifted arith. (A)  $n = ((P))_{11-15} = N_{11-15}$ 

Contents of A-register shifted circularly n positions to the right, bit 0 following bit 15.

Modified elements :

#### - Registers : A

Indicartors :

| с   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | ¥ | Last bit shifted out of A |
| #   | Ħ | lf initial shift = 0      |

#### Trap conditions : standard

| SRCS | =5,×   |
|------|--------|
| SRCS | =SPDL3 |

#### NAME : Shift Arithmetic, Double

Class : 1

Non-priviledged

Standard

SAD

Instruction format :

|   | Addr | ess |   |   |   |   |   |   |   |    | Ni | umber | of shi | ft step | os |
|---|------|-----|---|---|---|---|---|---|---|----|----|-------|--------|---------|----|
|   |      |     |   | 0 | 0 | 0 | 0 | 0 | 1 | 0  |    |       |        |         |    |
| 0 | 1    | 2   | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12    | 13     | 14      | 15 |

| Addressing mode | Hexade | cimal code | Execution time (us) |  |  |
|-----------------|--------|------------|---------------------|--|--|
| PX              | EO     | 4-n        | 4,3+2,1 n           |  |  |
| Р               | FO     | 4-n        | 4,3 + 2,1 n         |  |  |

#### n = number of shift steps

<u>Function</u>: (E, A) shifted  $\rightarrow$  (E, A) n = ((P))<sub>11-15</sub> = N<sub>11-15</sub>

Contents of E,A extended register shifted arithmetically n positions to the right. Bit 0 (sign bit) restored after each shift step.

Modified elements :

- Registers : E-A

Indicators :

| С   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | ŧ | Last bit shifted out of A |
| #   | # | lf initial shift = 0      |

Trap conditions : standard

Examples :

 SAD
 =SPDL2, x

 SAD
 =&03

#### NAME : Shift Left, Circular, Double

Class : 1

Non-priviledged

Standard

**SLCD** 

Instruction format :

| Addr | ess |   |   |                 |   |    |                  |   |    |                     | Nur | nber of sh | ift steps | 6  |
|------|-----|---|---|-----------------|---|----|------------------|---|----|---------------------|-----|------------|-----------|----|
|      |     |   |   | )               | 0 | 0  | 0                | 0 | 1  | 1                   |     |            |           |    |
| 1    | 2   | 3 | 4 |                 | 5 | 6  | 7                | 8 | 9  | 10                  | 11  | 12 13      | 14        | 15 |
|      |     |   |   | Addressing mode |   |    | Hexadecimal code |   |    | Execution time (us) |     |            |           |    |
|      |     |   |   |                 |   | PX |                  |   | EO | 6                   | n-n |            | + 2,1     |    |
|      |     |   |   |                 |   | Р  |                  |   | FO | 6                   | -n  |            | + 2,1     |    |

#### n = number of shift steps

<u>Function</u>: (E, A) shifted  $\rightarrow$  (E, A) n = ((P))<sub>11-15</sub> = N<sub>11-15</sub>

Contents of E, A extended register shifted circularly n positions to the left, bit 31 following bit 0.

#### Modified elements :

- Registers : E-A

Indicators :

| с   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | ŧ | Last bit shifted out of E |
| #   | # | lf initial shift = 0      |

Trap conditions : standard

| SLCD | =15,× |
|------|-------|
| SLCD | =1    |

#### NAME : Shift Left, Circular, Single

Class : 1

0

Non-priviledged

Standard

**SLCS** 

Instruction format :

| Address |                 |   |    |   |    |      |      | Num    | ber of shift steps  |
|---------|-----------------|---|----|---|----|------|------|--------|---------------------|
|         | 0               | 0 | 0  | 0 | 1  | 0    | 0    |        |                     |
| 1 2 3   | 4               | 5 | 6  | 7 | 8  | 9    | 10   | 11     | 12 13 14 15         |
|         | Addressing mode |   |    |   | He | xade | cima | l code | Execution time (µs) |
|         |                 |   | PX |   |    | EO   | 8    | l-n    | 4,3 + 1,5 n         |
|         |                 |   | Ρ  |   |    | F0   | 8    | l-n    | 4,3 + 1,5 n         |

n = number of shift steps

<u>Function</u>: (A) shifted  $\rightarrow$  (A) n = ((P))<sub>11-15</sub> = N<sub>11-15</sub>

Contents of A-register shifted circularly n positions to the left, bit 15 following bit 0.

Modified elements :

#### - Registers : A

Indicators :

| с   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | ≠ | Last bit shifted out of A |
| #   | # | If initial shift = 0      |

#### Trap conditions : standard

| SLCS | =2,× |
|------|------|
| SLCS | =7   |

# NAME : Shift right, Arithmetic, Single

Class : 1

Non-priviledged

Standard

SAS

Instruction format :

|   | Addr | ess |   |   |   |   |   |   |   |    | Nu | mber | of shi | ft step | os |
|---|------|-----|---|---|---|---|---|---|---|----|----|------|--------|---------|----|
|   |      |     |   | 0 | 0 | 0 | 0 | 1 | 0 | 1  |    |      |        |         |    |
| 0 | 1    | 2   | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12   | 13     | 14      | 15 |

| Addressing mode | Hexade | cimal code | Execution time (ys) |
|-----------------|--------|------------|---------------------|
| PX              | EO     | A-n        | 4,3 + 1,5 n         |
| Р               | FO     | A-n        | 4,3 + 1,5 n         |

n = number of shift steps

 $\frac{\text{Function}: (A) \text{ shifted}}{n = ((P))_{11-15}} = N_{11-15}$ 

Contents of A-register shifted arithmetically n positions to the right. Bit 0 (sign bit) is restored after each shift step.

#### Modified elements :

- Registers : A

- Indicators : C-O

Indicators :

| С   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | ¢ | Last bit shifted out of A |
| #   | # | lf initial shift = 0      |

#### Trap conditions : standard

| SA S | =&2,×  |
|------|--------|
| SA S | =SPDL2 |

# NAME : Shift Right, Logical, Single

Class : 1

Non-priviledged

Standard

SRLS

Instruction format :

|   | Addr | ess |   |   |   |   |   |   |   |    | N  | umber     | of shi | ft step | os |
|---|------|-----|---|---|---|---|---|---|---|----|----|-----------|--------|---------|----|
|   |      |     |   | 0 | 0 | 0 | 0 | 1 | 1 | 0  |    |           |        |         |    |
| 0 | 1    | 2   | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | <u>12</u> | 13     | 14      | 15 |
|   |      |     |   |   |   |   |   |   |   |    |    |           |        |         |    |

| Addressing mode | Hexade | cimal code | Execution time (µs) |
|-----------------|--------|------------|---------------------|
| PX              | EO     | C-n        | 4,3 + 1,5 n         |
| Р               | FO     | C-n        | 4,3 + 1,5 n         |

n = number fo shift steps

<u>Function</u>: (A) shifted  $\rightarrow$  (A) n = ((P))<sub>11-15</sub> = N<sub>11-15</sub>

Contents of A-register shifted n positions to the right. Upper order bits replaced by 0's.

Modified elements :

#### - Registers : A

- Indicators : C-O

Indicators :

| с   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | ŧ | Last bit shifted out of A |
| #   | # | If initial shift = 0      |

Trap conditions : standard

| SRLS | =0,× |
|------|------|
| SRLS | =8   |

# NAME : Shift Right, Circular, Double

Class : 1

Non-priviledged

Standard

SRCD

#### Instruction format :

| Address |   |       |      |      |    |        |      | Nun    | nber of sh  | ift steps   |     |
|---------|---|-------|------|------|----|--------|------|--------|-------------|-------------|-----|
|         | 0 | 0     | 0    | 0    | 1  | 1      | 1    |        |             |             |     |
| 0 1 2 3 | 4 | 5     | 6    | 7    | 8  | 9      | 10   | 11     | 12 13       | 14 15       |     |
|         | A | ddres | sing | mode | He | xade   | cima | l code | Execut      | ion time (µ | ıs) |
|         |   | PX    |      |      |    | EO E-n |      |        | 4,3 + 2,7 n |             |     |
|         |   |       | Ρ    |      |    | FO     |      | E-n    | 4,3         | 3 + 2,7 n   |     |

#### n = number of shift steps

 $\frac{\text{Function}}{n}: (E, A) \text{ shifted } - (E, A)$   $n = ((P))_{11-15} = N_{11-15}$ 

Contents of E, A extended register shifted circularly n positions to the right, bit 0 following bit 31.

#### Modified elements :

#### - Registers : E-A

- Indicators : C-O

#### Indicators :

| с   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | ŧ | Last bit shifted out of A |
| #   | # | If initial shift = 0      |

#### Trap conditions : standard

| SRCD | =18,× |
|------|-------|
| SRCD | =&12  |



If  $N_{10} = 1$ ,  $N_{11-15}$  is meaningless

| Addressing mode | Hexadecimal code |
|-----------------|------------------|
| DL              | 3C               |
| PX              | EC               |
| Р               | FC               |

Execution times vary according to shift types.

Function : r shifted  $\rightarrow$  r (r is A or E, A) $N_{11-15}$  number of shift step $0 \le N_{11-15} \le 32$  $N_{8-10}$  instruction type

- 0 Shift left logical in E, A (SLLD) N<sub>11-15</sub> = number of shift steps
- 4 Shift right logical in E, A (SRLD)
   N<sub>11-15</sub> = number of shift steps
- Compute parity in A (PTY)
   N<sub>11-15</sub> = number of shift steps
   Upon execution, E contains the number of set bits shifted out of (A)
- 6 Double lengh normalize in E, A N<sub>11-15</sub> = maximum number of shift steps
   - 3/5
   High-speed interrupt de-activation (DITR). Only bit N<sub>10</sub> is taken into consideration when set.

Modified elements :

5 7

- Registers : A (and E for double shifts)
- Indicators : C O

Indicators :

| с   | 0 | Upon execution       |
|-----|---|----------------------|
| 0/1 | # | Last bit shifted out |
| #   | # | If step no. = zero   |

Remark :

This page only describes the general usage of SHC. For further details see the individual description of each particular case.

<u>Trap conditions</u>: Standard and non-implemented instruction (Mode violation for DITR)

Miscellaneous : DITR will be described separately with the control instruction.

| SHC | EPDL12 (equivalent to SRLD = 2)           |
|-----|-------------------------------------------|
| SHC | =5, x (if x = 5, equivalent to SLLS = 10) |
| SHC | &48 (equivalent to PTY = 8)               |

# NAME : Shift Left, Logical, Double

Class : 1

Non-priviledged

Optional

**SLLD** 

Instruction format :

|   | Addr | ess |   |   |   |            |   |     |   |    | N  | umber | of shi | ft step | os |
|---|------|-----|---|---|---|------------|---|-----|---|----|----|-------|--------|---------|----|
|   |      |     |   | 1 | 1 | 0          | 0 | 0   | 0 | 0  |    |       |        |         |    |
|   |      |     |   |   |   | . <u> </u> |   | l Č |   |    |    |       |        |         |    |
| 0 | 1    | 2   | 3 | 4 | 5 | 6          | 7 | 8   | 9 | 10 | 11 | 12    | 13     | 14      | 15 |

| Addressing mode | Hexadec | imal code | Execution time (µs) |
|-----------------|---------|-----------|---------------------|
| PX              | EC      | 0-n       | 4,9 +1,2 n          |
| Р               | FC      | 0-n       | 4,9 +1,2 n          |

#### n = number of shift steps

<u>Function</u>: (E, A) shifted  $\rightarrow$  (E, A) n = ((P))<sub>11-15</sub> = N<sub>11-15</sub>

Contents of E, A extended register shifted n positions to the left. Lower order bits replaced by 0's.

#### Modified elements :

- Registers : E-A

Indicators :

| с   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | ¥ | Last bit shifted out of E |
| #   | # | lf step no. = zero        |

Trap conditions : Standard and non-implemented instruction

| SLLD | =5,× |
|------|------|
| SLLD | =&0E |

#### NAME : Shift Right, Logical, Double

Class : 1

Non-priviledged

Optional

**SRLD** 

Instruction format :

|   | Addr | ess |   | _ |   |   |   |   |   |    | Nu | umber | of shi | ft step | os |
|---|------|-----|---|---|---|---|---|---|---|----|----|-------|--------|---------|----|
|   |      |     |   | 1 | 1 | 0 | 0 | 1 | 0 | 0  |    |       |        |         |    |
| 0 | 1    | 2   | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12    | 13     | 14      | 15 |
|   |      |     |   |   |   |   |   |   |   |    |    |       |        |         |    |

| Addressing mode | Hexadeci | imal code | Execution time (µs) |  |  |  |
|-----------------|----------|-----------|---------------------|--|--|--|
| PX              | EC       | 8-n       | 4,9 + 1,8 n         |  |  |  |
| Р               | FC       | 8-n       | 4,9 + 1,8 n         |  |  |  |

#### n = number of shift steps

 $\frac{\text{Function}}{n}: (E, A) \text{ shifted } \longrightarrow (E, A)$   $n = ((P))_{11-15}$ 

Contents of E, A extended register shifted n positions to the right. Upper order bits replaced by 0's.

#### Modified elements :

- Registers : E-A

- Indicators : C-O

#### Indicators :

| с   | 0 | Upon execution            |
|-----|---|---------------------------|
| 0/1 | # | Last bit shifted out of A |
| #   | # | lf step no. = zero        |

Trap conditions : Standard and non-implemented instruction

| SRLD | =3,× |
|------|------|
| SRLD | =31  |

NAME : PariTY check in A

Class : 1

Non-priviledged

Optional

Instruction format :

|   | Addre | ess |   |   |       |      |      |    |      |      | Nu     | Imber | of shi | ft ste | ps    | _     |
|---|-------|-----|---|---|-------|------|------|----|------|------|--------|-------|--------|--------|-------|-------|
|   |       |     |   | 1 | 1     | 0    | 0    | 0  | 1    | 0    |        |       |        |        |       |       |
| 0 | 1     | 2   | 3 | 4 | 5     | 6    | 7    | 8  | 9    | 10   | 11     | 12    | 13     | 14     | 15    | _     |
|   |       |     |   | A | ddres | sing | mode | He | xade | cima | l code | E>    | ecut   | ion t  | ime   | (µs)  |
|   |       |     |   |   |       | PX   |      |    | EC   | 4    | l-n    | 5     | ,8 +   | 1,2    | n + ( | ),3 m |
|   |       |     |   |   |       | Р    |      |    | FC   | 4    | -n     | 5     | ,8+    | 1,2    | n + 0 | ,3 m  |

n = number of shift steps

m = number of set bits detected

Function: (A) shifted(A)(E) = number of set bits shifted out of (A)
$$n = ((P))_{11-15} = N_{11-15}$$

A-register contents shifted circularly in positions to the left. When the instruction is over, E-register contains the number of set bits which have been shifted out of A.

#### Modified elements :

- Registers : A
- Indicators : C-O

#### Indicators :

| с   | 0   | Upon execution                  |
|-----|-----|---------------------------------|
| 0/1 | -   | Last bit shifted out of A       |
| -   | 0/1 | (E <sub>15</sub> ) = parity bit |
| #   | #   | lf step no. = zero              |

Trap conditions : Standard and non-implemented instruction

| PTY | =2,× |
|-----|------|
| PTY | =&F  |

#### NAME : double length NormaLiZe (option)

Class : 1

Non-priviledged

Optional

NLZ

#### Instruction format :

|   | Addr | ess |   |   |       | -     |      |    |      |          | Nun    | nber | of shi | ft step | os       |
|---|------|-----|---|---|-------|-------|------|----|------|----------|--------|------|--------|---------|----------|
|   |      |     |   | 1 | 1     | 0     | 0    | 1  | 1    | 0        |        |      |        |         |          |
| 0 | 1    | 2   | 3 | 4 | 5     | 6     | 7    | 8  | 9    | 10       | 11     | 12   | 13     | 14      | 15       |
|   |      |     | ļ | A | dress | ina r | mode | He | xade | <br>cima | l code | E    |        | ion ti  | ime (us) |

| Addressing mode | Hexadecim | al code | Execution time (µs) |
|-----------------|-----------|---------|---------------------|
| PX              | EC        | C-n     | 4,9 + 1,8 n         |
| Р               | FC        | C-n     | 4,9 +1,8 n          |

#### n = number of shift steps

Function:(E, A) shifted(E, A)X is decremented by the actual number of shift steps $n = ((P))_{11-15} = N_{11-15}$ 

The contents of E, A extended register is shifted to the left until bit 0 is different from bi 1 or up to a maximum of n positions. X-register is decremented by the actual number of shift steps.

Modified elements :

- Registers : E - A - X

- Indicators : C-O

Indicators :

| С | 0 | Upon execution     |
|---|---|--------------------|
| 0 | 0 | Normalization 01   |
| 0 | 1 | Stop on zero count |
| 1 | 0 | Normalization 10   |

Trap conditions : Standard and non-implemented instruction

| NLZ | =10,× |
|-----|-------|
| NLZ | =20   |

#### VII-8. INTER-REGISTER OPERATIONS

#### VII-8.1. Introduction

SRG (SeT Register) is the basic instruction for inter-register operations. A word located at Y memory address is used to specify the operation type.



In parameter addressing mode which is normally used, these two words are obviously identical.

For the sake of clarity, each instruction derived from SRG will be described separately.

Their mnemonics are recognized by MITRAS I and II.

#### Remark 1 :

Two particular cases of SRG, RTS and RSV, do not belong to the inter-register operation class. Though mentioned with SRG, they will be fully described with system branch instructions.

#### Remark 2 :

Any addressing mode other than "parameter" is meaningless for SRG-family instructions.

#### VII-8.2. Description

Inter-register operations will be described in the following order :

|                 | SRG | Set ReGister                                |
|-----------------|-----|---------------------------------------------|
| 1               | XAE | eXchange A and E                            |
|                 | XAX | eXchange A and X                            |
|                 | XAA | eXchange left byte of A and right byte of A |
|                 | CCE | Copy Complement E                           |
|                 | ACE | Add Carry and E                             |
|                 | ССА | Copy Complement A                           |
| SRG derivates 🧹 | AEE | A Exclusive OR with E                       |
|                 | CNX | Copy Negative X                             |
|                 | AIE | A Inclusive OR with E                       |
|                 | AAE | A And E                                     |
|                 | LNE | Load Negative E                             |
|                 | CNA | Copy Negative A                             |
|                 | СНХ | Copy Half X                                 |

#### NAME : Set ReGister

#### Class : 1

Non-priviledged

Standard

SRG

Instruction format :



| Addressing mode | Hexadecimal code |
|-----------------|------------------|
| DL              | 31               |
| PX              | El               |
| Р               | Fl               |

Execution time depending on operation type.

# Function : N<sub>11-14</sub>

| •   |                                                             |
|-----|-------------------------------------------------------------|
| - 0 | ReTurn Section 🛛 🛶 (RTS)                                    |
| - 1 | Exchange contents of A and E 🛶 (XAE)                        |
| - 2 | Exchange contents of A and X (XAX)                          |
| - 3 | Exchange contents of E and X 🛛 🛶 (XEX)                      |
| - 4 | Exchange $(A_{0-7})$ and $(A_{8-15}) \longrightarrow (XAA)$ |
| - 5 | Complement E 🔶 (CCE)                                        |
| - 6 | Return SuperVisor 🗕 (RSV)                                   |
| - 7 | Add Carry in E 🛛 🛶 (ACE)                                    |
| - 8 | Complement A 🛶 (CCA)                                        |
| - 9 | A Exclusive OR E in A 🛶 (AEE)                               |
| - A | Copy Negative X 🛶 (CNX)                                     |
| - B | A OR E in A 🛶 (AIE)                                         |
| - C | A and E in A 🛶 (AAE)                                        |
| - D | Load Negative in E 🛛 → (LNE)                                |
| - E | Copy Negative A 🛛 🛶 (CNA)                                   |
| - F | Compute Half X — (CHX)                                      |

#### Modified elements :

- Registers : see individual instructions

- Indicators : see individual instruction

Trap conditions : standard

| SRG | EPDL11 (equivalent to XEX)                   |
|-----|----------------------------------------------|
| SRG | =&10, $\times$ ((x) = &E, equivalent to CHX) |
| SRG | =1.4 (equivalent to ACE)                     |

#### NAME : eXchange contents of A and E

Class : 1

Non-priviledged

02

4,3

Standard

XAE

Instruction format :



F1

#### Function : (A) $\longrightarrow$ (E)

#### Contents of A-register and E-register exchanged

Ρ

Modified elements :

- Registers : E-A

Trap conditions : standard

Examples : XAE

#### NAME : eXchange contents of A and X

Class : 1

# Non-priviledged

#### Instruction format :

|   |   | Add | ress |   |   |     |   |   |   |   |    | lins | tructio | on typ | e  |    |
|---|---|-----|------|---|---|-----|---|---|---|---|----|------|---------|--------|----|----|
|   | 1 | 1   | 1    | 1 | 0 | · 0 | 0 | 1 |   |   |    | 0    | 0       | 1      | 0  |    |
| I | 0 | 1   | 2    | 3 | 4 | 5   | 6 | 7 | 8 | 9 | 10 | 11   | 12      | 13     | 14 | 15 |

| Addressing mode | Hexadec | imal code | Execution time (µs) |  |  |  |  |
|-----------------|---------|-----------|---------------------|--|--|--|--|
| Р               | Fl      | 04        | 4,3                 |  |  |  |  |

Function : (A)  $\rightarrow$  (X)

Contents of A-register and X-register exchanged.

#### Modified elements :

- Registers : A - X

Trap conditions : standard

Examples : XAX



VII-58

### NAME : eXchange contents of E and X

Class : 1

#### Instruction format :

|   | Add | ress                |   |   |      |       |      |     |     |       | Inst | ructio | on typ | e    |           |
|---|-----|---------------------|---|---|------|-------|------|-----|-----|-------|------|--------|--------|------|-----------|
| 1 | 1   | 1                   | 1 | 0 | · 0  | 0     | 1    |     |     |       | 0    | 0      | 1      | 1    |           |
| 0 | 1   | 2                   | 3 | 4 | 5    | 6     | 7    | 8   | 9   | 10    | 11   | 12     | 13     | 14   | 15        |
|   |     |                     | Ī | A | ddre | ssing | mode | Hex | ade | cimal | code | e Ex   | xecu   | tion | time (µs) |
|   |     |                     |   |   |      | Ρ     |      | F1  |     |       | 06   |        |        | 4,3  |           |
|   |     | <i>i</i> _ <b>1</b> | - | ( |      |       |      |     |     |       |      |        |        |      |           |

Non-priviledged

### Function : (E) $\longrightarrow$ (X)

#### Contents of E-register and X-register exchanged.

#### Modified elements :

– Registers : E – X

Trap conditions : standard

Examples : XEX

#### NAME : eXchange left byte of A and right byte of A

Class : 1

Instruction format :

|   | Add | ress |   |   |     |   |   |   |   |    | Ins | structio | on typ | e  |    |
|---|-----|------|---|---|-----|---|---|---|---|----|-----|----------|--------|----|----|
| 1 | 1   | 1    | 1 | 0 | · 0 | 0 | 1 |   |   |    | 0   | 1        | 0      | 0  |    |
| 0 | 1   | 2    | 3 | 4 | 5   | 6 | 7 | 8 | 9 | 10 | 11  | 12       | 13     | 14 | 15 |

| Addressing mode | Hexade | cimal code | Execution time (µs) |  |  |  |  |
|-----------------|--------|------------|---------------------|--|--|--|--|
| Р               | Fl     | 08         | 2,8                 |  |  |  |  |

Non-priviledged

Function :  $(A_{0-7}) \rightarrow (A_{8-15})$ 

Rightmost and leftmost bytes of A-register exchanged.

Modified elements :

- Registers : A

Trap conditions : standard

Examples : XAA





#### NAME : Copy Complement, logical E

Class : 1

Non-priviledged

0A

2,8

Standard

CCE

Instruction format :

#### Instruction type Address 1 0 0 0 1 1 0 1 0 1 1 2 3 5 6 7 8 9 10 11 12 13 14 15 4 Addressing mode Hexadecimal code Execution time (us)

F1

# Function : (Ē) --- (E)

One's complement of E-register contents (bit 1 --- 0, bit 0 --- 1).

Ρ

#### Modified elements :

- Registers : E

Trap conditions : standard

Examples : CCE

### NAME : Add Carry in E

Class : 1

### Non-priviledged

#### Instruction format :

|   | Add | ress |   |   |     |   |   |   |   |    | Ins | tructio | on typ | e  |    |
|---|-----|------|---|---|-----|---|---|---|---|----|-----|---------|--------|----|----|
| 1 | 1   | 1    | 1 | 0 | · 0 | 0 | 1 |   |   |    | 0   | 1       | 1      | 1  |    |
| 0 | 1   | 2    | 3 | 4 | 5   | 6 | 7 | 8 | 9 | 10 | 11  | 12      | 13     | 14 | 15 |

| Addressing mode | Hexadeo | imal code | Execution time (us) |  |  |  |  |
|-----------------|---------|-----------|---------------------|--|--|--|--|
| Р               | Fl      | 0E        | 3,4                 |  |  |  |  |

Function : (E) + C  $\rightarrow$  (E)

Carry indicator value added to E-register contents; result in E.

### Modified elements :

- Registers : E

- Indicators : C-O

Indicators :

| с | 0 | Upon execution |
|---|---|----------------|
| 1 | - | Carry          |
| _ | 1 | Overflow       |

#### <u>Trap conditions</u> : standard

Examples : ACE

# ACE

Standard

#### NAME : Copy Complement, logical A

Class : 1

Non-priviledged

Standard

CCA

Instruction format :

|         | Add | ress |   |   |     |   |   |   |   |    | Ins | structio | on typ | e  | _  |
|---------|-----|------|---|---|-----|---|---|---|---|----|-----|----------|--------|----|----|
| 1       | 1   | 1    | 1 | 0 | . 0 | 0 | 1 |   |   |    | 1   | 0        | 0      | 0  |    |
| <b></b> | 1   | 2    | 3 | 4 | 5   | 6 | 7 | 8 | 9 | 10 | 11  | 12       | 13     | 14 | 15 |

| Addressing mode | Hexadec | imal code | Execution time (µs) |  |  |  |  |
|-----------------|---------|-----------|---------------------|--|--|--|--|
| Р               | Fl      | 10        | 2,8                 |  |  |  |  |

# <u>Function</u> : $(\overline{A}) \longrightarrow (A)$

One's complement of E-register contents (bit  $1 \rightarrow 0$ , bit  $0 \rightarrow 1$ ).

Modified elements :

- Registers : A

Trap conditions : standard

Examples : CCA

#### NAME : A Exclusive OR E in A

Class : 1

#### Non-priviledged

Instruction format :

|   |   | Addr | ress |   |   |     |   |   |   |   |    | Ins | structio | on typ | е  |    |
|---|---|------|------|---|---|-----|---|---|---|---|----|-----|----------|--------|----|----|
|   | 1 | 1    | 1    | 1 | 0 | · 0 | 0 | 1 |   |   |    | 1   | 0        | 0      | 1  |    |
| • | 0 | 1    | 2    | 3 | 4 | 5   | 6 | 7 | 8 | 9 | 10 | 11  | 12       | 13     | 14 | 15 |

| Addressing mode | Hexadeo | cimal code | Execution time (µs) |  |  |  |  |
|-----------------|---------|------------|---------------------|--|--|--|--|
| Р               | F۱      | 12         | 3,1                 |  |  |  |  |

Function : (A)  $\oplus$  (E) \_\_ (A)

Exclusive OR between A-register contents and E-register contents; result in A.

#### Modified elements :

- Registers : A

- Indicators : C-O

Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | A > 0          |
| 0 | 1 | A < 0          |
| 1 | 0 | A = 0          |



Standard

f

#### NAME : Copy Negative X

Class : 1

Non-priviledged

Standard

CNX

Instruction format :



| Addressing mode | Hexadea | imal code | Execution time (µs) |  |  |  |  |
|-----------------|---------|-----------|---------------------|--|--|--|--|
| Р               | Fl      | 14        | 3,1                 |  |  |  |  |

Function :  $-(X) \longrightarrow (X)$ 

Two's complement (complement to  $2^{16}$ ) of X-register contents; result in X.

Modified elements :

- Registers : X

Trap conditions : standard

Examples : CNX

#### NAME : A Inclusive or E in A

Class : 1

#### Non-priviledged

Instruction format :

| _ |   | Add | ress |   | Instruction type |     |   |   |   |   |    |    |    |    |    |    |
|---|---|-----|------|---|------------------|-----|---|---|---|---|----|----|----|----|----|----|
|   | 1 | 1   | 1    | 1 | 0                | · 0 | 0 | 1 |   |   |    | 1  | 0  | 1  | 1  |    |
|   | 0 | 1   | 2    | 3 | 4                | 5   | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |

| Addressing mode | Hexadec | imal code | Execution time (µs) |  |  |  |  |
|-----------------|---------|-----------|---------------------|--|--|--|--|
| Р               | Fl      | 16        | 3,1                 |  |  |  |  |

<u>Function</u> : (A)  $\lor$  (E)  $\longrightarrow$  (A)

Inclusive OR between A-register contents and E-register contents; result in A.

Modified elements :

- Registers : A

- Indicators : C-O

Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | A > 0          |
| 0 | 1 | A < 0          |
| 1 | 0 | A = 0          |

#### Trap conditions : standard

Examples : AIE



NAME : A And E in A

Non-priviledged

Standard

ΔΔΕ

Instruction format :



<u>Function</u>: (A)  $\land$  (E)  $\rightarrow$  (A)

Logical AND (intersection) between A-register contents, and E-register contents; result in A.

Modified elements :

- Registers : A

- Indicators : C-O

Indicators :

| с | 0 | Upon execution |
|---|---|----------------|
| 0 | 0 | A > 0          |
| 0 | 1 | A < 0          |
| 1 | 0 | A = 0          |

Non-priviledged

Trap conditions : standard

Examples : AAE

# NAME : Load, Negative in E

Class : 1

Instruction format :

|   | Add | ress |   |   |     |   |   |   |   |    | Ins | tructio | on typ | е  |    |
|---|-----|------|---|---|-----|---|---|---|---|----|-----|---------|--------|----|----|
| 1 | 1   | 1    | 1 | 0 | . 0 | 0 | 1 |   |   |    | 1   | 1       | 0      | 1  |    |
| 0 | 1   | 2    | 3 | 4 | 5   | 6 | 7 | 8 | 9 | 10 | 11  | 12      | 13     | 14 | 15 |

| Addressing mode | Hexadeo | cimal code | Execution time (µs) |  |  |  |  |
|-----------------|---------|------------|---------------------|--|--|--|--|
| Р               | F١      | 1A         | 3,1                 |  |  |  |  |

Function :  $-1 \rightarrow (E)$ 

-1 value loaded into E-register.

Modified elements :

- Registers : E

Trap conditions : standard

Examples : LNE



NAME : Copy Negative A

Non-priviledged

Standard

CNA

Instruction format :



| Addressing mode | Hexadeci | mal code | Execution time (µs) |  |  |  |
|-----------------|----------|----------|---------------------|--|--|--|
| Р               | Fl       | 1C       | 3,4                 |  |  |  |

# <u>Function</u> : - (A) $\rightarrow$ (A)

Two's complement (complement to 2<sup>16</sup>) of A-register contents; result in A.

Modified elements :

- Registers : A

- Indicators : C-O

Indicators :

| С | 0 | Upon execution |
|---|---|----------------|
| 1 | - | Carry          |
| - | 1 | Overflow       |

Trap conditions : standard

Examples : CNA

### NAME : Compute Half X

Class : 1

Non-priviledged

Instruction format :

|   | Addı | ress |   | Instruction type |     |   |   |   |   |    |    |    |    |    |    |
|---|------|------|---|------------------|-----|---|---|---|---|----|----|----|----|----|----|
| 1 | 1    | 1    | 1 | 0                | · 0 | 0 | 1 |   |   |    | 1  | 1  | 1  | 1  |    |
| 0 | 1    | 2    | 3 | 4                | 5   | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |

| Addressing mode | Hexadea | imal code | Execution time (us) |
|-----------------|---------|-----------|---------------------|
| Р               | F1      | 1 E       | 3,1                 |

<u>Function</u>: (X) / 2  $\rightarrow$  (X)

X-register contents shifted one position to the right. Sign bit (bit 0) restored. As a result, X-register contents is divided by two.

Modified elements :

- Registers : X

Trap conditions : standard

Examples : CHX

Standard

### VII-9. FLOATING-POINT ARITHMETIC

#### VII-9.1. Introduction

These instructions operate on single precision floating-point format operands and are implemented in an optional device called "floating-point operator" or OVF.

In single precision floating-point format, the numbers are represented on a double-word. This double-word has the following structure :

- A sign bit (position 0)

- A base-16 exponent whose value is increased by 64 to provide the "characteristic" (positions 1 through 7).

- A 6 hexadecimal digit mantissa (positions 8 through 31).



A floating-point number N has the following formel definition :

- If  $N \ge 0$   $N = M \times 16^{C-64}$ 

with M = 0 or  $16^{-6} \leq M < 1$  and  $0 \leq C \leq 127$ 

- A positive floating-point number having a zero mantissa must also have a zero characteristic; it represents the zero value.

- A positive floating-point number is "normalized" if its mantissa satisfies the relation :  $1/16 \le M < 1$ .

- A negative number is represented by the two's complement of its absolute value. More specifically the representation of a negative number N includes a sign bit (0), a characteristic and a mantissa on a double-word length. The number N is represented by the two's complement of this double-word.

Normally floating-point arithmetic instructions operate on normalized operands (no pre-normalization effected) and provide normalized results.

For non-normalized operands, the results are normalized or not, as the case may be.

Limits of normalized floating-point format :

 $0.86362 \times 10^{-76} < N < 0.72370 \times 10^{+76}$ 

#### VII-9.2. Description

The floating-point instructions perform the four operations and are described in the following order :

- FAD Floating ADd
- FSU Floating SUbtract
- FMU Floating MUltiply
- FDV Floating DiVide

# Examples of floating-point representations :

| Nombre Décimal                             | 9 | SINGLE PRECISION FLOATING FORMAT |      |      |      |      |      |      |       | Hexadecimal |        |
|--------------------------------------------|---|----------------------------------|------|------|------|------|------|------|-------|-------------|--------|
|                                            | + |                                  | с    | м    |      |      |      |      | value |             |        |
| +(16 <sup>+63</sup> )(1-2 <sup>-24</sup> ) | 0 | 111                              | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111  | 7 F         | FFFFFF |
| +(16 <sup>+3</sup> )(5/16)                 | 0 | 100                              | 0011 | 0101 | 0000 | 0000 | 0000 | 0000 | 0000  | 43          | 500000 |
| +(16 <sup>-3</sup> )(209/256)              | 0 | 011                              | 1101 | 1101 | 1000 | 0000 | 0000 | 0000 | 0000  | 3D          | D10000 |
| +(16 <sup>-63</sup> )(2047/4096)           | 0 | 000                              | 0001 | 0111 | 1111 | 1111 | 0000 | 0000 | 0000  | 01          | 7FF000 |
| +(16-64)(1/16)                             | 0 | 000                              | 0000 | 0001 | 0000 | 0000 | 0000 | 0000 | 0000  | 00          | 100000 |
| 0                                          | 0 | 000                              | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000  | 00          | 000000 |
| -(16 <sup>-64</sup> )(1/16)                | 1 | 111                              | 1111 | 1111 | 0000 | 0000 | 0000 | 0000 | 0000  | FF          | F00000 |
| -(16 <sup>-63</sup> )(2047/4096)           | 1 | 111                              | 1110 | 1000 | 0000 | 0001 | 0000 | 0000 | 0000  | FF          | 801000 |
| -(16 <sup>-3</sup> )(209/256)              | 1 | 100                              | 0100 | 0100 | 1111 | 0000 | 0000 | 0000 | 0000  | C2          | 2F0000 |
| -(16 <sup>+3</sup> )(5/16)                 | 1 | 011                              | 1100 | 1011 | 0000 | 0000 | 0000 | 0000 | 0000  | BC          | B00000 |
| -(16 <sup>+63</sup> )(1-2 <sup>-24</sup> ) | 1 | 000                              | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0001  | 80          | 000001 |

#### NAME : Floating ADd (option)

Class : 0'

Non-priviledged

Optional

FAD

Instruction format :

| This Toe Toring | <u> </u> |   |   |   |    |          |      |          |        |        |       |
|-----------------|----------|---|---|---|----|----------|------|----------|--------|--------|-------|
| Address         |          |   |   |   |    |          |      | Displace | ment   |        |       |
|                 | 1        | 1 | 0 | 1 | 0  |          |      |          |        |        |       |
| 0 1 2           | 3        | 4 | 5 | 6 | 7  | 89       | 10   | 11       | 12     | 13     | 14 15 |
|                 |          |   |   | 1 |    |          |      | ·        |        |        |       |
|                 |          |   |   |   | Ad | dressing | mode | Hexac    | lecimo | al cod | e     |
|                 |          |   |   |   |    | DL       |      |          | 1A     |        |       |
|                 |          |   |   |   |    | DG       |      |          | 5A     |        |       |
|                 |          |   |   |   |    | IL       |      |          | 7A     |        |       |
|                 |          |   |   |   |    | IGX      |      |          | 9A     |        |       |
|                 |          |   |   |   |    |          |      |          |        |        |       |

ILX

Function : (E, A) + ( $Y_2$ ,  $Y_2$  + 2)  $\rightarrow$  (E, A)

Contents in floating format of E, A extended accumulator added with floating operand contained in  $Y_2$  -address double-word; result in E, A.

#### Modified elements :

- Registers : E A
- Indicators : C-O

#### Indicators :

| с | 0 | Upon execution               |
|---|---|------------------------------|
| 0 | 0 | Result $\neq$ 0, no overflow |
| 0 | 1 | Overflow                     |
| 1 | 0 | Result = 0                   |
| 1 | 1 | Underflow                    |

ΒA

#### Trap conditions : standard

| FAD | EPDL26      |
|-----|-------------|
| FAD | ₩ EPDC26    |
| FAD | ລEPDL27     |
| FAD | ۵# EPDC27,× |
| FAD | ۵EPDL27,×   |

NAME : Floating SUbtract

Class : 0'

Non-priviledged

Optional

**FSU** 

Instruction format :



<u>Function</u>: (E, A) - (Y<sub>2</sub>, Y<sub>2</sub> + 2)  $\rightarrow$  (E, A)

Floating operand contained in  $Y_2$ -address double-word subtracted from contents in floating format of E, A extended accumulator; result in E, A.

#### Modified elements :

- Registers : E A
- Indicators : C-O

Indicators :

| с | 0 | Upon execution               |
|---|---|------------------------------|
| 0 | 0 | Result $\neq$ 0, no overflow |
| 0 | 1 | Overflow                     |
| 1 | 0 | Result = 0                   |
| 1 | 1 | Underflow                    |

#### Trap conditions : standard

| FSU | EPDL26       |
|-----|--------------|
| FSU | ₩ EPDC26     |
| FSU | ବ EPDL27     |
| FSU | ୍ଥ⊭ EPDC27,× |
| FSU | a EPDL27,×   |

| Non-            | priviledged                                        |
|-----------------|----------------------------------------------------|
|                 |                                                    |
|                 | Displacement                                       |
| 0               |                                                    |
| 7 8 9 10        | ) 11 12 13 14 1                                    |
| Addressing mode | Hexadecimal code                                   |
| DL              | 1C                                                 |
| DG              | 5C                                                 |
| IL              | 7C                                                 |
| IGX             | 9C                                                 |
|                 | ВС                                                 |
|                 | 0<br>7 8 9 10<br>Addressing mode<br>DL<br>DG<br>IL |

<u>Function</u>: (E, A) x (Y<sub>2</sub>, Y<sub>2</sub> + 2)  $\longrightarrow$  E, A

Contents in floating format of E, A extended accumulator (multiplicand) multiplied by floating operand contained in Y<sub>2</sub>-address double-word (multiplier); result in E, A.

#### Modified elements :

- Registers : E A
- Indicators : C-O

#### Indicators :

| с | 0 | Upon execution               |
|---|---|------------------------------|
| 0 | 0 | Result $\neq$ 0, no overflow |
| 0 | 1 | Overflow                     |
| 1 | 0 | Result = 0                   |
| 1 | 1 | Underflow                    |

#### Trap conditions : standard

#### Examples :

| FMU | EPDL26             |
|-----|--------------------|
| FMU | ₩ EPDC26           |
| FMU | a EPDL27           |
| FMU | $a \neq EPDC27, x$ |
| FMU | a EPDL27,×         |

Optional

**FMU** 

| 4057 0                 |                                  |   |
|------------------------|----------------------------------|---|
| NAME : Floating DiVide |                                  |   |
| Class : 0'             | N on-priviledged                 | ( |
| Instruction format :   |                                  |   |
| Address                | Displacement                     |   |
| 1 1 1                  | 0 1                              |   |
| 0 1 2 3 4 5            | <b>6 7 8 9 10 11 12 13 14 15</b> |   |

| Addressing mode | Hexadecimal code |
|-----------------|------------------|
| DL              | 1 D              |
| DG              | 5D               |
| IL              | 7 D              |
| IGX             | 9D               |
| ILX             | BD               |

Function : 
$$(E, A) : (Y_2, Y_2 + 2) \rightarrow (E, A)$$

Contents in floating format of E, A extended accumulator (dividend) divided by floating operand contained in Y<sub>2</sub> -address double-word (divisor); result in E, A.

Modified elements :

- Registers : E A
- Indicators : C-O

Indicators :

| с | 0 | Upon execution                |
|---|---|-------------------------------|
| 0 | 0 | Result $\neq$ 0, non overflow |
| 0 | 1 | Overflow                      |
| 1 | 0 | Result = 0                    |
| 1 | 1 | Underflow                     |

# Trap conditions : standard

Examples :

| FDV | EPDL26                |
|-----|-----------------------|
| FDV | ₩ EPDC26              |
| FDV | a EPDL27              |
| FDV | a⊭EPDC27,×            |
| FDV | <sup>a</sup> EPDL27,× |

**FDV** 

Optional

#### VII-10. BYTE STRING PROCESSING

Byte or character string operations are performed by three instructions :

| M∨S | Mo∨e byte String      |
|-----|-----------------------|
| CPS | ComPare byte String   |
| TRS | TRanslate byte String |

NAME : MoVe byte String

Non-priviledged

#### Instruction format :

| , | Addres | SS |   |   |   |   |   |   |   | D  | isplac | ement |    |    |    |
|---|--------|----|---|---|---|---|---|---|---|----|--------|-------|----|----|----|
|   |        |    | 1 | 1 | 1 | 1 | 1 |   |   |    |        |       |    |    |    |
| 0 | 1      | 2  | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11     | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | ١F               | 3 + 3,3 n           |
| DG              | 5F               | 3 + 3,3 n           |
| IL              | 7 F              | 4 + 3, 3 n          |
| IGX             | 9F               | 4 + 3,3 n           |
| ILX             | AF               | 4 + 3,3 n           |

n = number fo shift steps

Function : For  $\alpha$  varying on a byte basis from (E) - 1 to 0, ((G) + (A) +  $\alpha$ )  $\longrightarrow$  (Y +  $\alpha$ ) When transfer is over -1  $\longrightarrow$  E

A byte string beginning at an address defined with respect to G-base by the contents of A-register and whose length (in bytes) is specified in E-register, is stored in core memory starting from Y-address.

When the transfer is over, E-register contents is -1 and A-register contents is unmodified.

Modified elements :

- Registers : E

- Memory locations : (Y) to (Y + (E) - 1)

Trap conditions : standard and non-implemented instruction

Miscellaneous : This instruction is interruptible between each byte transfer

<u>Examples</u>:

| M∨S | EPDL4     |
|-----|-----------|
| M∨S | ₩ EPDC4   |
| M∨S | a EPDL3   |
| M∨S | a⊭EPDC3,× |
| M∨S | a EPDL3,× |



Optional

#### NAME : ComPare byte String

Non-priviledged

Optional

CPS

Instruction format :

| Address |   |   |   |       |      |      |     |     | C           | )<br>isplace | ment        |       |      |          |
|---------|---|---|---|-------|------|------|-----|-----|-------------|--------------|-------------|-------|------|----------|
|         |   | 0 | 1 | 0     | 1    | 0    |     |     |             |              |             |       |      |          |
| 0 1     | 2 | 3 | 4 | 5     | 6    | 7    | 8   | 9   | 10          | 11           | 12          | 13    | 14   | 15       |
|         |   |   | A | ddres | sing | mode | He> | ade | cimal       | code         | Ex          | ecuti | on t | ime (µs) |
|         |   |   |   | DL    |      |      | 0A  |     |             | 4,2 + 3,4 n  |             |       |      |          |
|         |   |   |   | Ρ     |      |      | 2A  |     |             | 4,6 + 3,4 n  |             |       | ,4 n |          |
|         |   |   |   |       | DG   |      | 4A  |     |             |              | 4,2 + 3,4 n |       |      | ,4 n     |
|         |   |   |   | IL    |      |      | 6A  |     |             | 5,2 + 3,4 n  |             |       | ,4 n |          |
|         |   |   |   | IGX   |      | 8A   |     |     | 5,2 + 3,4 n |              |             | ,4 n  |      |          |
|         |   |   |   |       | ILX  |      |     | A   | 4           |              |             | 5,2   | + 3  | ,4 n     |
|         |   |   | L |       |      |      | 1   |     |             |              |             |       |      |          |

n = number of comparaison made

<u>Function</u>: For  $\alpha$  varying on a byte basis from 0 to (E) - 1, y = ((G) + (A) +  $\alpha$ )

Upon execution :

- if found : A = address of reference byte within the string
- if not found : A = address of first non-processed byte

A byte y read at Y-address in core memory is sequentially compared to every byte of a string beginning at an address defined with respect to G-base by the contents of A-register and whose length is specified in E-register.

Upon execution :

If the reference byte is found in the string, its address with respect to G-base is in A-register and E-register contains the unprocessed string length.

If the reference byte y is not found in the string, A-register contains the starting address with respect to G-base and E-register final contents is zero.

CPS

CPS

Modified elements :

- Registers : E - A

- Indicators : C-O

Indicators :

CPS

CPS

| с | 0 | Upon execution     |
|---|---|--------------------|
| 0 | 0 | Character found    |
| 0 | 1 | Character no found |

|            |        | -implemented instruction interruptible between b |                                        |
|------------|--------|--------------------------------------------------|----------------------------------------|
| Examples : |        |                                                  | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |
| CPS        | EPDL18 | CPS                                              | a EPDL19                               |

=&6C

*#* EPDC18

 $a \neq EPDC19, x$ 

a EPDL19,×

# NAME : TRanslatable byte String

Class : 0'

Non-priviledged

Optional

TRS

Instruction format :

| A | Addres | S |   |   |   |   |          |   |   | D  | isplac | ement |    |    |    |
|---|--------|---|---|---|---|---|----------|---|---|----|--------|-------|----|----|----|
|   |        |   | 1 | 1 | 1 | 1 | 0        |   |   |    |        |       |    |    |    |
|   |        |   |   |   |   | A | <u> </u> |   |   |    |        |       |    |    |    |
| 0 | 1      | 2 | 3 | 4 | 5 | 6 | 7        | 8 | 9 | 10 | 11     | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| DL              | 1 E              | 4,5 + 2,75 n        |
| DG              | 5E               | 4,5 + 2,75 n        |
| IL              | 7E               | 5,5 + 2,75 n        |
| IGX             | 9E               | 5,5 + 2,75 n        |
| ILX             | BE               | 5,5 + 2,75 n        |

n : number of bytes to be translated

Function :For 
$$\alpha$$
 varying on a byte basis from 0 to (E) - 1 $(Y + ((A) + (G) + \alpha)_e) \longrightarrow ((A) + (G) + \alpha)$ When transfer is over, 0  $\longrightarrow$  (E)

Given : an origin code O and a result code R, as well as a 256 consecutive byte translation table starting at Y-calculated address and organized as follow :

| Table relative beginning<br>address hexadecimal) | Contents                                             |
|--------------------------------------------------|------------------------------------------------------|
| 00                                               | Value of R-code corresponding to 00 value in O-code. |
| 01                                               | Value of R-code corresponding to 01 value in O-code. |
| 02                                               | Value of R-code corresponding to 02 value in O-code. |
| ÷                                                |                                                      |
| FF                                               | Value of R-code corresponding to FF value in O-code. |

A string beginning at an address defined with respect to G-base by the contents of A-register and whose length is specified in E-register is translated byte per byte through the translation table by TRS instruction.

Starting from Y calculated address, the origin string is overwritten byte per byte by the result string.

Translation table creation is obviously the user's responsibility.

#### Modified elements :

- Registers : A (if initial  $E \neq 0$ ) - E - Memory locations : ((A)) to ((A) + (E) - 1)

Trap conditions : standard and non-implemented instruction

# VII-11. BRANCH INSTRUCTIONS

These instructions normally provide for interrupting the sequential instruction execution in a program segment.

They include :

| BRU | BRanch Unconditional            |
|-----|---------------------------------|
| BRX | BRanch with indeX               |
| BCT | Branch on Carry True            |
| BOT | Branch on Overflow True         |
| BCF | Branch on Carry False           |
| BOF | Branch on Overflow False        |
| BAZ | Branch on A Zero                |
| BAN | Branch on A Negative            |
| BE  | Branch on Equel to              |
| BZ  | Branch on Zero                  |
| BL  | Branch on Less than             |
| BLZ | Branch on Less than Zero        |
| BNE | Branch on Not Equal to          |
| BNZ | Branch on Not Zero              |
| BGE | Branch on Greater than or Equal |
| BPZ | Branch on Positive or Zero      |
|     |                                 |

#### Remark 1 :

An indicator is "true" when set and "false" when reset.

#### Remark 2 :

If P-register contents is even, the executed instruction is located at (P) absolute address.

If P-register contents is odd, the executed instruction is located at (P) - 1 absolute address.

Remark 3 :

Several conditional branches correspond to the same basic instruction. These additional mnemonics (not recognized by MITRAS I) are provided for easier program writing when used after a load or compare instruction.

to

| Basic instruction | Mnemonics for use after loading | Mnemonics for use after comparison |
|-------------------|---------------------------------|------------------------------------|
| ВСТ               | BZ                              | BE                                 |
| BOT               | BLZ                             | BL                                 |
| BCF               | BNZ                             | BNE                                |
| BOF               | BPZ                             | BGE                                |

#### NAME : BRanch Unconditional

Non-priviledged

Standard

BRU

Instruction format :

|   |   |   | Addr | ess |   |   |   |   |   | D  | isplace | ement |    |    |    |
|---|---|---|------|-----|---|---|---|---|---|----|---------|-------|----|----|----|
| 1 | 1 | 0 |      |     | 1 | 1 | 1 |   |   |    |         |       |    |    |    |
| 0 | 1 | 2 | 3    | 4   | 5 | 6 | 7 | 8 | 9 | 10 | 11      | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (ys) |
|-----------------|------------------|---------------------|
| RP              | C7               | 1,8                 |
| RM              | CF               | 1,8                 |
| IL              | D7               | 3                   |
| IG              | DF               | 3                   |

<u>Function</u> :  $Y \rightarrow (P)$ 

Y-address is loaded into P-register and execution proceeds at Y-address.

Modified elements :

- Registers : P

Trap conditions : standard

|       | BR U | <sup>a</sup> EPDL14       |       |
|-------|------|---------------------------|-------|
| EPPL2 | BRU  | EPPL3+1                   |       |
| EPPL3 | BRU  | a⊭ EPDC13                 |       |
|       | BR U | EPPL3-1 Equivalent to BRU | EPPL2 |
|       | BR U | \$                        |       |

NAME : BRanch indeXed

Class : 2

Non-priviledged

2,1

2,1

3,2

3,2

Standard

BRX

Instruction format :

| - |   |   |   |      |     |      |       |      |    |      |       |         |       |      |       |        |      |
|---|---|---|---|------|-----|------|-------|------|----|------|-------|---------|-------|------|-------|--------|------|
|   |   | _ |   | Addr | ess |      |       |      |    |      | C     | isplace | ement |      |       |        |      |
|   | 1 | 1 | 0 |      |     | 0    | 0     | 1    |    |      |       |         |       |      |       |        |      |
|   | 0 | 1 | 2 | 3    | 4   | 5    | 6     | 7    | 8  | 9    | 10    | 11      | 12    | 13   | 14    | 15     |      |
|   |   |   |   |      | Ad  | dres | ssing | mode | He | xade | cimal | code    | E>    | ecut | ion t | ime (, | ــــ |
|   |   |   |   |      |     |      |       |      |    |      |       |         | 1     |      |       |        |      |

C1

C9

DI

D9

| Function : | RP | : | (P) + 2 De + 2 (X) | · (P) |
|------------|----|---|--------------------|-------|
|            |    |   |                    |       |

RM : (P) - 2 De - 2 (X)  $\longrightarrow$  (P) |L : (De + (L) + (X)) + G'  $\longrightarrow$  (P)

$$IG : (De + (G) + (X)) + G' \longrightarrow (P)$$

RΡ

RM

IL

IG

Y calculated address is loaded into P-register and execution proceeds at Y-address. In indirect addressing, the index is used for a pre-indexing executed prior to indirect addressing.

Y-address is calculated according to the above formulae.

Remark :

BRX may be used with relative plus or minus addressing modes, but its most frequent application is based on indirect addressing to provide multiple branch capability through an address table.

Modified elements :

- Registers : P

Trap conditions : standard

| EPPLO | BRX | EPPL1    | (for X = 2, branch at EPPL3)    |
|-------|-----|----------|---------------------------------|
| EPPL1 | BRX | EPPL3    | (for $X = 1$ , branch at EPPL4) |
| EPPL2 | BRX | EPPL3    | (for $X = 0$ , branch at EPPL3) |
| EPPL3 | BRX | EPPL2    | (for X = 1, branch at EPPL1)    |
| EPPL4 | BRX | EPPL2    | (for $X = 2$ , branch at EPPLO) |
|       | BRX | ର EPDL15 | (for $X = 0$ , branch at EPPL1) |
|       | BRX | a⊭epdc15 | (for X = 2, branch at EPPL2)    |
|       | BRX | ର EPDL15 | (for $X = 4$ , branch at EPPL3) |
|       | BRX | a≠EPDC15 | (for $X = 6$ , branch at EPPL4) |

| NAME : Branch on    | CITUE           |                  |                     | BCT     |
|---------------------|-----------------|------------------|---------------------|---------|
| Class : 2           |                 | N on-priviled    | ged                 | Standar |
| nstruction format : |                 |                  |                     |         |
| Addre               | ess             | Displacen        | nent                |         |
| 1 1 0               | 0 0 0           |                  |                     |         |
| 0 1 2 3             | 4 5 6 7         | 8 9 10 11        | 12 13 14 15         |         |
|                     |                 |                  |                     | 1       |
|                     | Addressing mode | Hexadecimal code | Execution time (µs) | ļ       |
|                     | RP              | C0               | 2,1 1,9             |         |
|                     | RM              | C8               | 2,1 1,9             |         |
|                     | IL              | D0               | 3,3 1,9             |         |
|                     | IG              | D8               | 3,3 1,9             |         |

 $\frac{\text{Function}}{\text{If } C = 1} \implies Y \longrightarrow (P)$ If C = 0  $\implies (P) + 2 \longrightarrow (P)$ 

If Carry indicator is set (1), Y calculated address in loaded into P-register and execution continues at Y-address.

If Carry indicator is reset (0), execution proceeds in sequence.

Modified elements :

- Registers : P

Indicators :

| с | 0 | Function according to initial value |
|---|---|-------------------------------------|
| 0 |   | Continue in sequence                |
| 1 |   | Branch                              |

#### Trap conditions : standard

|       | BCT | a⊭ EPDC14           |                        |
|-------|-----|---------------------|------------------------|
| EPPL2 | BCT | \$ +1               |                        |
| EPPL3 | BCT | EPPL3+1             | Equivalent to BCT \$+1 |
|       | BCT | <sup>⊕</sup> EPDL13 |                        |

# NAME : Branch on O True

Non-priviledged

Standard

BOT

Instruction format :

| Addressing mode | Hexadecimal code | Executio | n time (µs) | F                   |
|-----------------|------------------|----------|-------------|---------------------|
| RP              | C2               | 2,1      | 1,9         |                     |
| RM              | СА               | 2,1      | 1,9         |                     |
| IL              | D2               | 3,3      | 1,9         |                     |
| IG              | DA               | 3,3      | 1,9         |                     |
|                 |                  |          | LIf conti   | inue in seque<br>ch |

$$\frac{\text{Function}}{\text{If } O = 1} \xrightarrow{\text{Y}} Y \xrightarrow{\text{(P)}} (P)$$

$$\text{If } O = 0 \xrightarrow{\text{(P)}} (P) + 2 \xrightarrow{\text{(P)}} (P)$$

If Overflow indicator is set (1), Y calculated address is loaded into P-register and execution continues at Y-address.

If Overflow indicator is reset (0), execution proceeds in sequence.

#### Indicators :

| С | 0 | Function according to initial value |
|---|---|-------------------------------------|
|   | 0 | Continue in sequence                |
|   | 1 | Branch                              |

#### Trap conditions : standard

| Examples : |     |            |
|------------|-----|------------|
| EPPL4      | BOT | EPPL1      |
| EPPL1      | BOT | a # EPDC14 |
| EPPL3      | BOT | aepdl13    |
| EPPL2      | BOT | EPPL4      |

# NAME : Branch on C False

Instruction format :



 $\frac{\text{Function}}{\text{If } C = 0} \implies Y \longrightarrow (P)$   $\text{If } C = 1 \implies (P) + 2 \longrightarrow (P)$ 

If Carry indicator is reset (0), Y calculated address is loaded into P-register and execution continues at Y-address.

If Carry indicator is set (1), execution proceeds in sequence.

Modified elements :

- Registers : P

Indicators :

| С | 0 | Function according to initial value |
|---|---|-------------------------------------|
| 0 |   | Branch                              |
| 1 |   | Continue in sequence                |

#### Trap conditions : standard

| Examples : |     |          |
|------------|-----|----------|
| EPPL4      | BCF | EPPL1    |
| EPPL3      | BCF | EPPL4    |
| ëPPL2      | BCF | ର EPDL14 |
| EPPL1      | BCF | a#EPDC13 |

Class : 2

1

0

Non-priviledged

| 4057 U<br>NAME : Branch or |                 |                                       |                     | BOF                        |
|----------------------------|-----------------|---------------------------------------|---------------------|----------------------------|
| NAME : Branch or           | 1 O False       |                                       |                     | BOF                        |
| Class : 2                  |                 | Non-priviled                          | ged                 | Standard                   |
| Instruction format :       |                 |                                       |                     |                            |
| Addr                       | ess             | Displacem                             | nent                |                            |
| 1 1 0                      | 1 1 0           |                                       |                     |                            |
| 0 1 2 3                    | 4 5 6 7         | 8 9 10 11                             | 12 13 14 15         |                            |
|                            | :<br>•          | • • • • • • • • • • • • • • • • • • • |                     | 7                          |
|                            | Addressing mode | Hexadecimal code                      | Execution time (µs) |                            |
|                            | R P             | C6                                    | 2,1 1,9             |                            |
|                            | RM              | CE                                    | 2,1 1,9             |                            |
|                            | IL              | D6                                    | 3,3 1,9             |                            |
|                            | IG              | DE                                    | 3,3 1,9             |                            |
|                            |                 |                                       |                     | ntinue in sequence<br>Inch |

If Overflow indicator is reset (0), Y calculated address is loaded into P-register and execution continues at Y-address.

If Overflow indicator is set (1), execution proceeds in sequence.

#### Modified elements :

- Registers : P

Indicators :

| с | 0 | Function according to initial value |
|---|---|-------------------------------------|
|   | 0 | Branch                              |
|   | 1 | Continue in sequence                |

| Trap conditions : | standard |                                                               |       |
|-------------------|----------|---------------------------------------------------------------|-------|
| Examples :        |          |                                                               |       |
| EPPL1             | BOF      | EPPL2+2                                                       |       |
| EPPL2             | BOF      | aEPDL14                                                       |       |
| EPPL3             | BOF      | a⊭ EPDC13                                                     |       |
|                   | BOF      | EPPL2-1 <table-cell-rows> Equivalent to BOF</table-cell-rows> | EPPLI |

| Addressing mode | Hexadecimal code | Executio | n time (µs) |
|-----------------|------------------|----------|-------------|
| RP              | C5               | 2,4      | 2,2         |
| RM              | CD               | 2,4      | 2,2         |
| IL              | D5               | 3,5      | 2,2         |
| IG              | DD               | 3,5      | 2,2         |

 $\frac{\text{Function}}{\text{If } (A) = 0} \implies Y \longrightarrow (P)$  $\text{If } (A) \neq 0 \implies (P) + 2 \longrightarrow (P)$ 

If A-register contents is zero, Y calculated address is loaded into P-register and execution continues at Y-address.

If A-register contents is not zero, execution proceeds in sequence.

Modified elements :

- Registers : P

Trap conditions : standard

Examples :

| EPPL2 | BAZ | a⊭ EPDC14    |
|-------|-----|--------------|
|       | BAZ | <b>\$ +2</b> |
| EPPL2 | BAZ | \$ -1        |
|       | BAZ | aEPDL13      |

0

1

2

| <u>4057 U</u>               |                                      |
|-----------------------------|--------------------------------------|
| NAME : Branch on A Negative |                                      |
| Class : 2                   | Non-priviledged                      |
| Instruction format :        |                                      |
| Address                     | Displacement                         |
| 1,1,0,1,0,0                 |                                      |
| 0 1 2 3 4 5 6 7 8           | B 9 10 11 12 13 14 15                |
| F                           |                                      |
| Addressing mode             | Hexadecimal code Execution time (µs) |

C4

сс

D4

DC

| Function : | If (A) < 0 $\longrightarrow$ Y $\longrightarrow$ (P)        |
|------------|-------------------------------------------------------------|
| <u></u>    | If (A) $\geq 0 \longrightarrow (P) + 2 \longrightarrow (P)$ |

If A-register contents is negative, Y calculated address is loaded into P-register and execution continues at Y-address.

2,2

2,2

2,2

2,2

\_If branch

LIF continue in sequence

2,4

2,4

3,5

3,5

If A-register contents is zero or positive, execution proceeds in sequence.

RP

RM

IL

IG

Modified elements :

- Registers : P

<u>Trap conditions</u> : standard

Examples :

| EPPL1 | BAN | \$+2     |
|-------|-----|----------|
| EPPL3 | BAN | EPPLI    |
|       | BAN | a EPDL13 |
| EPPL2 | BAN | a⊭epdc14 |

BAN

Standard

|   |   |   | Add | ress |   |   |   |   |   | ۵  | )isplac | ement |
|---|---|---|-----|------|---|---|---|---|---|----|---------|-------|
| 1 | 1 | 0 |     |      | 0 | 0 | 0 |   |   |    |         |       |
| 0 | 1 | 2 | 3   | 4    | 5 | 6 | 7 | 8 | 9 | 10 | 11      | 12    |

| Addressing mode | Hexadecimal code | Executio | n time (µs) |
|-----------------|------------------|----------|-------------|
| RP              | C0               | 2,1      | 1,9         |
| RM              | C8               | 2,1      | 1,9         |
| IL.             | D0               | 3,3      | 1,9         |
| IG              | D8               | 3,3      | 1,9         |
|                 |                  |          | If cont     |

 $\frac{\text{Function}}{\text{If Carry}} : \begin{array}{c} \text{If Carry} = 1 \implies Y & \longrightarrow & (P) \\ \text{If Carry} = 0 & \implies (P) + 2 & \longrightarrow & (P) \end{array}$ 

Normally, this instruction is preceded by a comparison.

If the first term of the comparison was equal to the second, Y calculated address is loaded into P-register and execution continue at Y-address.

If the first term of the comparison was different from the second, execution proceeds in sequence.

### Modified elements :

- Registers : P

Indicators :

| с | 0 | Function according to initial value |
|---|---|-------------------------------------|
| 0 |   | Continue in sequence                |
| 1 |   | Branch                              |

Trap conditions : standard

Miscellaneous : This instruction is equivalent to a BCT

| BE | EPPL4    |
|----|----------|
| BE | a⊭EPDC13 |
| BE | a EPDL14 |
| BE | EPPL1    |
|    | BE<br>BE |

NAME : Branch if Zero

Non-priviledged

Standard

BZ

Instruction format :

|   |   |    | Ad | dress |       |      |      |    |      |       | Displace | men | t     |       |         |
|---|---|----|----|-------|-------|------|------|----|------|-------|----------|-----|-------|-------|---------|
| 1 | 1 | _0 |    |       | 0     | 0    | 0    |    |      |       |          |     |       |       |         |
| 0 | 1 | 2  | 3  | 4     | 5     | 6    | 7    | 8  | 9    | 10    | 11       | 12  | 13    | 14    | 15      |
|   |   |    |    | Ad    | ddres | sing | mode | He | exad | ecima | l code   | E   | xecut | ion 1 | time (µ |
|   |   |    |    |       |       | RP   |      |    | C    | 20    |          |     | 2,1   |       | 1,9     |
|   |   |    |    |       | RM    |      |      | С8 |      |       |          |     | 2,1   |       | 1,9     |
|   |   |    |    |       | IL    |      |      |    | [    | 00    |          |     | 3,3   |       | 1,9     |
|   |   |    |    |       |       | IG   |      |    | [    | 28    |          |     | 3,3   |       | 1,9     |
|   |   |    |    |       |       |      |      |    |      |       |          |     |       |       | Lif c   |

 $\frac{\text{Function}}{\text{If Carry}} : \begin{array}{c} \text{If Carry} = 1 \\ \text{If Carry} = 0 \end{array} \xrightarrow{(P)} (P) + 2 \\ \text{(P)} \end{array}$ 

This instruction is normally preceded by a load instruction.

If the previously stored value is zero, Y calculated address is loaded into P-register and execution continues at Y-address.

If the previously stored value is different from zero, execution proceeds in sequence.

### Modified elements :

- Registers : P

Indicators :

| С | 0 | Function according to initial value |
|---|---|-------------------------------------|
| 0 |   | Continue in sequence                |
| 1 |   | Branch                              |

<u>Trap conditions</u> : standard

Miscellaneous : This instruction is equivalent to a BCT

| EPPL4 | BZ | a EPDL14 |
|-------|----|----------|
| EPPL2 | BZ | EPPL1    |
| EPPL3 | BZ | a≠EPDC13 |
| EPPLI | BZ | EPPL4    |

# NAME : Branch if Less

#### Class : 2

Non-priviledged

Standard

sequence

BL

Instruction format :

| Addressing mode | Hexadecimal code | Executio | on time (us) |
|-----------------|------------------|----------|--------------|
| RP              | C2               | 2,1      | 1,9          |
| RM              | CA               | 2,1      | 1,9          |
| IL              | D2               | 3,3      | 1,9          |
| IG              | DA               | 3,3      | 1,9          |

 $\frac{\text{Function}}{\text{If Overflow}} : \text{ If Overflow} = 1 \implies Y \longrightarrow P$ If Overflow = 0  $\implies$  (P) + 2  $\longrightarrow$  (P)

Normally, this instruction is preceded by a comparison.

If the first term of the comparison was less than the second, Y calculated address is loaded into P-register and execution continues at Y-address.

If the first term of the comparison was equal to or greater than the second, execution proceeds in sequence.

### Modified elements :

- Registers : P

Indicators :

| с | 0 | Function according to initial value |
|---|---|-------------------------------------|
|   | 0 | Continue in sequence                |
|   | 1 | Branch                              |

Trap conditions : standard

Miscellaneous : This instruction is equivalent to a BOT

| EPPL4 | BL | @EPDL14   |
|-------|----|-----------|
| EPPL2 | BL | EPPLI     |
| EPPL3 | BL | ₽# EPDC13 |
| EPPL1 | BL | EPPL4     |

# NAME : Branch if Less Zero

Class : 2

Non-priviledged

Standard

Instruction format :



FunctionIf Overflow = 1 
$$\implies$$
 Y  $\longrightarrow$  (P)If Overflow = 0  $\implies$  (P) + 2  $\longrightarrow$  (P)

This instruction is normally preceded by a load instruction.

If the previously stored value was less than zero, Y calculated address is loaded into P-register and execution at Y-address.

If the previously stored value was equal to or greater than zero, execution proceeds in sequence.

### Modified elements :

- Registers : P

Indicators :

| с | 0 | Function according to initial value |
|---|---|-------------------------------------|
|   | 0 | Continue in sequence                |
|   | 1 | Branch                              |

Trap conditions : standard

Miscellaneous : This instruction is equivalent to a BOT

| EPPLO | BLZ | a# EPDC14                  |       |
|-------|-----|----------------------------|-------|
| EPPL2 | BLZ | EPPL1                      |       |
| EPPL3 | BLZ | a EPDL13                   |       |
| EPPL1 | BLZ | \$–3 🛛 — Equivalent to BLZ | EPPLO |

| 4057 | U |  |  |
|------|---|--|--|
|      |   |  |  |

#### NAME : Branch if Not Equal

BNE

#### Class : 2

Non-priviledged

Standard

Instruction format :

|   | Address |   |   |          |      |       |      | D        | isplacer | ment  |      |    |       |            |                              |     |
|---|---------|---|---|----------|------|-------|------|----------|----------|-------|------|----|-------|------------|------------------------------|-----|
| 1 | 1       | 0 |   |          | 0    | 1     | 1    |          |          |       |      |    |       |            |                              |     |
| 0 | 1       | 2 | 3 | 4        | 5    | 6     | 7    | 8        | 9        | 10    | 11   | 12 | 13    | 14 15      |                              |     |
|   |         |   |   | Ad       | ddre | ssing | mode | He       | xade     | cimal | code | E× | ecuti | on time (µ | us)                          |     |
|   |         |   |   |          |      | RP    |      |          | C        | 3     |      |    | 2,1   | 1,9        |                              |     |
|   |         |   |   |          |      | RM    |      |          | CI       | В     |      |    | 2,1   | 1,9        |                              |     |
|   |         |   |   |          |      | ۱L    |      |          | D3       | 3     |      |    | 3,3   | 1,9        |                              |     |
|   |         |   |   |          |      | IG    |      |          | D        | В     |      |    | 3,3   | 1,9        |                              |     |
|   |         |   |   | <b>*</b> |      |       |      | <u>.</u> |          |       |      |    |       |            | continue in sequer<br>branch | nce |

Function:If Carry = 0  $\implies$  Y  $\longrightarrow$  (P)If Carry = 1  $\implies$  (P) + 2  $\longrightarrow$  (P)

Normally, this instruction is preceded by a comparison.

If the first term of the comparison was different from the second, Y calculated address is loaded into P-register and execution continues at Y-address.

If the first term of the comparison was equal to the second, execution proceeds in sequence.

#### Modified elements :

- Registers : P

Indicators :

| С | 0 | Function according to initial value |
|---|---|-------------------------------------|
| 0 |   | Branch                              |
| 1 |   | Continue in sequence                |

Trap conditions : standard

Miscellaneous : This instruction is equivalent to a BCF

|       | BNE | \$ +1    |
|-------|-----|----------|
|       | BNE | a EPDL13 |
| EPPL2 | BNE | a⊭EPDC14 |
| EPPL3 | BNE | \$-3     |

#### 4057 U NAME : Branch if Not Zero BNZ Class : 2 Standard Non-priviledged Instruction format : Displacement Address 0 1 1 0 1 1 2 7 0 1 3 4 5 6 8 9 10 11 12 13 14 15 Execution time (us) Addressing mode Hexadecimal code RP C3 2,1 1,9 RM СВ 2,1 1,9 3,3 1,9 1L D3 IG DB 3,3 1,9 If continue in sequence If branch

Function :If Carry = 0  $\implies$  Y  $\longrightarrow$  (P)If Carry = 1  $\implies$  (P) + 2  $\longrightarrow$  (P)

This instruction is normally preceded by a load instruction.

If the previously stored value was different from zero, Y calculated address is loaded into P-register and execution continues at Y-address.

If the previously stored value was equal to zero, execution proceeds in sequence.

### Modified elements :

- Registers : P

Indicators :

| с | 0 | Function according to initial value |
|---|---|-------------------------------------|
| 0 |   | Branch                              |
| 1 |   | Continue in sequence                |

Trap conditions : standard

Miscellaneous : This instruction is equivalent to a BCF

| EPPL3 | BNZ | EPPL1     |
|-------|-----|-----------|
| EPPL4 | BNZ | aEPDL13   |
| EPPL2 | BNZ | ब⊭ SPDC14 |
| EPPL1 | BNZ | EPPL4     |

### NAME : Branch if Greater or Equal

Class : 2

Non-priviledged

Standard

BGE

Instruction format :



Normally, this instruction is preceded by a comparison.

If the first term of the comparison was greater than or equal to the second, Y calculated address is loaded into P-register and execution continue at Y-address.

If the first term of the comparison was less than the second, execution proceeds in sequence.

### Modified elements :

- Registers : P

Indicators :

| 0 | Function according to initial value |
|---|-------------------------------------|
| 0 | Branch                              |
| 1 | Continue in sequence                |

Trap conditions : standard

Miscellaneous : This instruction is equivalent to a BOF

| EPPL4 | BGE | EPPL1     |
|-------|-----|-----------|
| EPPL1 | BGE | aEPDL13   |
| EPPL2 | BGE | a⊭ EPDC14 |
| EPPL3 | BGE | EPPL4     |

## NAME : Branch if Positive or Zero

Class : 2

Non-priviledged

Standard

**BPZ** 

Instruction format :



 $\frac{\text{Function}}{\text{If Overflow}} : \text{ If Overflow} = 0 \implies Y \longrightarrow (P)$ If Overflow = 1  $\implies (P) + 2 \longrightarrow (P)$ 

This instruction is normally preceded by a load instruction.

If the previously stored value was greater than or equal to zero, Y calculated address is loaded into P-register and execution continues at Y-address.

If the previously stored value was less than zero, execution proceeds in sequence.

### Modified elements :

- Registers : P

Indicators :

| 0 | Function according to initial value |
|---|-------------------------------------|
| 0 | Branch                              |
| 1 | Continue in sequence                |

Trap conditions : standard

Miscellaneous : This instruction is equivalent to a BOF

| EPPL2 | BPZ | a EPDL14                 |       |
|-------|-----|--------------------------|-------|
| EPPL3 | BPZ | \$ +2                    |       |
|       | BPZ | a⊭EPDC13                 |       |
|       | BPZ | \$-2 → Equivalent to BRU | EPPL3 |
|       |     |                          |       |

# VII-12. SYSTEM COMMUNICATION INSTRUCTIONS

These instructions perform sophisticated call and communication operations between system constituents : program modules, monitor modules, interrupt subroutines.

They include :

| CLS  | CalL Section                     |
|------|----------------------------------|
| RTS  | ReTurn Section                   |
| CSV  | Call SuperVisor                  |
| DIT  | De-activate InTerrupt            |
| DITR | De-activate high-speed InteRrupt |

# NAME : Call Section

Class : 1

Non-priviledged

CLS

Standard

In master mode In slave mode

Instruction format :

|   | Addr | ess |   |   |   |   |   |   |   | Di | splace | ement |    |    |    |  |
|---|------|-----|---|---|---|---|---|---|---|----|--------|-------|----|----|----|--|
|   |      |     |   | 1 | 0 | 0 | 0 |   |   |    |        |       |    |    |    |  |
| 0 | 1    | 2   | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11     | 12    | 13 | 14 | 15 |  |

| Addressing mode | Hexadecimal code | Executio | n time (µs) |
|-----------------|------------------|----------|-------------|
| DL              | 38               | 8,3      | 7,9         |
| PX              | E8               | 8,3      | 7,9         |
| Р               | F8               | 8,3      | 7,9         |
|                 |                  |          |             |

 Function :
  $(P) - G' \longrightarrow (((G) - 4 N) + (G))$ 
 $(L) - G' \longrightarrow (((G) - 4 N) + (G) + 2)$ 
 $(G) + ((G) - 4 N) \longrightarrow (L)$ 
 $(G) + ((G) - 4 N + 2) \longrightarrow (P)$ 

where N is the calculated operand, i.e.  $(Y_2)$ 

N ≠ 0

### Note

As discussed before, a program is made up of a number of sections individually characterized by a local base L and a program base P. These characteristic values are entered in the program's PRT (one SRD per section).

### Purpose of the CLS

A CLS is basically a branch instruction providing connection between a given section ("calling") and another section ("called") of the same program, while ensuring permanent communications between the two sections as well as an easy return means.

## Involved elements

- Program's PRT
- First two words of the calling section's LDS

- Contents of CLS calculated address which contains the called section number. (Note that Assemblers and Compilers which operate with a Linkage Editor offer the convenient possibility of calling a section by its name; thus, the actual number of the section may be unknown to the programmer).

# Operation of the CLS

- L- and P-base values, relative to G, of the calling section are stored in the first two words of the called section's LDS.

- With the section number, L- and P-base values of the called section are fetched and stored in the corresponding registers.

- A branch is made at the called section.

# Communication with the calling section

Three methods are available for transferring the parameters between calling and called sections :

- 1) Through the Common Data Section (CDS)
- 2) In indirect local (IL) or indirect local indexed (ILX) addressing modes, via the second word of the LDS.

3) Via A, E, X-registers and/or C-O indicators.

Operation flow chart

- i = called section no.
- i = calling section no.



# Modified elements :

- Registers : L - P

- Memory locations : first two words of called section's LDS.

## Trap conditions : standard

Miscellaneous : The CLS operating with elements of the called section is not re-entrant. It may be used both in Master mode and Slave mode.

| CLS    | LPS1 |
|--------|------|
| CLS    | =2   |
| CLS    | =2,× |
| ∨11-92 |      |

#### RTS NAME : ReTurn Section Class : 1 Standard Non-priviledged Instruction format : Address Instruction type 1 1 0 · 0 0 1 1 1 0 0 0 0 2 3 7 0 1 4 5 6 11 12 13 8 9 10 14 15 Hexadecimal code Execution time (us) Addressing mode Ρ F1 00 4,3 4,7 In master mode In slave mode

Function : ((L)) + G' + 2 --- (P)((L) + 2) + G' → (L)

The RTS placed in a section called by a CLS provides the return to the calling section by restoring in L and P-registers the corresponding values contained in the first two words of the called section's LDS.

The operation of the RTS is illustrated on the CLS diagram.

Modified elements :

- Registers : L - P

Trap conditions : standard

Examples : RTS

NAME : Call SuperVisor

Non-priviledged

Standard

CSV

Instruction format :

| Address |       |       |      | Displacem         | ent                 |
|---------|-------|-------|------|-------------------|---------------------|
|         | 0 1   | 1     | 1    |                   |                     |
| 1 2 3   | 4 5   | 6     | 7    | 8 9 10 <u>1</u> 1 | 12 13 14 15         |
|         | Addre | ssing | mode | Hexadecimal code  | Execution time (µs) |
|         |       | DL    |      | 37                | 9,9                 |
|         |       | ΡX    |      | E7                | 9,9                 |
|         |       | Ρ     |      | F7                | 9,9                 |

 $\frac{\text{Function}: (P) - (G) \longrightarrow ((G))}{(L) - (C) \longrightarrow ((C) + 2)}$ 

$$1 \longrightarrow PR$$

$$1 \longrightarrow MS$$

$$((12) - 4 N) \longrightarrow (L)$$

$$((12) - 4 N + 2) \longrightarrow (P)$$

Where N is the calculated operand, i.e.  $(Y_2)$ 

### Note :

As discussed before, a monitor is made up of a number of sections individually characterized by a local base L and a program base P. These characteristic values are entered in the PRTS (Supervisor's PRT) located anywhere in the memory and pointed at through absolute address 12 (decimal). A monitor operates in Master mode and overrides memory protection.

### Purpose of the CSV

A CSV is basically a branch instruction providing connection between a user program section and a supervisor section, while ensuring the re-entrance of the Supervisor section and an easy return to the user program.

Involved elements

- PRTS (Supervisor's PRT)
- PRTS pointer
- First three words of the calling program's CDS

- Contents of CSV calculated address which contains the called section number. (Note that Assemblers and Compilers which operate with a Linkage Editor offer the convenient possibility of calling a supervisor section by a name M:xxxx; thus, the actual number of the section may be unknown to the programmer).

# Operation of the CSV

- L- and P-base values, relative to G, of the current section, and its indicators are stored in the first three words of the calling program's CDS.

- With the section number, L- and P-base values are fetched.

- MA and PR indicators are forced to 1.

- A branch is made at the called section.

#### Communication with the calling section

These communications are made in indirect general indexed (IGX) addressing mode via the second word of the calling program's CDS.

However, it is still possible to transfer the parameters via A, E and X-registers.

#### **Re-entrance**

For full re-entrance, the supervisor section stores all variable elements it handles in the calling program's CDS (addressing mode : direct general or direct general indexed).

Standard modules use a 16-word TWB for this purpose.

#### Operation flow chart



Modified elements :

- Registers : L-P

- Memory locations : The first three words of the calling's program's CDS, i.e. (G) through (G+5)

- Indicators : MS set PR set

# Trap conditions : standard

<u>Miscellaneous</u> : The program is interruptible between a CSV and the immediately following instruction (for interrupt masking, should it be required).

Priviledged

Examples :

| CSV | M:10 |
|-----|------|
| CSV | =2   |
| CSV | =2,× |

### NAME : Return SuperVisor

Class : 1

Instruction format :

|   |   | Add | ress |   |   |                 |   |   |    |      |       | Instr | ucti               | on typ | е  |           |
|---|---|-----|------|---|---|-----------------|---|---|----|------|-------|-------|--------------------|--------|----|-----------|
|   | 1 | 1   | 1    | 1 | 0 | · 0             | 0 | 1 |    |      |       | 0     | 1                  | 1      | 0  |           |
| • | 0 | 1   | 2    | 3 | 4 | 5               | 6 | 7 | 8  | 9    | 10    | 11    | 12                 | 13     | 14 | 15        |
|   |   |     |      |   | A | Addressing mode |   |   |    | xade | cimal | code  | Execution time (µs |        |    | time (µs) |
|   |   |     |      |   | Р |                 |   |   | F۱ | C0   |       | 6,7   |                    |        |    |           |

 $\frac{\text{Function}: ((G) + 4) \longrightarrow \text{Indicators}}{(G) + ((G) + 2) \longrightarrow (L)}$   $(G) + 2 + ((G)) \longrightarrow (P)$ 

The RSV placed in a monitor section (Master mode) called by a CSV provides the return to the calling section by restoring in L- and P-registers the corresponding values contained in the first two words of the CDS of the program to which the calling section belongs. It also restores the initial status of the indicators.

### Modified elements :

- Registers : L-P

- Indicators : All indicators are restored (to the value they had before the CSV if the G-base has not been changed in the meantime).

Trap conditions : standard and mode violation

Examples : RSV



| <u>4057</u> | U        |      |       |       |       |    |   |   |   |        |      |    | <u> </u> |    |    |   |          |
|-------------|----------|------|-------|-------|-------|----|---|---|---|--------|------|----|----------|----|----|---|----------|
| NAM         | <u> </u> | De-  | -acti | ve In | Terru | pt |   |   |   |        |      |    |          |    |    |   | DIT      |
| Clas        | s :      | 1    |       |       |       |    |   |   | P | rivile | dged |    |          |    |    |   | Standard |
| Instr       |          |      | mat   | :     |       |    |   |   |   |        |      |    |          |    |    |   |          |
|             | Add      | ress |       | T     |       |    |   |   |   |        |      |    |          |    |    | ٦ |          |
| 1           | 1        | 1    | 1     | 0     | , 1   | 0  | 0 |   |   |        |      |    |          | 0  | 1  |   |          |
| 0           | 1        | 2    | 3     | 4     | 5     | 6  | 7 | 8 | 9 | 10     | 11   | 12 | 13       | 14 | 15 |   |          |
|             |          |      |       |       |       |    |   |   |   |        |      |    |          |    |    |   | 7        |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| Р               | F4               | 32,5                |

### Function :

#### Note

As discussed before, the level of a program is the interrupt level at which it may be activated. A program which cannot be activated at any interrupt level is said to be "at zero level".

MITRA 15's interrupt system is based on structure of hierarchized levels.

When an interrupt is received at a higher level than that of the current program, the latter is interrupted otherwise. If the interrupt level is lower than that of the current program the interrupt is placed in waiting state unit! the upper level is de-activated.

#### Purpose of the DIT

Since the acceptance of an interrupt causes a branch to the corresponding subroutine, the function of DIT is to terminate this interrupt subroutine and to return control to the interrupted program.

In this respect, the DIT instruction is an actual system branch.

#### Elements involved

The program context comprises the current contents of X, E, A, G, L, P registers and indicators.

Every interrupt has an associated pointer indicating a memory area in which the context may be saved on occurence of an interrupt at this level. The memory area for saving the context at a given level is actually reserved only if a program is connected to this level. Generally, this area is located immediately after the program storage area.

This area contains the register and indicator values at the last interrupt time (either if a higher level interrupt has been accepted, or if the level has been de-activated). If the program is never interrupted, the saving area contains the initial program contents (at the time its execution is started).

The <u>32 context pointers</u> (indicating the saving area of each level) are stored in increasing level order in the context pointer table (at increasing addresses starting from CPT address).

Saved elements are stored on a one-element-per-word basis at increasing addresses starting from the pointed address in the following order :

- Indicators, X, E, A, G, L, P.

#### Example of interrupt process



#### Operation of the DIT

- P-register incremented by 2
- Current level de-activated
- Context stored from the address which is pointed by the corresponding context pointer
- Acceptance of the highest priority waiting level (R8 updated)

- Context loaded with the contents of the saving area which is pointed at by the new level's pointer (execution is started).

### Acceptance of an interrupt

DIT performs the return branch of the interrupt subroutine which had been call at the time the corresponding interrupt was accepted. This instruction :

- Stores the interrupted level context from the memory address indicated by the associated context pointer.
- Accepts the level of the highest priority interrupt (R8 up-dated)
- Loads the context from the saving area which is pointed at by the new level (execution is started).

#### Interrupt configurations

There are 31 interrupt configurations (obviously zero level needs none). These configurations are used by DIT to know located exactly the interrupt level to be de-activated.

They are stored in ascending level order in DVT table (in descending address order starting from CPT address).





This table may be located anywhere in the memory, the CPT address being in a word whose absolute address is 10 (decimal).

#### Current program level

The current program level is indicated by R8-register which contains the double of this level number.

### Modified elements :

- Registers : A, E, X, P, L, G, R8
- Memory locations : The eight words of the de-activated interrupt context
- Indicators : All

Trap conditions : standard and mode violation

<u>Miscellaneous</u> : Since DIT performs a context swapping, no protection or masking is required. All interrupt subroutine must conclude with a DIT. A DIT is meaningless at level zero (which cannot be de-activated). Examples : DIT

# NAME : De-activate high-speed InTerrupt

Class : 1

Priviledged

Optional

DITR

Instruction format :

| Address |                 |   |   |   |     |      |       |      |                     |     |  |  |
|---------|-----------------|---|---|---|-----|------|-------|------|---------------------|-----|--|--|
|         | 1               | 1 | 0 | 0 |     |      | 1     |      |                     |     |  |  |
| 0 1 2 3 | 4 5 6 7         |   | 8 | 9 | 10  | 11   | 12 13 | 3 14 | 15                  |     |  |  |
|         | Addressing mode |   |   |   | Hex | adec | imal  | code | Execution time (µs) |     |  |  |
|         | PX              |   |   |   |     | EC   | 2     | 0    | 6,1                 |     |  |  |
|         |                 |   | Р |   |     | FC   | 2     | 0    |                     | 6,1 |  |  |

Function :

#### Comparative analysis of normal and high-speed interrupt

- Acceptance of a normal interrupt includes the following operations :
- Context of currently executed level (specified by R8) is saved in core memory.
- Calling level (Na) is accepted and R8 is updated.
- Context elements corresponding to Na are loaded in the registers.

• Acknowledgment of a normal interrupt is performed by the final DIT instruction of the interrupt subroutine and includes the following operations :

- Context of currently processed interrupt is saved in core memory.
- Corresponding level is de-activated.
- Waiting level is accepted and R8 is updated.
- Context elements corresponding to the new level are loaded in the registers.
- Acceptance of the high-speed interrupt includes the following operations :
- Normal interrupts are placed in waiting status until acknowledgment of the high-speed interrupt.
- Current indicators are saved in register 6 of block 0.
- R12 is loaded with the number of the block which is reserved for high-speed interrupt processing.
- Indicators are loaded with the contents of register 6 in the reserved block.
- Acknowledgment of the high-speed interrupt is performed by the final DITR instruction of the interrupt subroutine and includes the following operations :
- Indicators are saved in register 6 of the reserved block.
- R12 is cleared (return to block 0).
- High-speed level is de-activated (normal interrupts are enabled).
- Previous indicators saved in register 6 of block 0 are restored.

4057 U

Modified elements :

- Registers : return to block 0

- Indicators : restored

Trap conditions : standard and mode violation

Examples : DITR

# VII-13. CONTROL INSTRUCTIONS

| TES | TEst and Set           |
|-----|------------------------|
| STM | SeT interrupt Mask     |
| CLM | CLear interrupt Mask   |
| RD  | Read Direct            |
| WD  | Write Direct           |
| LDP | LoaD memory Protection |

#### 4057 U

NAME : TEst and Set

Priviledged

Optional

**TES** 

Instruction format :

| Ado | lress |   |         | Displacement |   |      |                  |   |    |                    |    |    |         |    |
|-----|-------|---|---------|--------------|---|------|------------------|---|----|--------------------|----|----|---------|----|
|     |       |   | 1       | 1            | 0 | 1    |                  |   |    |                    |    |    |         |    |
| 0 1 | 2     | 3 | 4       | 5            | 6 | 7    | 8                | 9 | 10 | 11                 | 12 | 13 | 14      | 15 |
|     |       |   | Address |              |   | mode | Hexadecimal code |   |    | Execution time (µs |    |    | me (µs) |    |
|     |       |   | DL      |              |   |      | 31               | ) |    | 3,6                |    |    |         |    |

$$P \begin{cases} (De)_2 \longrightarrow A \\ 0 \longrightarrow (De)_2 \end{cases}$$

$$PX \begin{cases} (De + (X))_2 \longrightarrow A \\ 0 \longrightarrow (De + (X))_2 \end{cases}$$

$$DL \begin{cases} ((De + (L)))_2 \longrightarrow A \\ 0 \longrightarrow ((De + (L)))_2 \end{cases}$$

PΧ

Ρ

This instruction tests and clears a memory location without being interrupted. Initial value loaded in A. Test result loaded in the indicators. This instruction is used when several processors work in a common memory area, for example to enable a processor to perform an "occupation test" on a table.

ΕD

FD

3,4

3,4

The protection bit is also reset.

Ρ

#### Modified elements :

- Registers : A
- Memory locations : y<sub>2</sub>
- Indicators : C-O

Indicators :

| С | Ö | Upon execution     |
|---|---|--------------------|
| 0 | 0 | y <sub>2</sub> < 0 |
| 0 | 1 | y <sub>2</sub> > 0 |
| 1 | 0 | y <sub>2</sub> = 0 |

Trap conditions : Mode violation

| TES | EPDL28 |
|-----|--------|
| TES | =&3E,× |
| TES | =9     |

# NAME : SeT interrupt Mask

Priviledged

Standard

STM

Instruction format :



| <br>Addressing mode | Hexadecimal code | Execution time (µs) |  |  |  |  |
|---------------------|------------------|---------------------|--|--|--|--|
| Р                   | F4               | 3,4                 |  |  |  |  |

Functions : (N<sub>12</sub>) --- Interrupt mask (MA)

MA-indicator is set.

As a consequence all interrupt levels are masked.

Modified elements :

- Indicators : MA

Trap conditions : standard and mode violation

Examples : STM

# NAME : CLear interrupt Mask

Class : 1

Instruction format :

| Address |  |
|---------|--|
|         |  |

| 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 |   |   |    |    |    |    | 0  | 0  |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |
|-----------------|------------------|---------------------|
| Р               | F4               | 3,4                 |

Priviledged

Function : (N<sub>12</sub>) -- Interrupt mask (MA)

MA-indicator is reset. As a consequence, all interrupt levels are masked.

Modified elements :

- Indicators : MA

Trap conditions : standard and mode violation

Examples : CLM



Standard

Class : 1

NAME : Read Direct

# Instruction format :



Priviledged

Function : The read mode is determined by the contents of E-register



RD is the input instruction and its meaning depends on the addressed controller.

# NAME : Write Direct

Class : 1

Priviledged

| Instruction | format : |
|-------------|----------|
|             |          |

|   | Addr | ess |   |    |                 |   |   |    |                  |    |    |     |                     |    |    |  |
|---|------|-----|---|----|-----------------|---|---|----|------------------|----|----|-----|---------------------|----|----|--|
| 1 | 1    | 1   | 1 | 0  | 1               | 0 | 0 |    |                  |    |    |     |                     | 1  | 1  |  |
| 0 | 1    | 2   | 3 | 4  | 5               | 6 | 7 | 8  | 9                | 10 | 11 | 12  | 13                  | 14 | 15 |  |
|   |      |     |   | Ac | Addressing mode |   |   | He | Hexadecimal code |    |    |     | Execution time (µs) |    |    |  |
|   |      |     |   |    | Р               |   |   |    | F4               |    |    | 3,5 |                     |    |    |  |

Function : The write mode is determined by the contents of E-register.



WD is the output instruction and its meaning depends on the addressed controller.

WD

Standard

RD

NAME : Loa D memory Protection

Class : 1

Priviledged

Optional

LDP

Instruction format :

| _ | Addr | ress |   |   |   |   |   |   |   | D  | isplace | ement |    |    |    |
|---|------|------|---|---|---|---|---|---|---|----|---------|-------|----|----|----|
|   |      |      |   | 1 | 0 | 1 | 1 |   |   |    |         |       |    |    |    |
| 0 | 1    | 2    | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11      | 12    | 13 | 14 | 15 |

| Addressing mode | Hexadecimal code | Execution time (µs) |  |  |  |  |
|-----------------|------------------|---------------------|--|--|--|--|
| DL              | 3B               | 3,1 +1,8 n          |  |  |  |  |
| PX              | EB               | 3,1 + 1,4 n         |  |  |  |  |
| Р               | FB               | 3,1 + 1,4 n         |  |  |  |  |

n = number of words in the string.

 $\frac{\text{Function}}{N_{15}} : \text{For X varying 0 and (E)-1} \\ N_{15} \longrightarrow bp((A) + 2X)$ 

Upon execution E = -1

A = Address of the first non-processed word

LDP loads the protection bit in a word string.

The starting address is in A and the string length is specified in E.

Each protection bit is loaded with the value of bit 15 in the calculated operand (contents of calculated address). The string is protected when this bit is set (1), otherwise, there is no protection.

#### Modified elements :

- Registers : E-A

- Memory locations :  $(y_2)$  to  $(y_2 + (E) - 1)$ 

Trap conditions : standard and mode violation

Miscellaneous : This instruction is interruptible between two words

| LDP | =1     |
|-----|--------|
| LDP | =0     |
| LDP | =0,×   |
| LDP | EPDL21 |

# 8. Input/Output control system

### VIII-1. INPUT/OUTPUT SYSTEM ORGANIZATION

The following sections only describe Input/Output operations under Monitor control.

Though the procedure has a standard aspect and is mainly oriented towards standard peripheral transfers, it will be seen later that it also provides for processing non-standard peripheral transfers and offers the convenient feature of a direct user check on the validity of such transfers.

An Input/Output operation may be divided into five steps :

a) Reservation of a buffer, if required.

- b) Transfer request (resident system call).
- c) Transfer initialization.
- d) Transfer completation.
- e) Transfer end and validity check.

Step a) is and independent supervisor call : reservation of a dynamic data block.

Steps a) and b) are performed by the requesting task (CSV M:10 or M:Z10).

Step c) is performed by the Monitor in response to the M:10 call. Control is returned to the calling program upon transfer initialization.

Steps d) and e) are controlled by the system in full independence from the calling task, and in apparent simultaneity with the currently executed tasks; the calling program may follow the transfer progress, if required (CSV M:WAIT or M:ZWAT).

#### Remark :

If the device is busy at transfer request time, two different processes may be initiated (according to the Monitor).

1) The request is queued and control is returned to the calling task.

From the user's viewpoint, everything goes on as if transfer initialization step c) were actually completed, i.e. he may consider that step d) has begun and may wait for transfer end, if required.

In such a case, step d) combines the delay for waiting for the logical release of the device and the duration of the actual transfer initialization and performance.

Queuing is always possible at or above MTR-level.

2) No queuing of the request; control is returned to the calling task only when the transfer has beep actually initialized.

### VIII-2. INPUT/OUTPUT INTERFACE

### VIII-2.1. Definition

Most of supervisor processing is common to all types of transfer during steps b), c) and e) described above :

1) Transfer request is analyzed for a possible preliminary processing,

2) Logical occupation of the handler is tested,

3) If required, the transfer request is queued and the Supervisor manages the queue,

4) All parameters required for physical initialization and transfer control are set up,

5) If possible, the device initial status is partially or completely read and analyzed if the whole procedure or part of it is common to all devices,

6) A branch is made to the specific control module of the device (handler),

7) A number of error conditions are acknowledged and processed when the transfer is over (sole processing specific to step e)).

The Input/Output interface of the Operating System includes the whole of these processings common to all transfers which are performed between the time the user issues a request and the time a handler takes over, and between the transfer end and the release of its results to the user.

• Input/Output processing levels

Three level classes may be considered :

a) Physical level (level 0) at which the handler performs operations which are specific to a given type of device.

b) Logical level (level 1) which includes steps 2 through 7 above. This level is that of the resident core of the basic monitor. It is usually called "I/O supervisor" (or more restrictively, "I/O interface").

c) Upper levels (2 and above) which perform step 1 of the above processing according to a hierarchy which defines the degree of sophistication of the operating system :

- records blocking/unblocking,

- file management system,
- I/O macros of sophisticated languages (FORTRAN, ...),
- specialized packages.

Level 1 controls all actual user transfers and constitutes a resident program module independent from user programs, with a number of specialized tools or "handlers" corresponding to the various device types.

In contrast, levels 2 and above are usually subroutine librairies supplied with the system for static or dynamic integration to a task, according to their origin :

- either resident as common subroutines,

- or selected in a system library and generated with a program by the linkage editor.

These subroutines are mutually related according to the general hierarchy which has been defined elsewhere for subroutines in general.

The block diagram page VIII-3 illustrates the general I/O organization.

# VIII-2.2. Input/Output control module or "handler"

Hereafter, a device controller should be regarded as including both the physical controller unit and the coupling micro-program.

The actual initialization of the transfer to or from the device, the initialization control, the possible transfer attendance and the end of transfer acknowledgment depend on the type of device, i.e. of the controller. These operations must be performed by a module which is specific of the controller.

This specialized control module is called a "handler".



General Input/output organization

It includes two sections :

- Handler 1 or "initialization handler",
- Handler 2 or "transfer control handler".

Depending on the type of device, the associated controller will operate in one of the following two modes :

- blocked data transfers,
- individual data item transfers.

If a transfer requested at level 1 applies to blocked data, the handler operating mode will be one of the following :

- The handler controls the transfer of one data block in one single operating cycle;

- The handler controls the elementary data item transfers to or from the data block. This transfer is either fully controlled by handler 2, or every elementary data transfer is controlled by handler 1 cyclically re-activated by handler 2 (for exemple to avoid rewriting in handler 2 all initialization and checking functions of handler 1).

#### • Handler 1 : initialization of a transfer

Handler 1 has the following functions :

a) If required, it analyses the initial status of the controller and/or device, before initiating the transfer. In case of abnormal conditions, the transfer is aborted and the error conditions are signalled to the I/O supervisor.

b) It issues a block transfer or read/write command, according to the operating modes of the controller and handler 2.

c) It checks that the controller actually takes over the initialization for abnormal conditions which do not require an interrupt. If an abnormal condition is detected, the procedure is as defined in a) above.

d) It returns the control to the calling program.

Handler 1 always operates at the priority level of the calling program.

The calling program is usually the I/O supervisor (level 1), but it may also be handler 2 when the data transfers are automatically re-activated.

#### • Handler 2 : transfer control

Handler 2 is a Master mode immediate program which is triggered by the controller interrupts to perform the following functions :

- it takes over the transfer steps upon interrupt, in turn with the micro-program;

- if required, it re-activates handler 1;

- it controls the end of transfer operations.

During each step, handler 2 may detect abnormal conditions which may required the transfer to be interrupted or resumed. In the latter case, the transfer is resumed by a return to handler 1.

Handler 2 always operates at the priority level of the controller interrupt.

At the end of the transfer (normal or abnormal), handler 2 performs a call to the I/O supervisor to signal the end and the validity of the transfer, before de-activating the associated interrupt level.

Remark :

Several controllers of the same type may be serviced in apparent simulaneity by handler 2. In effect, the corresponding interrupts are then grouped at the same level before reaching the processing unit, so that when handler 2 is occupied by a given interrupt, the other interrupts are waiting.



When queue management is available, each device controller has its own queue. Each queue contains chained elements and is managed through a pair of pointers. The queue elements are taken among free elements which are also chaine and managed through a pair of "hole pointers".

A "busy indicator" Ci is associated with every serviced controller i.

4057 U



Input/Output requests management

VIII-3. TRANSFERS

# VIII-3.1. Transfer requests

# • I/O calls : CSV M:10 or CSV M:ZIO

A transfer control block CB is associated with the CALL SUPERVISOR of the transfer request. This block contains user-defined parameters. At the end of the transfer, it also contains status information supplied by the system.

When the CALL is executed, A-register should contain the CB address relative to G-base. When this address is defined during execution, one may conveniently use a LEA instruction which provides resolution relative to G whatever the mode, master or slave.

The calling sequence is then : LEA CB CSV M:10

For CSV M:ZIO (available at and above MTR-level), which provides for common area I/O's, the address contained in A must be relative to the common area address (available in location 6 of the program).

The resident associates to the transfer request a dynamic event defined by the CB address and returns the control to the calling program once the transfer is initialized or queued.

The user may then perform a call to the M:WAIT module (wait event) for an event which is the beginning or the end of the transfer.

• Description of the control block parameters



For M:10 call, the I/O buffer address and the error branch address must always be relative to G.

In Slave mode this is always the case.

In Master mode, where references are normally translated into absolute addresses at loading time, these references must be preceded by a "#" character at assembly time (or a "." character in case of a LP compilation), to preserve relocatability.

For M:ZIO these addresses will be relative to ZC.

# • Byte 0 : event byte

When the transfer is over, the resident sets the bits of the "event byte" according to the following code (bit 0 is set when the resident takes over and reset at the end of the transfer).

- $-\underline{Bit 0}$  $\begin{cases} = 0 : I/O \text{ operation over} \\ = 1 : I/O \text{ operation in progress} \end{cases}$  $-\underline{Bit 1}$ = 1 : error or abnormal end $-\underline{Bit 2}$  $\begin{cases} = 0 : \text{ logical error (e.g. incorrect call format)} \\ = 1 : \text{ physical error (e.g. signalled by the controller)} \end{cases}$  $-\underline{Bit 3}$  $\begin{cases} U = 0 : \text{ error detected after transfer end} \\ U = 1 : \text{ status information supplied when the transfer is over} \end{cases}$ = 1 $\begin{cases} U = 0 : \text{ error during transfer initialization} \\ U = 1 : \text{ status information supplied when the transfer is initialized} \end{cases}$
- Bits 4, 5, 6 and 7 : error or abnormal end code.

Bits 2 through 7 are significant only if bit 1 is set (=1).

Bits 4, 5, 6, 7 provide 16 different codes for every combinaison of bits 2 and 3.

| • | Byte | 1 | : |
|---|------|---|---|
|---|------|---|---|

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
|---|---|---|---|---|---|---|---|
| υ | E | S | Т | I |   |   |   |

U = I : the user checks the transfer on resultant status information.

E = 1 : branch address in case of error or abnormal end (standard error processing).

- S = 1 : additional information present (e.g. sector address on disk storage)
- T = 1 : time out requested
- l = 1 : activate interrupt after transfer
- U = 1 and E = 1 conditions are mutually exclusive.

• Byte 2 : specifies the requested I/O function according to the following coding table :

|                      | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
|----------------------|---|---|---|---|---|---|---|---|
| Read, forward        | 0 | 0 | 0 | 0 | - | - | - | - |
| Read, backward       | 0 | 0 | 1 | 0 | - | - | - | - |
| Write                | 1 | 0 | 0 | 0 | - | - | - | - |
| Write EOD/Tape mark  | 1 | 0 | 1 | 0 | - | - | - | - |
| Format/rewind        | 1 | 0 | - | 1 | - | - | - | - |
| Skip block, forward  | - | 1 | 0 | 0 | - | - | - | - |
| Skip file, forward   | - | 1 | 0 | 1 | - | - | - | - |
| Skip block, backward | - | 1 | 1 | 0 | - | - | - | - |
| Skip file, backward  | - | 1 | 1 | 1 | - | - | - | - |

• <u>Byte 3</u> : contains the numerical value of the operational label specified at assembly time (index in I/O tables). (See section VIII-4. hereafter).

- Bytes 4 and 5 : contain the address of the first byte to be transferred to/from the core memory.
- Bytes 6 and 7 : contain the number of bytes to be transferred.
- Bytes 8 and 9 : (optional)

If U = 0 and E = 1, they contain a user-defined branch address used in case of error or abnormal end.

If U = 1 and E = 0, they contain the transfer status bits supplied by the controller and set by the resident.

• Bytes 10 and 11 : (optional)

They contain additional information whose basic function is to indicate a sector address on disk storage. For other devices, they may contain an other parameter or even the address of an additional parameter table.

• Bytes 12 and 13 : (optional)

They contain the requested time-out value.

• Bytes 14 and 15 : (optional)

They contain the interrupt level number which must be triggered by the resident when the transfer is over.

Remark :

Optional bytes are evaluated in the order of appearance of U, E, S, T, and I indicators.

When a given option is specified, the bytes corresponding to the preceding options must be reserved.

### VIII-3.2. Transfer validity checking (CSV M:WAIT or CSV M:ZWAT)

The transfer validity may be ascertained either in standard mode, or in user mode :

• Standard mode (U = 0)

All controller status bits are sensed by the resident (interface and handler which returns an easily interpretable abnormal condition code to the user. If requested in the initial CB (E = 1), the resident may return the control to a user specified address in case of abnormal condition.

If the error is impossible to correct, the control is not returned to the user, but to the typewriter after printing the corresponding program identifier and error message.

### • User mode (U = 1, E = 0)

The resident loads the status bits in bytes 8 and 9 without performing any sensing; the control is always returned to the user program.

In both cases, the transfer is considered to be over, even if a blocking condition occurs during initialization.

- CSV M:WAIT (corresponding to CSV M:IO)
- Calling sequence :

LEA CB CSV M:WAIT

At the time the CSV is met, the address relative to G of the I/O transfer control block must be stored in A-register.

• Function :

Wait for completion of an I/O transfer.

If the transfer is already over when the M:WAIT call is received, control is returned to the user (possibly at a restart address for abnormal conditions, if requested in byte 1 of the CB).

If the transfer is still in progress when the M:WAIT call is received, the latter :

- stores the calling task level in the I/O CB;

- de-activates this level if not zero, or waits for the completion of the transfer if the level is zero.

M:WAIT call temporarily de-activates the level of the program which is waiting for an I/O transfer end, in order that lower priority programs be undertaken without being blocked. The pending program is restarted as soon as the transfer is over, its level being re-activated by the handler of the controller involved in the transfer.

• Outputted elements :

A < 0 in case of I/O error.

In this case, the user should examine CB byte 0 for ascertaining the cause of the error.

 $A \ge 0$  no error

CSV M:ZWAT

Its function is the same as that of M:WAIT but relates to a M:ZIO call. The transmitted CB address must be relative to ZC.

# VIII-3.3. Communication between I/O interface and handler

The I/O interface (level 1) is basically made up of two modules :

M:10 and M:102

- Initializer M:10
- De-activation of the event which is associated with the CB by resetting bit 0 of CB byte 0.
- Bits 1 through 7 reset in CB byte 0.
- Controller occupation tested and a waiting loop established, if required
- Initialization of logical parameters required for transfer control.
- Branch to the transfer control module (H1) of the device.

M:10 supplies the following parameters to H1

- (A) = user buffer absolute address
- (E) = element of OLTB table associated with the transfer operational label (see table description)
- (X) = user CB absolute address

 $(T3)_{TWB}$  = byte count for transfer

- Upon return from H1, M:10 examines A-register contents.

A = 0 — return to calling program

 $A \neq 0 \rightarrow A_{9-15}$  loaded in CB (0)<sub>1-7</sub>; associated event activated : CB(0)<sub>0</sub> = 0;

and :

If U-indicator  $[CB(1)_0] = 1$  or

If U = 0 and A > 0, control is returned to the user

If U = 0 and A  $_{<}$  0, M:10 edits an error message and the user task is aborted.

Under MOB Basic Monitor, only one user I/O request is allowed at a time for a given device : no queue is provided.

Every I/O request of the user program will be associated with an event and the user may request by program to wait until it is activated.

Any other I/O request for the same controller (e.g. on console interrupt) occuring before the event is activated will cause a waiting loop at calling program level, until the first transfer is over.

Interrupts should be masked during the test, since the higher priority console interrupt may request an I/O transfer and change the logical status of the devices.

Under other Monitors, the user may issue several I/O requests for the same device; they will be queued and satisfied in turn as soon as the device becomes available.

• Handler 1 : H1

- Senses the controller and/or device initial status as regards specific conditions of this device type, if required;

- Sends the transfer request according to the controller and handler 2 operation mode;

- Checks the proper acceptance of this initialization by the controller for abnormal conditions which do not cause an interrupt;

- Returns the control to the calling program.

Note :

Handler 1 always operates at the calling program level, i.e. at the physical interrupt level to which it is connected.

Upon occurence of abnormal conditions, the transfer is considered over and the error conditions are sent to interface 1 through A-register.

Transfer end

When the transfer initialized by handler 1 is over, the interrupt associated with the controller activates handler 2.

We saw before that a block transfer may be carried out in two different ways :

- (i) Transfer of the whole block in one time.
- (2) Transfer of the block per data items.
- First case : block fully transferred

Handler 2 :

- Reads device status
- Checks proper device operation during the transfer
- Calls M:102

H2 supplies M:102 with

- (T1) = Element of OLTB table
- (T0) = User CB absolute address
- (A) = Report on the operation which has just been terminated.

Module 102 :

- Processes transfer errors, if any.
- Re-initializes the logical parameters which were used during the transfer.
- Activates the associated event (CB).
- Returns the control to the calling program.
- Second case : transfer interrupted

Handler 2 :

- Reads the device status,
- Checks for proper transfer : on error, module M:1O2 is called,
- Tests if all data have been transferred : if transfer is over, see first case above,
- Restarts the next data transfer by a branch to handler 1,
- De-activates the interrupt level.

### VIII-4. OPERATIONAL LABELS

#### VIII-4.1. General

The operational labels system has been introduced to enable the programs to process a logical environment.

An I/O transfer may be requested through an operational label which represents the actual I/O function. The correspondance between operational labels and physical devices is handled by the Monitor through assignment statements.

With such a system, the I/O programming is practically independent from the physical devices which are actually used and this ensures a total compatibility of the program with any configuration.

### VIII-4.2. Definition

An operational label is a number which is generally a 4-character mnemonic code.

Operational labels are distributed into two classes : standard operational labels written M:XX with a predetermined function and user operational labels written U:FX whose functions are user-specified.

| Decimal number | Mnemonic | Mnemonic Function |                           |  |  |  |  |
|----------------|----------|-------------------|---------------------------|--|--|--|--|
| 1              | M:BI     | Binary Input      | Binary                    |  |  |  |  |
| 2              | M:BO     | Binary Output     | Binary                    |  |  |  |  |
| 3              | M:CI     | Command Input     | Alphanumeric              |  |  |  |  |
| 4              | M:OC     | Operator Console  | Alphanumeric              |  |  |  |  |
| 5              | M:EI     | Element Input     | Binary or<br>Alphanumeric |  |  |  |  |
| 6              | M:EO     | Element Output    | Binary or<br>Alphanumeric |  |  |  |  |
| 7              | M:LO     | Listing Output    | Alphanumeric              |  |  |  |  |
| 8              | M:LL     | Listing Log       | Alphanumeric              |  |  |  |  |

| Decimal number | Mnemonic | Function            | Mode         |
|----------------|----------|---------------------|--------------|
| 9              | M:DO     | Diagnostic Output   | Alphanumeric |
| 10             | M:SI     | Source Input        | Alphanumeric |
| 11             | M:SL     | System's Library    | Binary       |
| 12             | M:UL     | User's Library      | Binary       |
| 13             | M:SY     | SYstem              | Binary       |
| 14             | M:EP     | Executable Programs | Binary       |
| 15             | M:GI     | Go Input            | Binary       |
| 16             | M:GO     | Go Output           | Binary       |
| 17             | U:F1     |                     |              |
| 18             | U:F2     |                     |              |
| 19             | U:F3     |                     |              |
| 20             | U:F4     |                     |              |
| 21             | U:F5     |                     |              |
| 22             | U:F6     |                     |              |
| 23             | U:F7     |                     |              |
| 24             | U:F8     |                     |              |
| 25             | U:F9     |                     |              |
| 26             | U:FA     |                     |              |
| 27             | U:FB     |                     |              |
| 28             | U:FC     |                     |              |
| 29             | U:FD     |                     |              |
| 30             | U:FE     |                     |              |
| 31             | U:FF     |                     |              |

## VIII-4.3. Operational labels assignment

Every Monitor has for standard operational labels standard assignments defined at generation time. These assignments may be modified by monitor commands, except the following :

M:OC Typewriter M:SY M:EP M:UL M:SL M:GI M:GO

User operational labels have no standard assignments and it is the user's responsibility to specify its own assignments.

## ASSIGN

This command is available under MOB-E, MTR, MTRD.

| F              | Denotes an operational label reserved for Foreground use (MTR or MTRD)       |
|----------------|------------------------------------------------------------------------------|
| M:O1 O2        | Specifies the assigned standard operational label                            |
| U:O1 O2        | Specifies the assigned user operational label (MTR or MTRD)                  |
| T:t1 t2        | Specifies the type of device to which the operational label is assigned      |
| C:c1 c2        | Specifies the controller number within the specified type                    |
| D:d            | Specifies the device number on the controller                                |
| BN             | The corresponding file is binary                                             |
| AN             | The corresponding file is alphanumeric                                       |
| Possible valu  | es for device type are :                                                     |
| T:NO           | Cancel label. An input or output request with such a label is not performed. |
| T:TY           | Typewriter (key-in and type-out)                                             |
| T:PT           | Console paper tape reader/punch                                              |
| T:PR           | High-speed paper tape reader                                                 |
| T:PP           | High-speed paper tape punch                                                  |
| T:MC           | Minicassette                                                                 |
| T:LP           | Line printer                                                                 |
| T:CR           | Card reader                                                                  |
| T:CP           | Card punch                                                                   |
| T:DC           | DIAD disk unit                                                               |
| T:9T           | 9-track magnetic tape unit                                                   |
| T:DM           | DIAM disk-pack unit                                                          |
| • <b>T:</b> VU | CRT display console                                                          |
| T:PL           | Plotter                                                                      |

## • STOL

This command is available under MTRD.

# $% \text{STOL} \left\{ \begin{array}{l} M \\ U \end{array} \right\} : O_1 O_2, \ \text{T:t}_1 t_2, \left[ C : \left[ \& \right] c_1 c_2 \right], \left[ D : \left[ \& \right] d \right], \left[ \left\{ \begin{array}{l} BN \\ AN \end{array} \right\} \right] \right\}$

This command provides for changing operational labels standard assignments.

Options have the same meaning as for %ASSIGN.

A %STOL command without any option restores the normal assignment of standard operational labels.

## VIII-5. HANDLER UTILIZATION

## VIII-5.1. Typewriter handler (# 15 001)

General

- The typewriter handler controls type-ins and print-outs (T:TY) as well as paper tape read and punch (T:PT),

The various functions are determined by the selected operational label, by its assignment (typewriter or paper tape, input or output, binary or alphanumeric) and by the function byte (two elements of the I/O CB).

- A typewriter is 72 characters long.

- For alphanumeric input or output, the ISO 7-bit code is used (ASCII). ASCII--- EBCDIC code conversions are performed by the handler, since the internal code is always EBCDIC.

- The paper tape punch drive motor in energized when the "tape on" character is detected (&12 code in ASCII). This code is not punched unless the punch is already energized at that time. The motor is shut down after punching the "tape off" character (&14 code in ASCII).

- The typewriter controller is busy either in typewriter mode or in paper tape mode, and for each of these modes, in input or output mode. The typewriter functions connot be performed simultaneously.

## Functions

• Available commands

| Hexadecimal code | Functions            |
|------------------|----------------------|
| 00               | Read                 |
| 80               | Write with format    |
| 90               | Write without format |

• Alphanumeric input : typewriter or paper tape code : &00

- The input is made one character at a time and each character is converted in EBCDIC before being transferred into user's buffer. The transfer is terminated when the specified number of characters has been reached.

However, the "carriage return" character (&OD code in EBCDIC or ASCII) always terminates the transfer after being actually transmitted to user.

- The "Paper feed" characters (&OA code in EBCDIC and &15 code in ASCII) are neither transmitted to the user nor counted in the total number of characters of the transfer.

- The "TAPE OFF" or "NULL" characters included in a record heading are not transmitted to the user and are not counted in the total number of characters of the transfer.

- When the %EOD group is detected in a record heading, the CB event byte (byte 0) is forced to 41 hexadecimal and represents an "end-of-file" mark.

• Alphanumeric output : typewriter or paper tape. Codes 80 and 90.

- The output is made one character at a time, each character being converted in ASCII at transfer time without any alteration of the user's buffer.

The transfer is terminated when the specified number of characters has been reached. No filtering is made.

- When the %EOD group is written in a record heading, the CB event byte (byte 0) is forced to 41 bexadecimal and represents an "end-of-file" mark.

- No character filtering is made.

- In paper tape mode, the transferred data are preceded by a "TAPE ON" character (not punched) and followed by a "TAPE OFF" character (punched).

• Example :

If the user's buffer contains a "TAPE OFF", the handler restarts the punch (sends a "TAPE ON" which is not punched).

- Write with format. Code 80.

The user's buffer data transfer is preceded by two "paper feed" and "carriage return" characters for starting the line at the left margin.

- Write without format. Code 90.

No line adjustement character is provided. The format is entirely the user's responsibility.

• Binary input from paper tape. Code 00.

- The data are read one character at a time. The transfer is terminated when the specified number of characters has been reached.

- The "TAPE OFF" or "NULL" characters included in a record heading are not transmitted to the user and are not counted in the total number of characters specified for the transfer.

- When the %EOD group is detected in a record heading, the CB event byte (byte 0) is forced to 41 hexadecimal and represents an "end-of-file" mark.

• Binary output on paper tape. Code 80

- The data are punched one character at a time. The transfer is terminated when the specified number of characters has been reached.

- The user's buffer data transfer is preceded by a "TAPE ON" (not punched) and followed by a "TAPE OFF" (punched).

All bytes having a value of 14 or 94 hexadecimal (corresponding to a "TAPE OFF") are followed by a "TAPE ON" (not punched) for restarting the punch motor.

- When the %EOD group is detected in a record heading, the CB event byte (byte 0) in forced to 41 hexadecimal.

| • <u>Example</u> : |        |             |       |                       |                    |
|--------------------|--------|-------------|-------|-----------------------|--------------------|
| ES                 | CDS    |             |       |                       |                    |
|                    | RES    | 16          |       | TWB                   |                    |
| BBINS              | DATA   | &0001       |       |                       |                    |
|                    | DATA   | &0002       | {     | BINARY OUTP           | UT BUFFER          |
|                    | DATA   | &0003       | )     |                       |                    |
| BALPS              | TEXT   | "MESSAGE"   |       | Alphanumeric          | output buffer      |
|                    | BND    |             |       |                       |                    |
| BBINE              | RES    | 8           |       | Binary input bu       | offer              |
| BALPE              | RES    | 7           |       | Alphanumeric i        |                    |
|                    | FIN    | ,           |       | , inplication of to . |                    |
|                    | 1.113  |             |       |                       |                    |
| LI                 | LDS    |             |       |                       |                    |
|                    | RES    | 2           |       |                       |                    |
| CB1                | DATA   | 0           |       |                       |                    |
|                    | DATA,1 | 0           |       | Read command          |                    |
|                    | DATA,1 | 1 or DATA,1 | M:BI  |                       | Binary input       |
|                    | DATA   | ₩ BBINE     |       |                       |                    |
|                    | DATA   | 16          |       |                       |                    |
| CB2                | DATA   | 0           |       |                       |                    |
| CDZ                | DATA,1 | 0           |       | Read command          |                    |
|                    | -      | •           | 11.00 |                       |                    |
|                    | DATA,1 | 4 or DATA,1 | M:00  |                       | Alphanumeric input |
|                    | DATA   | ₩ BALPE     |       |                       |                    |
|                    | DATA   | 14          |       |                       |                    |
|                    |        |             |       |                       |                    |

| С ВЗ      | DATA<br>DATA,1<br>DATA,1<br>DATA<br>DATA                                                | 0<br>80<br>2 or DATA,1<br># BBINS<br>6                                                                        | M:BO | Write command<br>Binary output                                                                                                                                                                                       |
|-----------|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C B 4     | DATA<br>DATA,1<br>DATA,1<br>DATA<br>DATA<br>FIN                                         | 0<br>80<br>7 or DATA,1<br># BALPS<br>7                                                                        | M:LO | Write command<br>Alphanumeric output                                                                                                                                                                                 |
| P1<br>DEB | LPS<br>LEA<br>CSV<br>CSV<br>LEA<br>CSV<br>CSV<br>LEA<br>CSV<br>CSV<br>LEA<br>CSV<br>FIN | L1<br>CB1<br>M:IO<br>M:WAIT<br>CB2<br>M:IO<br>M:WAIT<br>CB3<br>M:IO<br>M:WAIT<br>CB4<br>M:IO<br>M:WAIT<br>DEB |      | Input of a 16-byte binary record from M:BI<br>Input of an alphanumeric record 14-characters max. from<br>typewriter (M:OC)<br>Output of a binary record 0001, 0002, 0003 on M:BO<br>Output of "MESSAGE" text on M:LO |
|           | END                                                                                     | P1                                                                                                            |      |                                                                                                                                                                                                                      |

#### VIII-5.2. 300 char./sec. paper tape reader handler (#15 062/60)

## General

- This handler controls the binary or alphanumeric input from the paper tape (T:PR), each of these two functions being determined by the selected operational label, by its assignment and by the function byte (two elements of the I/O CB).

- For alphanumeric input, the ISO 7-bit code is used (ASCII). The ASCII --- EBCDIC code conversion is performed by the handler, since the internal code is always EBCDIC.

## Functions

The available command byte is &00 (read).

• Alphanumeric input. Code &00

- The input is made one character at a time and each character is converted in EBCDIC before being transferred into user's buffer. The transfer is terminated when the specified number of characters has been reached.

However, the "carriage return" character (&OD code in EBCDIC or ASCII) always terminates the transfer after being actyally transmitted to the user.

- The "paper feed" characters (&OA code in EBCDIC and &15 code in ASCII) are neither transmitted to the user nor counted in the total number of characters of the transfer.

The "TAPE OFF" or "FULL" characters included in a record heading are neither transmitted to the user nor counted in the total number of characters of the transfer.

- When the %EOD group is detected in a record heading, the CB event byte (byte 0) is forced to 41 hexadecimal and represents an "end-of-file" mark.

• Binary input. Code &00

- The data are read one character at a time. The transfer is terminated when the specified number of characters has been reached.

- The "TAPE OFF" or "NULL" characters included in a record heading are neither transmitted to the user nor counted in the total number of characters specified for the transfer.

- When the %EOD group is detected in a record heading, the event byte (CB byte 0) is forced to 41 hexadecimal representing an "end-of-file" mark.

## VIII-5.3. 60 char./sec. paper tape punch handler (#15 060)

General

- This handler controls the binary or alphanumeric output on paper tape (T:PP), each of these functions being determined by the selected operational label, by its assignment and by the function byte (two elements of the I/O CB).

- For alphanumeric output, the ISO 7-bit code is used (ASCII). The ASCII---EBCDIC code conversion is performed by the handler, since the internal code is always EBCDIC.

Functions

The available command byte is &80 (write)

• Alphanumeric output. Code &80.

- The output is made one character at a time, each character bieng converted in ASCII at transfer time without any modification of the user's buffer. The transfer is terminated when the specified number of characters has been reached. No filtering is made.

- When the %EOD group is written in a record heading, the CB event byte (byte 0) is forced to 41 hexadecimal representing an "end-of-file" mark.

• Binary output. Command &80.

- The output is made one character at a time and the transfer is terminated when the specified number of characters has been reached.

## VIII-5.4. 300 char./sec. card reader handler (# 15 120)

General

- This handler controls the binary or alphanumeric input from the cards (T:CR), each of these functions being determined by the selected operational label, by its assignment and by the function byte (two elements of the I/O CB).

- For alphanumeric input, the EBCDIC card code is used on a one character per column basis (80 characters).
- For binary input, each card contains up to 120 bytes.

## Functions

The available command byte is &00 (read).

- Alphanumeric input. Code 00.
- 80 characters are read.

- When the %EOD group is detected in a record heading, the CB event byte (byte 0) is forced to 41 hexadecimal representing an "end-of-file" mark.

• Binary input. Code 00.

- 120 bytes are read.

- When the %EOD group is detected in a record heading, the CB event byte (byte 0) is forced to 41 hexadecimal representing an "end-of-file" mark.

Note that, in this case, %EOD is a 4-character group, punched in the first four columns of the card (i.e. the first six bytes in binary reading mode).

Thus, the EOD mark is the same in binary and alphanumerical reading.

#### ∨111-5.5. 200 l.p.m. printer handler (#15 412)

#### General

This handler controls the alphanumerical outputs on the line printer (T:LP).

The print line is 132 characters long.

The alphanumeric output code is the ISO 7-bit standard code (ASCII). The user's buffer may be coded in ASCII or EBCDIC.

- EBCDIC-coded buffer. This is the most frequent case

The user must use an alphanumeric operational label (M:LO, etc.). The EBCDIC  $\rightarrow$  ASCII conversion is performed by the handler in the buffer before the output transfer. The reciprocal ASCII  $\rightarrow$  EBCDIC conversion will be performed by the handler at the end of the transfer. This double conversion has no effect on the final contents of the buffer.

#### - ASCII-coded buffer

The user must use a binary operational label (M:BI, etc.); no code conversion is performed.

#### Functions

• Available commands :

| Hexadecimal code | Function             |
|------------------|----------------------|
| 80               | Write without format |
| 90               | Write with format    |

• Write without format mode

A paper feed is executed after the requested printing.

• Write with format

The first byte in the user's buffer will specify a paper positioning operation executed before the actual printing.

This skip code is conted in the number of transferred bytes.

The printing operation is normally followed by a paper feed, except when the format byte contains E0 or 60 (EBCDIC code).

| Code  |        |                                    |
|-------|--------|------------------------------------|
| ASCII | EBCDIC | Function                           |
| 5C    | EO     | Omit paper feed after printing     |
| 2D    | 60     | Skip 0 line                        |
| 7 B   | C0     | Skip 1 line                        |
| 41    | C1     | Skip 2 lines                       |
| 42    | C2     | Skip 3 lines                       |
| С3    | С3     | Skip 3 lines                       |
| 44    | C4     | Skip 4 lines                       |
| C5    | C5     | Skip 5 lines                       |
| С6    | C6     | Skip 6 lines                       |
| 47    | C7     | Skip 7 lines                       |
| 48    | C8     | Skip 8 lines                       |
| С9    | C9     | Skip 9 lines                       |
| 60    | CA     | Skip 10 lines                      |
| E1    | СВ     | Skip 11 lines                      |
| E2    | сс     | Skip 12 lines                      |
| 63    | CD     | Skip 13 lines                      |
| E4    | CE     | Skip 14 lines                      |
| 65    | CF     | Skip 15 lines                      |
| 30    | FO     | Skip on channel 0 (botton of form) |
| B1    | Fl     | Skip on channel 1                  |
| B2    | F2     | Skip on channel 2                  |
| 33    | F3     | Skip on channel 3 (top of form)    |

VIII-5.6. Fast-access disk handler (#15 200/1/2/3/4)

## General

This handler controls the transfers between the core memory and the fast-access disk.

The associated CB must include an additional information : the disk address. This address specifies a number of disk-sectors (the first sector being sector 0).



The transfer is always initiated at the beginning of a sector. If the requested byte number is not a multiple of 256, the last sector which is only partly occupied, is filled with zeroes. Thus, the modified memory area is always a multiple of 256.

The transfer being executed one word at a time, the byte count in the CB must be even.

This handler considers the disk as an ordinary device; the MTRD handler, which is more powerful, performs the disk area management tasks.

## Functions

• Available commands :

| Hexadecimal code | Function                      |
|------------------|-------------------------------|
| 00               | Read                          |
| 10               | Read and update disk-address  |
| 80               | Write                         |
| 90               | Write and update disk-address |

• Disk-address update :

For 10 and 90 command codes, the disk-address of the CB is incremented by the number of transferred sectors. This updating function may simplify the following transfers.

## zra 15

. C

. S

## **Appendix A** – List of pseudo-instructions

The following representation conventions are used in the table below :

- Pseudo : Name of the pseudo-instruction – Format : Operand format - Type : Type of operand . LE : Label expression . RE : Reference expression . V : Value : Character string : Segment name - Function : Definition of the pseudo-instruction function - DATA : Authorized in a CDS or LDS - PROG : Authorized in a LPS
- LAB : Assigns an address to a label

| PSEUDO                  | FORMAT       | Туре | FUNCTION                                                                                                                                                                                    | DATA | PROG | LAB |
|-------------------------|--------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-----|
| CDS                     | [DUM]        |      | Definition of the common data<br>section or CDS.<br>No code generated if DUM is<br>present.                                                                                                 |      |      | x   |
| LDS                     | [DUM]        |      | Definition of a local data segment<br>or LDS.<br>No code generated if DUM is<br>present.                                                                                                    |      |      | x   |
| IDS<br>(MITRAS II only) | [DUM]        |      | Identification of an indirect access<br>data segment. Any label specified<br>in this segment is defined with<br>respect to its starting address.<br>No code generated if DUM is<br>present. |      |      | ×   |
| LPS                     | NAME         | S    | Definition of an executable local<br>program segment LPS and thus of a<br>program section.<br>NAME is the name of the<br>associated LDS                                                     |      |      | ×   |
| END                     | SECTION NAME | S    | Indication of the assembly module<br>end SECTION NAME is the name<br>of the first section to be executed.                                                                                   |      |      |     |

| PSEUDO                             | FORMAT                                  | Type    | FUNCTION                                                                                                                                                                                                                                                | DATA | PROG | LAB |
|------------------------------------|-----------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-----|
| FIN                                | [LABEL]                                 | LE      | Indication of a segment end.<br>– LABEL may only be used in a LPS.<br>In this case, it defines the starting<br>address in the segment.                                                                                                                  | ×    | x    | x   |
| RES,1                              | VALUE                                   | V       | Reservation of a memory area.<br>– ,1 indicates, when specified,<br>that the reservation unit is the byte,<br>otherwise it is the word.<br>– VALUE defines ghe length of the<br>memory area.                                                            | x    | x    | ×   |
| BND                                |                                         |         | This pseudo-instructions advances<br>the location counter to a word<br>boundary.                                                                                                                                                                        | ×    | ×    |     |
| EQU                                | (Predefined expression)<br>(\$          | LE      | Definition of an equivalence<br>between the symbol in label field<br>and the quantity defined in operand<br>field.                                                                                                                                      | ×    | ×    | ×   |
| GOTO,n<br>(MITRAS II only)         | Lab1 , Lab2 , , Labn                    | LE      | Specification of a conditional<br>branch at assembly time.<br>– , n is a value pointing at a label<br>in operand field at which the branch<br>is made.                                                                                                  | ×    | ×    |     |
| DO<br>(MITRAS II only)             | VALUE<br>%                              |         | Specification of an iterative<br>assembly of an instruction.<br>- VALUE = number of iterations<br>- % : at every iteration cycle,<br>this character takes the value of<br>the iteration counter.                                                        | x    |      |     |
| DATA,1                             | [#] Expression 1<br>[,[#] Expression 2] | LE<br>∨ | Data generation statement<br>- ,1 if present in command field<br>the locations are expressed in<br>bytes, otherwise in words.<br>- # This symbol denotes that the<br>following expression must be left<br>relative to G upon loading in<br>Master mode. | ×    |      |     |
| GEN, Area list<br>(MITRAS II only) | Expression list                         | V       | Value generation statement.<br>– Area list is a sequence of values<br>each defining the length of an area<br>to be generated.<br>– Expression list is a sequence of<br>expressions defining the contents of<br>the declared areas.                      | ×    | x    | ×   |

| PSEUDO                   | FORMAT                     | Туре | FUNCTION                                                                                                                           | DATA | PROG | LA B |
|--------------------------|----------------------------|------|------------------------------------------------------------------------------------------------------------------------------------|------|------|------|
| ΤΕΧΤ                     | "Character string"         | С    | Generation of a character string.<br>– Character string is made up of<br>alphanumeric characters.                                  | ×    |      | ×    |
| DEF                      | Label [,Label]             | LE   | Declaration of labels as external definitions.                                                                                     | x    | ×    |      |
| REF                      | [#] Label<br>[, [#] Label] | LE   | Declaration of labels as external<br>references.<br>- ⊭ indicates that the label belongs<br>to the CDS.                            | ×    | ×    |      |
| BA SE                    | [Label]                    |      | This statement requests that all<br>address generated at assembly time<br>be relative to an address specified<br>in operand field. |      | ×    |      |
| PAGE<br>(MITRAS II only) |                            |      | The assembly listing is printed on<br>the next page if the output device<br>is the printer.                                        | ×    |      |      |

## mitra 15

## **Appendix B** – List of instructions

|              |       | c     | ode a | ccord | ling to | o addr | essing | mod  | e  |              |       | с    | ode a | ccord | ing to | o addı | essing | g mod | e          |
|--------------|-------|-------|-------|-------|---------|--------|--------|------|----|--------------|-------|------|-------|-------|--------|--------|--------|-------|------------|
| Instr.       | Class | Р     | DL    | IL    | ILX     | DG     | IGX    | RP   | RM | Instr .      | Class | Р    | DL    | IL    | ILX    | DG     | IGX    | RP    | RM         |
| ADD          | 0     | 25    | 05    | 65    | A 5     | 45     | 85     | -    | -  | LBL          | 0     | 2 D  | 0 D   | 6D    | AD     | 4D     | 8 D    | -     | -          |
| ADM          | 0'    | -     | 17    | 77    | B7      | 57     | 97     | -    | -  | LBR          | 0     | 2E   | 0E    | 6E    | AE     | 4E     | 8E     | -     | -          |
| AND          | 0     | 29    | 09    | 69    | Α9      | 49     | 89     | -    | -  | LBX          | 0     | 2F   | 0F    | 6F    | AF     | 4F     | 8F     | -     | -          |
| BAN          | 2     | -     | -     | D4    | -       | -      | DC     | C4   | cc | LDA          | 0     | 20   | 00    | 60    | A0     | 40     | 80     | -     | -          |
| BAZ          | 2     | -     | -     | D5    | -       | -      | DD     | C5   | CD | LDE          | 0     | 21   | 01    | 61    | A1     | 41     | 81     | -     | -          |
| BCF          | 2     | -     | -     | D3    | -       | -      | DB     | С3   | СВ | *•LDP        | 1     | FB   | 3B    | -     | -      | -      | -      | -     | -          |
| вст          | 2     | -     | -     | D0    | -       | -      | D8     | CO   | C8 | • L D R      | 1     | F9   | 39    | -     | -      | -      | -      | -     | -          |
| BOF          | 2     | -     | -     | D6    | -       | -      | DE     | C6   | CE | LDX          | 0     | 22   | 02    | 62    | A2     | 42     | 82     | -     | -          |
| BOT          | 2     | -     | -     | D2    | -       | -      | DA     | C2   | CA | LEA          | 0     | -    | 04    | 64    | A4     | 44     | 84     | ÷     | -          |
| BRU          | 2     | -     | -     | D7    | -       | -      | DF     | C7   | CF | MUL          | 0     | 2C   | 0C    | 6C    | AC     | 4C     | 8C     | -     | -          |
| BRX          | 2     | -     | -     | DI    | -       | -      | D9     | CI   | С9 | * M∨S        | 0'    | -    | 1 F   | 7F    | BF     | 5F     | 9F     | -     | -          |
| • CLM        | 1     | F 400 | -     | -     | -       | -      | -      | -    | -  | • RD         | 1     | F402 | -     | -     | -      | -      | -      | -     | -          |
| CLS          | 1     | F8    | 38    | -     | -       | -      | -      | E8 º | -  | RS∨          | 1     | F1   | -     | -     | -      | -      | -      | -     | -          |
| СМР          | 0     | 2B    | OB    | 6 B   | AB      | 4B     | 8 B    | -    | -  | RTS          | 1     | F100 | -     | -     | -      | -      | -      | -     | -          |
| * CPS        | 0     | 2A    | 0A    | 6A    | AA      | 4A     | 8A     | -    | -  | SBL          | 0'    | -    | 14    | 74    | B4     | 54     | 94     | -     | -          |
| Cs∨          | 1     | F7    | 37    | -     | -       | -      | -      | E7 o | -  | SBR          | 0'    | -    | 15    | 75    | B5     | 55     | 95     | -     | -          |
| DCL          | 1     | F6    | 36    | -     | -       | -      | -      | E6 o | -  | * SHC        | 1     | FC   | 3C    | -     | -      | -      | -      | ∘EC   | -          |
| DCX          | 1     | F3    | 33    | -     | -       | -      | -      | E3。  | -  | SHR          | 1     | FO   | 30    | -     | -      | -      | -      | ∘E0   | -          |
| • DIT        | 1     | F401  | -     | -     | -       | -      | -      | -    | -  | SPA          | 0'    | -    | 18    | 78    | B8     | 58     | 98     | -     | -          |
| *DIV         | 0     | 28    | 08    | 68    | A8      | 48     | 88     | -    | -  | SRG          | 1     | F1   | 31    | -     | -      | -      | -      | ∘ E 1 | -          |
| DLD          | 0'    | -     | 10    | 70    | BO      | 50     | 90     | -    | -  | STA          | 0'    | -    | 11    | 71    | B1     | 51     | 91     | -     | -          |
| DST          | 0'    | -     | 16    | 76    | B6      | 56     | 96     | -    | -  | STE          | 0'    | -    | 12    | 72    | B2     | 52     | 92     | -     | <b>-</b> . |
| EOR          | 0     | 23    | 03    | 63    | A3      | 43     | 83     | -    | -  | • STM        | 1     | F408 | -     | -     | -      | -      | -      | -     | -          |
| *FAD         | 0'    | -     | 1A    | 7A    | BA      | 5A     | 9A     | -    | -  | • STR        | 1     | FA   | 3A    | -     | -      | -      | -      | ۰EA   | -          |
| <b>≭</b> FDV | 0'    | -     | 10    | 7 D   | BD      | 5D     | 9D     | -    | -  | STS          | 0'    | -    | 19    | 79    | B9     | 59     | 99     | -     | -          |
| * FM U       | 0'    | -     | 10    | 7C    | BC      | 5C     | 9C     | -    | -  | STX          | 0'    | -    | 13    | 73    | B3     | 53     | 93     | -     | -          |
| * FSU        | 0'    | -     | 1 B   | 7 B   | BB      | 5 B    | 9B     | -    | -  | SUB          | 0     | 26   | 06    | 66    | A6     | 46     | 86     | -     | -          |
| ICL          | 1     | F5    | 35    | -     | -       | -      | -      | E5 o | -  | <b>∗</b> TES | 1     | FD   | 3D    | -     | -      | -      |        | ۰ED   | -          |
| ісх          | 1     | F2    | 32    | -     | -       | -      | -      | E2 o | -  | * TR S       | 0'    | -    | 1 E   | 7E    | BE     | 5E     | 9E     | -     | -          |
| IOR          | 0     | 27    | 07    | 67    | A7      | 47     | 87     | -    | -  | • WD         | 1     | F403 | -     | -     | -      | -      | -      | -     | -          |

#### Instructions are arranged in alphabetic order

<u>Note</u> :

- : Priviledged instruction
- \* : Optional instruction
- o : PX addressing mode

## Instructions are arranged in ascending hexadecimal order

| Code | Instruc . | Class | Adr. | Code       | Instruc . | Class | Adr. | Code | Instruc. | Class | Adr. | Code | Instruc. | Class | Adr. |
|------|-----------|-------|------|------------|-----------|-------|------|------|----------|-------|------|------|----------|-------|------|
| 00   | LDA       | 0     | DL   | 20         | LDA       | 0     | Р    | 40   | LDA      | 0     | DG   | 60   | LDA      | 0     | IL   |
| 01   | LDE       | 0     | -    | 21         | LDE       | 0     | -    | 41   | LDE      | 0     | -    | 61   | LDE      | 0     | -    |
| 02   | LDX       | 0     | -    | 22         | LDX       | 0     | _    | 42   | LDX      | 0     | -    | 62   | LDX      | 0     | -    |
| 03   | EOR       | 0     | -    | 23         | EOR       | 0     | -    | 43   | EOR      | 0     | -    | 63   | EOR      | 0     | -    |
| 04   | LEA       | 0     | -    | 24         | LEA       | 0     | -    | 44   | LEA      | 0     | -    | 64   | LEA      | 0     | -    |
| 05   | ADD       | 0     | -    | 25         | ADD       | 0     | -    | 45   | ADD      | 0     | -    | 65   | ADD      | 0     | -    |
| 06   | SUB       | 0     | -    | 26         | SUB       | 0     | -    | 46   | SUB      | 0     | -    | 66   | SUB      | 0     | -    |
| 07   | IOR       | 0     | -    | <b>2</b> 7 | IOR       | 0     | -    | 47   | IOR      | 0     | -    | 67   | IOR      | 0     | -    |
| 08   | + DIV     | 0     | -    | 28         | * DIV     | 0     | -    | 48   | * DIV    | 0     | -    | 68   | * DIV    | 0     | -    |
| 09   | AND       | 0     | -    | 29         | AND       | 0     | -    | 49   | AND      | 0     | -    | 69   | AND      | 0     | -    |
| 0A   | * CPS     | 0     | -    | 2A         | * CPS     | 0     | -    | 4A   | * CPS    | 0     | -    | 6A   | * CPS    | o     | -    |
| ОВ   | СМР       | 0     | -    | 2 B        | СМР       | 0     | -    | 4 B  | СМР      | 0     | -    | 6 B  | СМР      | 0     | -    |
| 0C   | MUL       | 0     | -    | 2C         | MUL       | 0     | -    | 4C   | MUL      | 0     | -    | 6C   | MUL      | 0     | -    |
| 0 D  | LBL       | 0     | -    | 2 D        | LBL       | 0     | -    | 4D   | LBL      | 0     | -    | 6 D  | LBL      | 0     | -    |
| OE   | LBR       | 0     | -    | 2E         | LBR       | 0     | -    | 4E   | LBR      | 0     | -    | 6E   | LBR      | 0     | -    |
| OF   | LBX       | 0     | -    | 2F         | LBX       | 0     | -    | 4F   | LBX      | 0     | -    | 6F   | LBX      | 0     | -    |
| . 10 | DLD       | 0'    | -    | 30         | SHR       | 1     | DL   | 50   | DLD      | 0'    | -    | 70   | DLD      | 0'    | -    |
| 11   | STA       | 0'    | -    | 31         | SRG       | 1     | -    | 51   | STA      | 0'    | -    | 71   | STA      | 0'    | -    |
| 12   | STE       | 0'    | -    | 32         | ісх       | 1     | -    | 52   | STE      | 0'    | -    | 72   | STE      | 0'    | -    |
| 13   | STX       | 0'    | -    | 33         | DCX       | 1     | -    | 53   | STX      | 0'    | -    | 73   | STX      | 0'    | -    |
| 14   | SBL       | 0'    | -    | 34         |           |       |      | 54   | SBL      | 0'    | -    | 74   | SBL      | 0'    | -    |
| 15   | SBR       | 0'    | -    | 35         | ICL       | 1     | -    | 55   | SBR      | 0'    | -    | 75   | SBR      | 0'    | -    |
| 16   | DST       | 0'    | -    | 36         | DCL       | 1     | -    | 56   | DST      | 0'    | -    | 76   | DST      | 0'    | -    |
| 17   | ADM       | 0'    | -    | 37         | CSV       | 1     | -    | 57   | ADM      | 0'    | -    | 77   | ADM      | 0'    | -    |
| 18   | SPA       | 0'    | -    | 38         | CLS       | 1     | -    | 58   | SPA      | 0'    | -    | 78   | SPA      | 0'    | -    |
| 19   | STS       | 0'    | -    | 39         | • LDR     | 1     | -    | 59   | STS      | 0'    | -    | 79   | STS      | 0'    | -    |
| 1A   | * FA D    | 0'    | -    | 3A         | • STR     | 1     | -    | 5A   | ★ FA D   | 0'    | -    | 7A   | ∗ FA D   | 0'    | -    |
| 1 B  | * FSU     | 0'    | , -  | 3B         | *•LDP     | 1     | -    | 5 B  | * FSU    | 0'    | -    | 7 B  | * FSU    | 0'    | -    |
| 10   | * FM U    | 0'    | -    | 3C         | ∗ ѕнс     | 1     | -    | 5C   | * FM U   | 0'    | -    | 7C   | * FM U   | 0'    | -    |
| 10   | * FD∨     | 0'    | -    | 3D         | * TES     | 1     | -    | 5 D  | ∗ FDV    | 0'    | -    | 7 D  | * FDV    | 0'    | -    |
| 1 E  | * TRS     | 0'    | -    | 3E         |           |       |      | 5E   | * TR S   | 0'    | -    | 7E   | * TRS    | 0'    | -    |
| 1F   | * M∨S     | 0'    | -    | 3F         |           |       |      | 5F   | *M∨S     | 0'    | -    | 7 F  | * M∨S    | 0'    | -    |

Note :

\* : Optional instruction

• : Priviledged instruction

| Code | Instruc.     | Class | Adr. | Code       | Instruc.     | Class | A dr . | Code | Instruc. | Class | Adr. | Code | Instruc.             | Class | Adr. |
|------|--------------|-------|------|------------|--------------|-------|--------|------|----------|-------|------|------|----------------------|-------|------|
| 80   | LDA          | 0     | IGX  | <b>A</b> 0 | LDA          | 0     | ILX    | CO   | вст      | 2     | RP   | EO   | SHR                  | 1     | РХ   |
| 81   | LDE          | 0     | -    | AI         | LDE          | 0     | -      | СІ   | BRX      | 2     | -    | El   | SRG                  | 1     | -    |
| 82   | LDX          | 0     | -    | A2         | LDX          | 0     | -      | C2   | вот      | 2     | -    | E2   | ісх                  | 1     | -    |
| 83   | EOR          | 0     | -    | A3         | EOR          | 0     | -      | С3   | BCF      | 2     | -    | E 3  | DCX                  | 1     | -    |
| 84   | LEA          | 0     | -    | A4         | LEA          | 0     | -      | C4   | BAN      | 2     | -    | E4   |                      |       |      |
| 85   | ADD          | 0     | -    | A 5        | ADD          | 0     | _      | C5   | BAZ      | 2     | -    | E 5  | ICL                  | 1     | -    |
| 86   | SUB          | 0     | -    | A6         | SUB          | 0     | -      | C6   | BOF      | 2     | -    | E6   | DCL                  | 1     | -    |
| 87   | IOR          | 0     | -    | A7         | IOR          | 0     | -      | C7   | BRU      | 2     | -    | E7   | csv                  | 1     | -    |
| 88   | *DIV         | 0     | -    | A8         | <b>*</b> DI∨ | 0     | -      | C8   | BCT      | 2     | RM   | E8   | CLS                  | 1     | -    |
| 89   | AND          | 0     | -    | A9         | AND          | 0     | -      | C9   | BRX      | 2     |      | E9   | • LDR                | 1     | -    |
| 8A   | * CPS        | 0     | -    | AA         | * CPS        | 0     | -      | CA   | BOT      | 2     | -    | EA   | • STR                | 1     | -    |
| 8 B  | СМР          | 0     | -    | AB         | СМР          | 0     | -      | СВ   | BCF      | 2     | -    | EB   | *•LDP                | 1     | -    |
| 8C   | MUL          | 0     | -    | AC         | MUL          | 0     | -      | сс   | BAN      | 2     | -    | EC   | * SHC                | 1     | -    |
| 8D   | LBL          | 0     | -    | AB         | LBL          | 0     | -      | CD   | BAZ      | 2     | -    | ED   | * TES                | 1     | -    |
| 8E   | LBR          | 0     | -    | AE         | LBR          | 0     | -      | CE   | BOF      | 2     | -    | EE   |                      |       |      |
| 8F   | LBX          | 0     | -    | AF         | LBX          | 0     | -      | CF   | BRU      | 2     | -    | EF   |                      |       |      |
| 90   | DLD          | 0'    | -    | во         | DLD          | 0'    | -      | D0   | BCT      | 2     | IL   | FO   | SHR                  | 1     | Р    |
| 91   | STA          | 0'    | -    | B1         | STA          | 0'    | -      | DI   | BRX      | 2     | -    | Fl   | SRG                  | 1     | -    |
| 92   | STE          | 0'    | -    | B2         | STE          | 0'    | -      | D2   | BOT      | 2     | -    | F2   | ісх                  | 1     | -    |
| 93   | STX          | 0'    | -    | B3         | STX          | 0'    | -      | D3   | BCF      | 2     | -    | F3   | DCX                  | 1     | -    |
| 94   | SBL          | 0'    | -    | B4         | SBL          | 0'    | -      | D4   | BAN      | 2     | -    | F4   | • sys <sup>(1)</sup> | 1     | -    |
| 95   | SBR          | 0'    | -    | B5         | SBR          | 0'    | -      | D5   | BAZ      | 2     | -    | F5   | ICL                  | 1     | -    |
| 96   | DST          | 0'    | -    | B6         | DST          | 0'    | -      | D6   | BOF      | 2     | -    | F6   | DCL                  | 1     | -    |
| 97   | ADM          | 0'    | -    | B7         | ADM          | 0'    | -      | D7   | BRU      | 2     | -    | F7   | CSV                  | 1     | -    |
| 98   | SPA          | 0'    | -    | B8         | SPA          | 0'    | -      | D8   | BCT      | 2     | ١G   | F8   | CLS                  | 1     | -    |
| 99   | STS          | 0'    | -    | B9         | STS          | 0'    | -      | D9   | BRX      | 2     | -    | F9   | • LDR                | 1     | -    |
| 9A   | * FA D       | 0'    | -    | BA         | * FA D       | 0'    | -      | DA   | BOT      | 2     | -    | FA   | • STR                | 1     | -    |
| 9B   | * FSU        | 0'    | -    | BB         | * FSU        | 0'    | -      | DB   | BCF      | 2     | -    | FB   | *∙LDP                | 1     | -    |
| 9C   | * FM U       | 0'    | -    | BC         | * FMU        | 0'    | -      | DC   | BAN      | 2     | -    | FC   | * SHC                | 1     | -    |
| 9D   | <b>≭</b> FD∨ | 0'    | -    | BD         | ∗ FDV        | 0'    | -      | DD   | BAZ      | 2     | -    | FD   | * TES                | 1     | -    |
| 9E   | * TRS        | 0'    | -    | BE         | ∗ TRS        | 0'    | -      | DE   | BOF      | 2     | -    | FE   |                      |       |      |
| 9F   | *M∨S         | 0'    | -    | BF         | * MSV        | 0'    | -      | DF   | BRU      | 2     | -    | FF   |                      |       |      |

## Note :

\* : Optional instruction

• : Priviledged instruction

(1) SYS : this mnemonic is not recognized by the Assembler

## SRG instruction

| Instruction | Function                           | Code |
|-------------|------------------------------------|------|
| AAE         | (A) ∩ (E) ——→(A)                   | F118 |
| ACE         | (E) + C (E)                        | F10E |
| AEE         | (A) ⊕ (E) → (A)                    | F112 |
| AIE         | (A) ∪ (E) ——→(A)                   | F116 |
| ССА         | (Ā) −−−−→ (A)                      | F110 |
| CCE         | (Ē) ——— (E)                        | F10A |
| СНХ         | Arithmetic shift 1 step left       | FIIE |
| CNA         | -A (A)                             | FIIC |
| CNX         | -X (X)                             | F114 |
| LNE         | -1 (E)                             | F11A |
| RTS         | Return section                     | F100 |
| RS∨         | Return supervisor                  | F10C |
| XAA         | A <sub>0-7</sub> A <sub>8-15</sub> | F108 |
| XAE         | (A) (E)                            | F102 |
| XAX         | (A) (X)                            | F104 |
| XEX         | (E) • (X)                          | F106 |

## SYS instruction $^{(1)}$

| Function       | Class | Instruction | Code  |
|----------------|-------|-------------|-------|
| Clear IT mask  | 1     | CLM         | F400  |
| De-activate IT | 1     | DIT         | F401  |
| Read direct    | 1     | RD          | F 402 |
| Write direct   | 1     | WD          | F403  |
| Set IT mask    | 1     | STM         | F408  |

 $^{(1)}$  SYS : this mnemonic is not recognized by the Assembler

## Addressing :

|     | Class 0           |     | Class 0'          | c  | lass 1    |    | Class 2       |
|-----|-------------------|-----|-------------------|----|-----------|----|---------------|
| Ρ   | Y=D               | DL  | Y=D+(L)           | Р  | N=D       | RP | Y=(P)+2D      |
| DL  | Y=D+(L)           | ۱L  | Y=(D+(L))+G '     | PX | N=D+(X)   | RM | Y=(P)-2D      |
| IL  | Y=(D+(LL)+G'      | ILX | Y=(D+(L))+G'+(X)  | DL | N=(D+(L)) | DL | Y=(D+(L))+G ' |
| ILX | Y=(D+(L))+G'+(X)  | DG  | Y=D+(G)           |    |           | DG | Y=(D+(G))+G'  |
| DG  | Y=D+(G)           | IGX | Y=(D+(G))+(G)+(X) |    |           |    |               |
| IGX | Y=(D+(G))+(G)+(X) |     |                   |    |           |    |               |

## SHR instruction

| 0 | 8 10                 | 15 |
|---|----------------------|----|
|   | $\varphi_{_{\rm C}}$ |    |

| Function                      | <b>₽</b> <sub>C</sub> | Code |
|-------------------------------|-----------------------|------|
| Shift Logical Left Single     | 0                     | SLLS |
| Shift Circular Right Single   | 1                     | SRCS |
| Shift Arithmetic Right Double | 2                     | SAD  |
| Shift Circular Left Double    | 3                     | SLCD |
| Shift Circular Left Single    | 4                     | SLCS |
| Shift Arithmetic Right Single | 5                     | SA S |
| Shift Logical Right Single    | 6                     | SRLS |
| Shift Circular Right Double   | 7                     | SRCD |

## SHC instruction

| 0 | 8 10           | 15 |
|---|----------------|----|
|   | φ <sub>c</sub> |    |

| Function                   | $\varphi_{\rm c}$ | Code |
|----------------------------|-------------------|------|
| Shift Logical Left Double  | 0                 | SLLD |
| Compute parity             | 2                 | PTY  |
| Shift Logical Right Double | 4                 | SRLD |
| Normalize E,A              | 6                 | NLZ  |
| De-activate fast IT        | 1<br>3<br>5<br>7  | DITR |

## <u>mitra 15</u>

## **Appendix D - Assembler operation**

## I - ASSEMBLY LISTING

## I-1. FORMAT OF AN ASSEMBLY LISTING LINE

The general line format of an assembly listing is illustrated below.

A line contains the following informations :

- Up to two error flags.
- A decimal line number.

- The current hexadecimal contents of the location counter.

- The object code (hexadecimal) generated by the Assembler.

- A indication of a forward reference if the argument address is anticipated.
- The source line image.

The lines which are skipped under control of a GOTO are not annotated except when they contain an invalid operation code.

| ſ | 1 |   |   | 4 |   |    |   |   | 9 |   |   |   |   | 14  |   |    |   |   | 20 |   |   |    |   | 7 | 72 |
|---|---|---|---|---|---|----|---|---|---|---|---|---|---|-----|---|----|---|---|----|---|---|----|---|---|----|
| ł |   |   |   | 1 |   |    |   |   |   |   |   |   |   | _1_ |   |    |   |   |    |   |   |    |   | - |    |
|   | Ε | Ε | D | D | D | D, | ŧ | L | L | L | L | ¥ | Х | х   | Х | XA | ¥ | * | S  | S | s | •• | S | S | S  |

| *                    | : | Space                                                          |
|----------------------|---|----------------------------------------------------------------|
| EE                   | : | Error flags                                                    |
| DDDD                 | : | Decimal number of source line                                  |
| LLLL                 | : | Hexadecimal value of location counter                          |
| XXXX or <b>**</b> XX | : | Hexadecimal value of a word or byte generated at LLLL location |
| A                    | : | When present, the reference is forward                         |
| \$\$\$\$             | : | Source text line                                               |

Format of an assembly listing line

## 1-2. OBJECT LISTING

In addition to the hexadecimal representation of the object code and the edition of the corresponding source text, the Assembler provides :

- A list of defined and/or referenced segments names, except under MITRAS I.
- A table of satisfied or unsatisfied labels per section (optional).

## 1-2. OBJECT LISTING

In addition to the hexadecimal representation of the object code and the edition of the corresponding source text, the Assembler provides :

- A list of defined and/or referenced segments names, except under MITRAS 1.
- A table of satisfied or unsatisfied labels per section (optional).

## II - OPERATING OPTIONS

II-1. MITRAS I

Command format

%ASS 1/options indicated on console switches (M:OC).

Options

Assembly listing :

- requested : console switch 15 reset

- omitted : console switch 15 set

Relocatable binary :

- requested : console switch 14 reset

- omitted : console switch 14 set

Output of an additional %EOD after the RB module :

- requested : console switch 13 reset

- omitted : console switch 13 set

## 11-2. MITRAS II

Command format

%ASS2 %CALL/ASS2/[SI][,BO] [,LO][,LL]

%ASS2/ Output on M:OC by the processor when loaded and started by %LOAD and %RUN.

%CALL/ASS2/ Output on M:OC by the processor when started without console interrupt. In this case, options are given on M:OC.

Under control of the linking module, the command and its options are entered via M:CI.

## Options

- Source file read on M:SI. When this option is omitted, no other option should be present, and all options are implicit.
- BO : Relocatable binary output requested.
- LO : Assembly listing output requested.
- LL : Label table printing requested, together with severity level and number of incorrect lines.

• Option for assembly end

When MITRAS II is loaded and started through a %LOAD and a %RUN, before returning to the beginning when the assembly is over, the following message is printed on M:OC :

%%EOD?

Meaning that the optional output of an additional "end-of-file" mark after the RB has been allocated.

The operator's answer on M:OC may be :

- OUI if the additional "end-of-file" mark is requested.
- NON if the additional "end-of-file" mark is not requested.
- Additional "end-of-file"

When a program module has been assembled, the relocatable binary output may have one of the following format :



- where E.O.F. stands for "end-of-file".

This is necessary for establishing the RB input file of the Linkage Editor. This file is organized as follows :



The Linkage Editor may then output a RMI file with the following format :

| Heading | File | E<br>O<br>F | E<br>O<br>F |  |
|---------|------|-------------|-------------|--|
|         |      | Г           | Г           |  |

111-2. TABLE FORMAT

111-2.1. Local label table

A table containing the local labels is printed after every LPS, before FIN pseudo-instruction. It has the following format :

LABE LLLL Z

- LABE : Label name.

- LLLL : Corresponding value of location counter or label reference number if it has not yet defined.

-Z : D = LDS label

- P = LPS label
  - A = Label value is absolute
  - X = Label not yet defined
  - R = Label declared in a REF pseudo-instruction

#### 111-2.2. Common label table

When the module assembly is completed, after END pseudo-instruction, a table of common labels is printed.

It has the following format :

LABE LLLL Z

- LABE : Label name

- LLLL : Corresponding value of location counter or label reference number if it has not yet been defined.

-Z : C = CDS label

- D = LDS label (declared in a DEF of the CDS and defined in a LDS).
- P = LPS label (declared in a DEF of the CDS and defined in a LPS).
- A = Label value is absolute
- X = Label not yet defined
- R = Label declared in a REF

#### 111-2.3. Severity level

After the common label table, MITRAS I outputs the following message :

$$NSV \begin{cases} 0\\1\\2\\3 \end{cases} \qquad NB ERR XXX$$

Indicating the highest error level encountered during assembly and the number of incorrect lines.

#### III-3. ERROR PROCESSING

#### III-3.1. Definition of assy error level

Four error levels will be considered :

- LEVEL 0 : No error or presumed error during assembly.
- LEVEL 1 : At least one presumed error. Linkage edition and program execution are possible.
- LEVEL 2 : Confirmed error for which the assembler has selected an option. Link edition is possible, but the edited program cannot be correctly executed in most cases without %MODIFY cards.
- LEVEL 3 : Major error. The assembly continues but linkage edition will be impossible. The source program must be corrected and re-assembled.

As a general rule, any level-3 error impedes link edition.

#### 111-3.2. List of errors detected during assembly

The incorrect source line is printed with 1 or 2 leading characters which identify the type of error.

Two error flags are set, at most.

- D : Double definition of a label. The first definition is assumed right.
- E : Syntactic or semantic error in operand field of an instruction or pseudo-instruction.
- For an instruction, the operand is ignored, the corresponding zone being cleared.
- For a segmentation pseudo, the operand field of the source card is ignored.

- For an EQU, the label becomes equivalent to an absolute zero value.

- For GOTO and DO pseudos, the operand field is ignored.

- For a TEXT pseudo, the operand field is ignored after the error (downstream).

- For a <u>DATA</u> pseudo, if the error affects the definition of the selected resolution, a DATA 0 will be generated by the Assembler.

If the error affects the operand field, the latter is ignored after the error (downstream).

- For a <u>GEN</u> pseudo, an error in the partitioning of the selected areas will cause a zero-word to be generated.

An error in the operand field stops the scanning of the card. However, everything upstream the error is normally taken into consideration.

- F : Incorrect expression in operand part of RES pseudo : a zero-word is generated.
- G : Negative variable address.
  - Address > 255

- Calculated displacement exceeding the available number of bits.

In all cases, incorrect value replaced by zero.

- I : Command unknown to the Assembler : replaced by RES 1.
  - Instruction or pseudo forbidden in this segment : the command is ignored.
  - No asterisk between operand and comment field.
- J : Forbidden character in this label : label ignored.
  - Mandatory label absent for a segmentation pseudo in the RB : label replaced by zero.
  - Label forbidden in this pseudo (BASE, BND, FIN, ...) : label ignored.
  - No label for an EQU : card ignored.
- N : Label table overflow.
- O: For a DATA, the result of an expression overflows the assigned partitions : result truncated.
   Discrepancy between the number of expressions and the number of partitions in a GEN.
- P : Location counter overflow (>65 535).
- R : A %EOD group met before the END card.
- T : Multiple definition of a segment.
- X : At the time a word is generated, the location counter value is odd. A zero-byte is first generated to increment the counter to a word boundary. If the source line includes a label, the corresponding value taken is the initial value of the location counter and not the corrected value.
- V : The currently assembled source line contains a forward branch whose reach cannot be checked because the forward branch control table is full.
- W : The currently assembled source line has a label to which one or several forward branches have been made.

Among these branches, at least one has a reach exceeding 255.

111-3.3. Distribution of error types on the levels

- Level O
- Level 1 : V-C
- Level 2 : D-E-F-G-I-J-O-T-W-X
- Level 3 : I-N-P-R

## Appendix C – Addressing modes

## 1) Class 0 addressing

Instructions of this type may only address any data in the local or common segments. Class 0' Prohibits parameter or immediate addressing.

This class includes :

- Load and store instructions
- Arithmetic instructions (fixed- or floating-point)
- Logical operations
- Byte string instructions
- Comparison instructions

Six addressing modes are allowed :

| Mode                              | Assembly<br>language    | Addressed data                                                                                                                     | Addressing function |
|-----------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| Direct, Local<br>DL               | IDENT                   | Byte, word or double-word<br>located in the first 256 bytes of<br>the local segment.                                               | Y=(L)+D             |
| Indirect, Local<br>IL             | aIDENT                  | Byte, word or double-word<br>located anywhere and pointed<br>at through the local segment.                                         | Y=G'+((L)+D)        |
| Indirect, Local, Indexed<br>ILX   | ∂IDENT,X                | Element of a byte, word or<br>double-word array located<br>anywhere and pointed at through<br>the local segment.                   | Y=G'+((L)+D)+(X)    |
| Direct, General<br>DG             | ₩ IDENT                 | Byte, word or double-word<br>located in the first 256 bytes of<br>the common segment.                                              | Y=(G)+D             |
| Indirect, General, Indexed<br>IGX | <sup>©</sup> ₩ IDENT, X | Element of an array pointed at through the common segment.                                                                         | Y=(G)+((G)+D)+(X)   |
| Parameter or immediate            | =OPERAND                | A 1-byte operand is specified<br>in the instruction. This byte may<br>be extended on the left by 8<br>leading zeroes, if required. | (Y) = D<br>Y = (P)  |

2) Class 1 addressing

These instructions are :

- Either without operand : register swapping, end of section, etc.,

- Or instructions whose operand is generally known (possibly through an unknown modifier) at program writing time : shift, index, increment, etc.

This class includes :

- Shift instructions
- Base instructions
- Section or supervisor calls
- I/O instructions
- Inter-register operations
- Interrupt-initiated and interrupt mask instructions.

Three addressing modes are allowed :

| Mode                        | Assembly<br>language | Operand                                                         | Addressing function  |
|-----------------------------|----------------------|-----------------------------------------------------------------|----------------------|
| Parameter or immediate<br>P | =PARAM               | Operand defined by displacement value.                          | (Y) = D<br>Y = (P)   |
| Parameter, Indexed<br>PX    | =PARAM,X             | Operand defined by value plus<br>X-register contents.           | (Y)=D+(X)<br>Y = (P) |
| Direct, Local<br>DL         | IDENT                | Operand located in the first<br>256 bytes of the local segment. | Y=(L)+D              |

## 3) Class 2 addressing

This class includes conditional and unconditional branch instructions.

Normally the instructions which are pointed at by a branch instruction belong to the same section.

Four addressing modes are allowed :

| Mode                             | Assembly<br>language | Branch instruction                                     | Addressing function |
|----------------------------------|----------------------|--------------------------------------------------------|---------------------|
| Relative downstream<br>(plus) RP | LA BE L              | Any instruction within<br>512 bytes downstream         | Y=(P)+2D            |
| Relative upstream<br>(minus) RM  | LABEL                | Any instruction within<br>512 bytes upstream           | Y=(P)-2D            |
| Indirect, Local<br>IL            | <sup>ଇ</sup> LABEL   | Any instruction pointed at through the local segment.  | Y=G '+((L)+D)       |
| Indirect, General<br>iG          | ື #LABEL             | Any instruction pointed at through the common segment. | Y=G'+((G)+D)        |

RC : 669805764 B R.C. Versailles – SIRENE : 669805764

Siège Social Direction Commerciale Division des Petits Ordinateurs et des Applications Spécialisées Direction Après-Vente 68, Route de Versailles 78430 Louveciennes Tél. 954 9080

#### Direction Générale Institut de Formation Parc de Rocquencourt 78150 Le Chesnay Tél. 954 4400 Centre de Vélizy Division Militaire Spatiale et Aéronautique Direction Après-Vente 10 - 12 avenue de l'Europe 78140 Vélizy Tél. 946 9670

DÉLÉGATIONS RÉGIONALES

RHONE-ALPES . 177, rue Garibaldi Immeuble M + M 69003 Lyon Tél. (78) 62 9065

Tour Mont Blanc 15, bd. du Maréchal Leclerc 38000 Grenoble Tél. (76) 44 9922

18-20 av. du Maréchal Foch 21000 Dijon Tél. (80) 32 2047

•

OUEST 3 Place du Colombier 35000 Rennes Tél. (99) 30 8454 CENTRE-OUEST 9, place Rouget de Lisle 37000 Tours Tél. (47) 20 2209 MIDI-PYRÉNÉES Av. du Général Eisenhower

AV. du General Elsennower 31023 Toulouse Tél. (61) 40 3563 Centre des Clayes-sous-bois Avenue Jean Jaurès 78340 Les Clayes-sous-bois Tél. 055 8000

Centre de Toulouse Avenue du Général Eisenhower 31023 Toulouse Tél. (61) 40 1140.

SUD-EST 433, rue Paradis 13008 Marseille Tél. (91) 77 0994

AQUITAINE 353, bd du Président Wilson 33200 Bordeaux Tél. (56) 08 6363 EST 25, avenue Robert Schuman 57000 Metz Tél. (87) 68 4921 2

15. rue des Francs Bourgeois 67000 Strasbourg Tél. (88) 32 1103

NORD 13, boulevard de la Liberté 59000 Lille Tél. (20) 57 7353