# MARK 5/9 $\begin{gathered}\text { Reference } \\ \text { Manual }\end{gathered}$ 




POINT 4 ${ }^{\text {TM }}$ MARK 5/9 COMPUTER REFERENCE MANUAL

Revision 01

## NOTICE

Every attempt has been made to make this reference manual complete, accurate and up-to-date. However, all information herein is subject to change due to updates. All inquiries concerning this manual should be directed to POINT 4 Data Corporation.

Copyright © 1986 by POINT 4 Data Corporation (formerly Educational Data Systems, Inc). Printed in the United States of America. All rights reserved. No part of this work covered by the copyrights hereon may be reproduced or copied in any form or by any means--graphic, electronic, or mechanical, including photocopying, recording, taping, or information and retrieval systems--without the prior written permission of:

POINT 4 Data Corporation
15442 Del Amo Avenue
Tustin, CA 92680
(714) 259-0777

## REVISION RECORD

## PUBLICATION NUMBER: HM—085-0023

## Revision Description Date

01 Complete revision of original POINT 4 User Reference Manual incorporating information concerning the MARK 5, MARK 5 with EIS, and MARK 9 ( 61000 Assembly Series CPU Boards)

## LIST OF EFFECTIVE PAGES

Changes, additions, and deletions to information in this manual are indicated by vertical bars in the margins or by a dot near the page number if the entire page is affected. A vertical bar by the page number indicates pagination rather than content has changed. The effective revision for each page is shown below.

## Page

Rev
Page
Rev
Page
Rey

| Cover | - |
| :--- | :---: |
| Title | 01 |
| ii thru xv | 01 |
| l-1 thru 1-20 | 01 |
| $2-1$ thru $2-22$ | 01 |
| $3-1$ thru $3-29$ | 01 |
| $4-1$ thru $4-37$ | 01 |
| 5-1 thru $5-41$ | 01 |
| 6-1 thru $6-23$ | 01 |
| $7-1$ thru $7-30$ | 01 |
| 8-1 thru 8-9 | 01 |
| Appendix Title | - |
| A-1 | 01 |
| B-1 | 01 |
| C-1 | 01 |
| D-1, D-2 | 01 |
| E-1 thru E-9 | 01 |
| F-1 thru G-4 | 01 |
| G-1 thru |  |
| H-1, H2 | 01 |
| Index-1 thru |  |
| Index-9 | 01 |
| Comment Sheet | 01 |
| Mailer |  |
| Back Cover | - |

## PREFACE

This is a reference manual for the POINT 4 MARK 5 and MARK 9 Computers. These computers are l6-bit, high-speed, general-purpose minicomputers.

The introduction describes POINT 4 MARK 5 and MARK 9 standard features and system architecture. It also provides detailed information on equipment and performance characteristics.

Step-by-step directions for installation and detailed operating procedures are provided. A section describing input/output interfaces is included.

Separate sections describe the POINT 4 MARK 5 and MARK 9 standard and extended instruction sets. The next section describes stack, hardware multiply/divide, and mapped memory instructions for the POINT 4 MARK 9 Computer. Optional features are discussed fully in the final section.

The appendices include pertinent information on POINT 4 MARK 5/9 instructions, and offer programming examples.

Related manuals include:

Title
POINT 4 (MARK 5) Diagnostics Manual MIGHTY MUX User Manual
MIGHTY MUX Diagnostics Manual
Cassette Tape Unit Hardware Manual LOTUS Controllers User Manual
LOTUS Cache Memory Hardware Manual MARK 9 CPU Diagnostics Document MARK 8 Verifier/Diagnostics Document MARK 5/9 Lowboy Computer System Unpacking and Installation Tech Memo MARK 5/9 Highboy Computer System Unpacking and Installation Tech Memo

## Pub. Number

HM-080-0014
HM-042-0015
HM-042-0007
HM-130-0017
HM-120-0033
HM-160-0026
HTP0041
HTPOO 47

## CONTENTS

Section Page
1 INTRODUCTION ..... 1-1
1.1 GENERAL DESCRIPTION ..... 1-1
1.1 .11.1 .21.1. 31.1 .41.2
1.31.3.11.3.1.11.3.1. 21.3.1.31.3.1.41.3.1.51.3.2
2INSTALLATION2-1
2.1 ENVIRONMENTAL REQUIREMENTS ..... 2-12.1 .12.1.22.1.32.22.2.12.2.2
Power Requirements ..... 2-1
Temperature Requirements ..... 2-1
Enclosure Requirements ..... 2-1
UNPACKING INSTRUCTIONS ..... 2-2
Unpacking the Cartons ..... 2-2
Container Contents ..... 2-2
PROCESSOR AND POWER SUPPLY MOUNTING ..... 2-5
Front Panel ..... 2-5
Chassis ..... 2-5
Printed Circuit Boards ..... 2-7
Power Supply Cabling ..... 2-9
POWERING UP THE SYSTEM ..... 2-12
Grounding ..... 2-13
2.4.2 Battery Shelf-Life ..... 2-13

| 2.5 | DIAGNOSTIC CHECKS | 2-14 |
| :---: | :---: | :---: |
| 2.5.1 | Normal Self-Test Operation | 2-15 |
| 2.5.2 | How to Interpret a Halt | 2-17 |
| 2.5.3 | Self-Test as a Continuous Reliability Test | 2-17 |
| 2.6 | UNIVERSAL CPU BOARD INSTALLATION | 2-18 |
| 2.6.1 | Universal CPU Board Voltage Requirements | 2-18 |
| 2.6.2 | Reserved Backplane Pins | 2-19 |
| 2.6.3 | Universal CPU Board Data Channel and Interrupt Priority Chains | 2-19 |
| 2.7 | OPERATOR CONTROL UNIT INSTALLATION | 2-20 |
| 2.7 .1 | Attachment to the Processor Front Panel | 2-20 |
| 2.7.2 | Connection Via Ribbon Cable | 2-20 |
| 3 | OPERATING PROCEDURES | 3-1 |
| 3.1 | INTRODUCTION | 3-1 |
| 3.2 | POWER SUPPLY INDICATOR PANEL | 3-1 |
| 3.3 | PROCESSOR MINI-PANEL | 3-4 |
| 3.3 .1 | Mini-Panel Operating Functions | 3-4 |
| 3.3.1.1 | Power Controls and Indicators | 3-6 |
| 3.3.1.1.1 | 1 Power Controls | 3-6 |
| 3.3.1.1.2 | Power Indicator Interpretations without Battery Backup | 3-7 |
| 3.3.1.1.3 | Power Indicator Interpretations with Battery Backup | 3-8 |
| 3.3.2 | Processor Operation Monitoring Indicators | 3-9 |
| 3.3 .3 | Program Execution Controls | 3-9 |
| 3.4 | OPERATOR CONTROL UNIT (OPTIONAL) | 3-11 |
| 3.4 .1 | Operator Control Unit Capabilities | 3-11 |
| 3.4 .2 | CPU State Indicators | 3-11 |
| 3.4 .3 | Octal Displays | 3-14 |
| 3.4 .4 | Data Entry and Processor Manipulation Controls | 3-15 |
| 3.5 | VIRTUAL CONTROL PANEL | 3-20 |
| 3.5 .1 | Addressing Modes | 3-22 |
| 3.5 .2 | Command Descriptions | 3-23 |
| 4 | INPUT/OUTPUT INTERFACES | 4-1 |
| 4.1 | INTRODUCTION | 4-1 |
| 4.2 | PROGRAM INTERRUPT AND PRIORITY SCHEME | 4-1 |
| 4.2.1 | Interrupt Sequence | 4-2 |
| 4.2.2 | Device Priority | 4-2 |
| 4.3 | PROGRAMMED TRANSFERS | 4-3 |
| 4.3 .1 | Master Terminal Interface | 4-3 |
| 4.3.2 | Programming Conventions | 4-4 |
| 4.3.2.1 | Instruction Formats | 4-4 |
| 4.3.2.2 | Terminal Output | 4-4 |
| 4.3.2.3 | Terminal Input via CRT Keyboard | 4-5 |
| 4.3.2.4 | Terminal Input via Paper Tape Reader | 4-5 |


| 4.4 | DATA CHANNEL TRANSFERS | 4-6 |
| :---: | :---: | :---: |
| 4.4 .1 | Selection of Data Channel Speed | 4-7 |
| 4.4 .2 | Criterion for Data Channel Speed Selection | 4-7 |
| 4.4 .3 | Data Channel Access Priorities | 4-7 |
| 4.5 | INPUT/OUTPUT BUS INTERFACE SIGNALS | 4-8 |
| 4.5 .1 | Input/Output Interface Signals | 4-8 |
| 4.5 .2 | Backplane Pin Signal Connectors | 4-16 |
| 4.6 | INPUT/OUTPUT TIMING | 4-19 |
| 4.6 .1 | Programmed I/O Instruction Timing | 4-19 |
| 4.6.1.1 | Data In | 4-19 |
| 4.6.1.2 | Data Out | 4-19 |
| 4.6 .2 | Program Interrupt Timing | 4-23 |
| 4.6 .3 | Data Channel Transfer Timing | 4-27 |
| 4.7 | INPUT/OUTPUT CONNECTORS | 4-34 |
| 4.7 .1 | Power Connectors | 4-34 |
| 4.7 .2 | External I/O Device Connector | 4-34 |
| 4.7 .3 | Master Terminal Connector | 4-37 |
| 5 | STANDARD INSTRUCTION SET | 5-1 |
| 5.1 | INTRODUCTION | 5-1 |
| 5.2 | OCTAL REPRESENTATION AND TWO'S COMPLEMENT NOTATION | 5-1 |
| 5.3 | INSTRUCTION TYPES | 5-3 |
| 5.4 | MEMORY REFERENCE INSTRUCTIONS | 5-5 |
| 5.4 .1 | Memory Addressing | 5-5 |
| 5.4.1.1 | Indexing Mode | 5-7. |
| 5.4.1.2 | Indirect Addressing Operations | 5-8 |
| 5.4.1.3 | Automatic Incrementing and Decrementing of Locations | 5-9 |
| 5.4 .2 | Types of Memory Reference Instructions | 5-10 |
| 5.4.2.1 | Move Data Instructions | 5-10 |
| 5.4.2.2 | Jump and Modify Memory Instructions | 5-11 |
| 5.4.2.3 | Assembler Language Conventions and |  |
|  | Addressing Examples | 5-12 |
| 5.5 | ARITHMETIC/LOGIC INSTRUCTION GROUP | 5-14 |
| 5.5.1 | Arithmetic/Logic Processing | 5-14 |
| 5.5.1.1 | Arithmetic/Logic Operations | 5-16 |
| 5.5.1.2 | Overflow and Carry-Out Operations | 5-17 |
| 5.5 .2 | Arithmetic/Logic Functions | 5-20 |
| 5.5 .3 | Secondary Functions | 5-21 |
| 5.5.3.1 | Shift Field (SH) | 5-21 |
| 5.5.3.2 | Carry Control Field (CY) | 5-22 |
| 5.5.3.3 | No-Load Field (NL) | 5-22 |
| 5.5.3.4 | Skip Control Field (SK) | 5-23 |
| 5.5 .4 | Assembler Language Conventions and Examples | 5-24 |
| 5.6 | INPUT/OUTPUT INSTRUCTION GROUP | 5-26 |
| 5.6 .1 | Regular I/O Instructions | 5-26 |
| 5.6.1.1 | I/O Transfer and Device Control Instructions | 5-28 |
| 5.6.1.2 | I/O Skip Instructions | 5-31 |
| 5.6 .1 .3 | Assembler Language Conventions and Examples | 5-32 |
| 5.6 .2 | Special Code 77 (CPU) Instructions | 5-34 |
| 5.6 .2 .1 | Assembler Language Conventions | 5-37 |
| 5.7 | INSTRUCTION EXECUTION TIMES | 5-38 |

6.1 INTRODUCTION 6-1

### 6.2 ENABLING/DISABLING EXTENDED INSTRUCTION SET 6-2

## 6.2 .1

6.3
6.3 .1
6.3.2
6.3.2.1
6.3 .3
6.3 .4
6.3 .5
6.3 .6
6.3 .7
6.3 .8
6.3 .9
6.3 .10
6.3 .11
6.3 .12

7
7.1
7.2
7.3
7.3 .1
7.3.2
7.3.3
7.3.4
7.3 .5
7.3.6
7.3.7
7.3.8
7.4
7.4 .1
7.5
7.5.1
7.5.2
7.5.3
7.5.4
7.5 .5
7.5.6
7.5 .7
7.5 .8
7.5.9
7.6

EXTENDED INSTRUCTION IMPLEMENTATION 6-3
Page Zero Locations 6-4
Immediate Compare Instructions 6-5
Other Immediate Operations 6-6
Bit Manipulation and Test Instructions 6-7
Bit Test Instruction Combinations 6-9
POINT 4 EIS Stack Instructions 6-10
Nybble Manipulation Instructions 6-13
Extended Load and Store Instructions 6-15
Vectored Jump to Subroutine Instruction 6-16
Byte Access Instructions 6-17
Binary Multiply and Divide Instructions 6-20
Move and Search Instructions 6-21
Trace Instruction 6-23

MARK 9 EXCLUSIVE INSTRUCTIONS 7-1
INTRODUCTION 7-1
HARDWARE MULTIPLY AND HARDWARE DIVIDE 7-2
STACK OPERATION 7-3
Push Accumulator 7-5
Pop Accumulator 7-5
Save 7-6
Move to Stack Pointer 7-8
Move to Frame Pointer 7-8
Move from Stack Pointer 7-9
Move from Frame Pointer 7-9
Return 7-10
MAPPED MEMORY OPERATION 7-12
Device Interrupt Processing 7-12
MEMORY MAP INSTRUCTIONS 7-13
Load Map 7-14
Initiate Page Check 7-16
Page Check 7-18
Read Map Status 7-20
Write Map Status 7-22
Map Single Cycle 7-24
Clear Map 7-24
Load Map Memory from Main Memory 7-25
Load Main Memory from Map Memory 7-27
TRAP INSTRUCTION 7-29
8 OPTIONAL FEATURES ..... 8-1
8.1 INTRODUCTION ..... 8-1
8.2 BATTERY BACKUP ..... 8-1
8.2 .1 Battery Backup Voltages ..... 8-2
8.2 .2 Power Monitor Auto-Restart Handling ..... 8-3
8.3 OPERATOR CONTROL UNIT (OCU) ..... 8-4
8.4 VOLTAGE REGULATOR ..... 8-4
8.5 MICRO-PROGRAMMED FLOATING POINT UNIT ..... 8-5
8.5.1 MFPU Formats ..... 8-5
8.5 .2 MFPU Commands ..... 8-6
8.5 .3 Oper and Addressing ..... 8-7
8.5 .4 Overflow and Underflow ..... 8-8
8.5 .5 Enabling and Disabling ..... 8-8
8.6 256K WORD MEMORY ..... 89

## APPENDICES

VON NEUMANN MAP OF POINT 4 MARK 5/9 STANDARD A-1
INSTRUCTIONS
B POINT 4 MARK 5/9 STANDARD INSTRUCTION REFERENCE CHARTB-1
C ASCII CODE CHART ..... C-1
D VIRTUAL CONTROL PANEL COMMANDS (MANIP) ..... D-1
E PROGRAMMING EXAMPLES ..... E-1
F OCTAL VALUES FOR EXTENDED INSTRUCTIONS ..... F-1
G EXECUTION TIMES FOR EXTENDED INSTRUCTIONS ..... G-1
H VON NEUMANN CHART OF EXTENDED INSTRUCTIONS ..... H-1

## FIGURES

| Number | Title | Page |
| :---: | :---: | :---: |
| 1-1 | POINT 4 MARK 5 Computer | 1-2 |
| 1-2 | POINT 4 MARK 9 Computer | 1-2 |
| 1-3 | Typical POINT 4 MARK 5/9 Computer System Configuration | 1-10 |
| 1-4 | POINT 4 MARK 5/9 Computer System Block Diagram | 1-11 |
| 1-5 | POINT 4 MARK $5 \mathrm{CPU} / \mathrm{Memory} \mathrm{Block} \mathrm{Diagram}$ | 1-13 |
| 1-6 | POINT 4 MARK 9 CPU/Memory Block Diagram | 1-14 |
| 1-7 | Operator Control Unit | 1-16 |
| 1-8 | POINT 4 MARK 5/9 Power Supply Block Diagram | 1-19 |
| 2-1 | POINT 4 MARK 5/9 Processor Chassis Packaging | 2-3 |
| 2-2 | POINT 4 MARK 5/9 Power Supply Packaging | 2-4 |
| 2-3 | Processor Chassis and Power Supply Chassis Mounting Slots | 2-6 |
| 2-4 | Typical Computer Chassis Configuration | 2-8 |
| 2-5 | Processor Chassis Backplane Connector Mounting Positions | 2-10 |
| 2-6 | Power Supply Chassis Rear Connector Mounting Positions | 2-11 |
| 2-7 | POINT 4 MARK 5/9 Self-Test Switch Location | 2-16 |
| 2-8 | Operator Control Unit Attachment to Front Panel | 2-21 |
| 2-9 | Operator Control Unit Remote Attachment | 2-22 |
| 3-1 | Power Supply Indicator Panel | 3-2 |
| 3-2 | POINT 4 MARK 5/9 Processor Mini-Panel | 3-5 |
| 3-3 | Operator Control Unit Controls and Indicators | 3-12 |
| 4-1 | Data Word Transfer Between Specified Accumulator and I/O Device Buffer | 4-3 |
| 4-2 | Input/Output Signal Diagram | 4-10 |
| 4-3 | Backplane I/O Signals | 4-17 |
| 4-4 | Programmed I/O Instruction Timing for MARK 5 | 4-20 |
| 4-5 | Programmed I/O Instruction Timing for MARK 5 with EIS | 4-21 |
| 4-6 | Programmed I/O Instruction Timing for MARK 9 | 4-22 |
| 4-7 | Inter rupt Timing for MARK 5 | 4-24 |
| 4-8 | Interrupt Timing for MARK 5 with EIS | 4-25 |
| 4-9 | Interrupt Timing for MARK 9 | 4-26 |
| 4-10 | Standard Data Channel Timing for MARK 5 | 4-28 |
| 4-11 | Standard Data Channel Timing for MARK 5 with EIS | 4-29 |
| 4-12 | Standard Data Channel Timing for MARK 9 | 4-30 |
| 4-13 | High-Speed Data Channel Timing for MARK 5 | 4-31 |
| 4-14 | High-Speed Data Channel Timing for MARK 5 with EIS | 4-32 |
| 4-15 | High-Speed Data Channel Timing for MARK 9 | 4-33 |
| 4-16 | Input/Output Connector Locations | 4-35 |


| 5-1 | POINT 4 MARK 5/9 16-Bit Binary Word Format | 5-1 |
| :---: | :---: | :---: |
| 5-2 | POINT 4 MARK 5/9 Instruction Format Summary | 5-4 |
| 5-3 | Jump and Modify Memory Instruction Binary Word Format | 5-5 |
| 5-4 | Move Data Instruction Binary Word Format | 5-5 |
| 5-5 | Arithmetic/Logic Instruction Format | 5-14 |
| 5-6 | Arithmetic/Logic Operations | 5-15 |
| 5-7 | Overflow and Carry Operations Analysis for Signed Integers | 5-19 |
| 5-8 | Input/Output Instruction Format | 5-26 |
| 5-9 | CPU-I/O Device Input/Output Functions | 5-27 |
| 6-1 | NOP Skip Command Format | 6-3 |
| 6-2 | Binary Format for Immediate Compare Instructions | 6-5 |
| 6-3 | Binary Format for Other Immediate Operations | 6-6 |
| 6-4 | Binary Format for Bit Manipulation and Test Instructions | 6-8 |
| 6-5 | Binary Format for Bit Test Instruction Combinations | 6-9 |
| 6-6 | Stack Organization for New Registers | 6-10 |
| 6-7 | Binary Format for New Register Instructions | 6-12 |
| 6-8 | Binary Format for Nybble Manipulation Instructions | 6-14 |
| 6-9 | Binary Format for Extended Load and Store Instructions | 6-15 |
| 6-10 | Binary Format for Vectored Jump to Subroutine Instruction | 6-16 |
| 6-11 | Binary Format for Byte Access Instructions | 6-19 |
| 6-12 | Binary Format for Binary Multiply and Divide Instructions | 6-20 |
| 6-13 | Binary Format for Move and Search Instructions | 6-22 |
| 6-14 | Binary Format for Trace Instruction | 6-23 |
| 7-1 | Hardware Multiply Instruction Format | 7-2 |
| 7-2 | Hardware Divide Instruction Format | 7-2 |
| 7-3 | Push Accumulator Instruction Format | 7-5 |
| 7-4 | Pop Accumulator Instruction Format | 7-5 |
| 7-5 | Save Instruction Format | 7-6 |
| 7-6 | Move to Stack Pointer Instruction Format | 7-8 |
| 7-7 | Move to Frame Pointer Instruction Format | 7-8 |
| 7-8 | Move from Stack Pointer Instruction Format | 7-9 |
| 7-9 | Move from Frame Pointer Instruction Format | 7-9 |
| 7-10 | Return Instruction Format | 7-10 |
| 7-11 | Load Map Instruction Format | 7-14 |
| 7-12 | Accumulator Format for Load Map Instruction | 7-14 |
| 7-13 | Initiate Page Check Instruction Format | 7-16 |
| 7-14 | Accumulator Format for Initiate Page Check Instruction | 7-16 |
| 7-15 | Page Check Instruction Format | 7-18 |
| 7-16 | Accumulator Format for Page Check Instruction | 7-18 |
| 7-17 | Read Map Status Information Format | 7-20 |
| 7-18 | Accumulator Format for Read Map Status Instruction | 7-20 |
| 7-19 | Write Map Status Instruction Format | 7-22 |
| 7-20 | Accumulator Format for Write Map Status Instruction | 7-22 |


| 7-21 | Map Single-Cycle Instruction Format | 7-24 |
| :---: | :---: | :---: |
| 7-22 | Clear Map Instruction Format | 7-24 |
| 7-23 | Load Map Memory from Main Memory Instruction Format | 7-25 |
| 7-24 | Table Format for Load Map Memory from Main Memory Instruction | 7-25 |
| 7-25 | Load Main Memory from Map Memory Instruction Format | 7-27 |
| 7-26 | Table Format for Load Main Memory from Map Memory Instruction | 7-27 |
| 7-27 | Trap Instruction Format | 7-29 |
| 8-1 | MFPU Formats | 8-5 |
| E-1 | Conditions Under Which Each of the BASIC Arithmetic Test Conditions Will Skip | E-2 |
| E-2 | The 20 Different Sets of Numbers Which Can Be Tested with a Single Instruction | E-3 |
| E-3 | How to Test for Any Bit in a Word | E-4 |
| E-4 | Master Terminal I/O Programming Examples | E-6 |

## TABLES

| Number | Title | Page |
| :---: | :---: | :---: |
| 3-1 | Power Supply Panel Indicators | 3-3 |
| 3-2 | Processor Mini-Panel Power Control Switch Settings | 3-6 |
| 3-3 | Power Indicator Interpretations without Battery Backup | 3-7 |
| 3-4 | Power Indicator Interpretations with Battery Backup | 3-8 |
| 3-5 | Processor Operation Monitoring Indicators | 3-9 |
| 3-6 | Program Execution Controls | 3-10 |
| 3-7 | CPU Operation Indicators | 3-13 |
| 3-8 | OCU Memory Access Controls | 3-16 |
| 3-9 | OCU Accumulator Access Controls | 3-17 |
| 3-10 | OCU Program Execution Controls | 3-18 |
| 3-11 | MANIP Command Functions and Parameters | 3-21 |
| 3-12 | MANIP Command Descriptions | 3-23 |
| 4-1 | Input/Output Bus Signal Classifications | 4-9 |
| 4-2 | Input/Output Signals | 4-11 |
| 4-3 | External I/O Device Connector Pin Assignments | 4-36 |
| 4-4 | Master Terminal Interface Pin Assignments | 4-37 |
| 5-1 | Memory Reference Instructions | 5-6 |
| 5-2 | Indexing Modes | 5-7 |
| 5-3 | Move Data Instructions | 5-10 |


| 5-4 | Jump and Modify Memory Instructions | 5-11 |
| :---: | :---: | :---: |
| 5-5 | Assembler Language Conventions for Memory |  |
|  | Reference Instructions | 5-13 |
| 5-6 | Arithmetic/Logic Functions | 5-20 |
| 5-7 | Shift Field Definitions | 5-21 |
| 5-8 | Carry Control Field | 5-22 |
| 5-9 | Skip Control Field | 5-23 |
| 5-10 | Assembler Language Conventions for Arithmetic and Logic Instructions | 5-25 |
| 5-11 | I/O Transfer Type Specification | 5-29 |
| 5-12 | Control Field Specification | 5-30 |
| 5-13 | I/O Skip Instructions | 5-31 |
| 5-14 | Assembler Language Conventions for Input/Output Instructions | 5-33 |
| 5-15 | Special CPU Instructions | 5-35 |
| 5-16 | Conditional skip Instructions | 5-37 |
| 5-17 | Instruction Execution Times for MARK 5 | 5-39 |
| 5-18 | Instruction Execution Times for MARK 5 with EIS | 5-40 |
| 5-19 | Instruction Execution Times for MARK 9 | 5-41 |
| 6-1 | Immediate Compare Instructions | 6-5 |
| 6-2 | Other Immediate Operations | 6-6 |
| 6-3 | Bit Manipulation and Test Instructions | 6-8 |
| 6-4 | Bit Test Instruction Combinations | 6-9 |
| 6-5 | Instructions Used for New Registers | 6-11 |
| 6-6 | Nybble Manipulation Instructions | 6-13 |
| 6-7 | Extended Load and Store Instructions | 6-1.5 |
| 6-8 | Byte Access Instructions | 6-18 |
| 6-9 | Binary Multiply and Divide Instructions | 6-20 |
| 6-10 | Move and Search Instructions | 6-21 |
| 7-1 | 32 K -Word Mode Stack Return Block Destinations | 7-6 |
| 7-2 | 64K-Word Mode Stack Return Block Destinations | 7-7 |
| 7-3 | 32 K -Word Mode Return Destinations | 7-10 |
| 7-4 | 64 K -Word Mode Return Destinations | 7-11 |
| 7-5 | Accumulator Functions for Load Map Instruction | 7-15 |
| 7-6 | Accumulator Functions for Initiate Page Check Instruction | 7-17 |
| 7-7 | Accumulator Functions for Page Check Instruction | 7-19 |
| 7-8 | Accumulator Functions for Read Map Status Instruction | 7-21 |
| 7-9 | Accumulator Functions for Write Map Status Instruction | 7-23 |
| 7-10 | Table Functions for Load Map Memory from Main Memory Instruction | 7-26 |
| 7-11 | Table Functions for Load Main Memory from Map Memory Instruction | 7-28 |
| 7-12 | Trap Instruction Functions | 7-29 |
| 8-1 | MFPU Commands | 8-6 |
| 8-2 | MFPU Command Formats | 8-7 |
| 8-3 | Error Overflow | 8-8 |

## Section 1 INTRODUCTION

### 1.1 GENERAL DESCRIPTION

The POINT 4 MARK 5 and MARK 9 computers are l6-bit, high-speed, general-purpose minicomputers with versatile instruction sets. These POINT 4 computers employ a novel design architecture (Microprogrammed Sequencer*) to achieve the simplicity and flexibility of microprogrammed design with the speed of hard-wired logic design. In addition, the design allows direct addressing of 64 K words of MOS random access memory (RAM). With mapped memory, the MARK 9 Computer can access 256 K words of memory. An Extended Instruction Set on the MARK 9 (optional on MARK 5) computer increases the system throughput while decreasing software requirements. These features make POINT 4 MARK 5 and MARK 9 computers well-suited to OEM applications in business data systems, communications, and control systems. Figures $1-1$ and $1-2$ are photographs of POINT 4 MARK 5 and MARK 9 computer systems.

[^0]

Figure 1-1. POINT 4 MARK 5 Computer


Figure 1-2. POINT 4 MARK 9 Computer

### 1.1.1 PEATURES

## MARR 5 Peatures

The POINT 4 MARK 5 Computer includes the following features:

- CPU and 64 K words of RAM on the same board
- Nova*-compatible instruction set
- High-speed, 400-nanosecond cycle time (fetch and execution)
- Standard or high-speed data channel (jumper option)
- Main memory Battery Backup option
- Main memory parity error halt option
- Virtual Control Panel
- Built-in Self-Test for extensive verification of memory and CPU operation
- Jumper-free backplane
- Detachable Operator Control Unit option
- Seven-slot front-load chassis and separate power supply
- Full IRIS Operating System compatibility
- 12 V regulator option
- POINT 4 Extended Instruction Set (EIS) option

[^1]
## MARK 9 Features

The POINT 4 MARK 9 Computer includes the following features:

- CPU with l28K words of onboard RAM
- 256K words of onboard RAM (option)
- Nova-compatible instruction set
- POINT 4 Extended Instruction Set (EIS)
- MARK 9-exclusive hardware multiply/divide and stack instructions
- High-speed, 300-nanosecond cycle time (fetch and execution)
- Mapped memory
- Standard or high-speed data channel (jumper option)
- Modified hamming error code circuitry
- Main memory Battery Backup option
- Virtual Control Panel
- Built-in Self-Test for 64 K words of memory and CPU printed circuit board operation
- Jumper-free backplane
- Detachable Operator Control Unit option
- Seven-slot, front-load chassis and separate power supply
- Full IRIS Operating System compatibility


### 1.1.2 MODELS

The POINT 4 MARK 5 CPU board is available in two models: standard and universal. Both models use the same CPU and memory. The standard POINT 4 MARK 5 CPU board is used with a POINT 4 chassis. The MARK 5 universal CPU board is designed to replace CPU and memory boards in a Nova-compatible chassis. The MARK 5 universal CPU board includes a series of switches and light-emitting diode (LED) monitors. These switches and LED monitors perform most of the functions that are performed by the Mini-Panel on the POINT 4 CPU chassis.

The POINT 4 MARK 9 CPU board is also available in both standard and universal models as described above.

## NOTE

Unless otherwise noted, information in this manual pertains to both standard and universal models of POINT 4 MARK 5 and 9 CPUs.

### 1.1.3 PERIPHERALS SUPPORTED

The following peripherals, available from various manufacturers, are supported: Teletypes, video display terminals, printing terminals, diskettes, fixed-head disks, cartridge disks, disk pack drives, magnetic tape units, cassettes, paper tape readers, paper tape punches, line printers, character printers, plotters, card readers, and card punches.

### 1.1.4 OPTIONS

## MARR 5 Options

The following options are available to enhance the POINT 4 MARK 5 Computer:

1. The main memory parity error halt option allows detection of data errors in memory transfers.
2. Main memory battery backup maintains the contents of memory for at least 2 hours in the event of a power failure.
3. An Operator Control Unit may be attached to the CPU front panel or extended by cable to a convenient work surface.
4. The voltage regulator option provides a 12 V regulator on the PC board for use in a chassis that does not provide a regulated +12 V supply.
5. The POINT 4 Extended Instruction Set (EIS) provides increased versatility and efficiency.
6. The Micro-Programmed Floating Point Unit (MFPU) reduces floating-point computation time. This option is available only if the MARK 5 CPU also has the EIS option.

## MARR 9 Options

The following options are available to enhance the POINT 4 MARK 9 Computer:

1. Main memory battery backup maintains the contents of memory for at least 2 hours in the event of a power failure.
2. An Operator Control Unit may be attached to the CPU front panel or extended by cable to a convenient work surface.
3. The MARK 9 is equipped with 128 K words of memory. Optional memory may be purchased to increase main memory to 256 K words.

### 1.2 EQUIPMENT SPECIFICATIONS

## MARK 5 CPU Specifications

Word length
General purpose accumulators
Memory cycle time
RAM access time
Crystal-controlled clock frequency
Memory
Standard data channel

High-speed data channel
Interrupt response
CPU board size

CPU board power consumption (max)

## MARR 9 CPU Specifications

Word length
General purpose accumulators
Cycle time (fetch and execution)
RAM access time
Crystal-controlled clock frequency

Memory size

Standard data channel

High-speed data channel
Interrupt response
CPU board size

CPU board power consumption (max)

16 bits
4
400 nanoseconds
200 nanoseconds
30 MHz
64K words
Input - 1100 nanoseconds Output - 1433 nanoseconds
Input - 800 nanoseconds
Output - 933 nanoseconds
1200 nanoseconds
15 in. $x 15$ in.
$(38.10 \mathrm{~cm} \times 38.10 \mathrm{~cm})$
$-5 V(1 m A)+5 V(4 A)+12 V(1.5 A)$

16 bits
4
300 nanoseconds
120 nanoseconds
40 MHz
128K words
256K words (optional)
Input - 1600 nanoseconds Output - 2000 nanoseconds
Input - 900 nanoseconds Output - 1200 nanoseconds
1175 nanoseconds
15 in. $x 15$ in. $(38.10 \mathrm{~cm} \times 38.10 \mathrm{~cm})$
+5V (14.0A) without battery backup
+5 V (11.0A) with battery backup
+5 V battery backup (3.0A)

## Electrical Specifications

AC Input - 99 to 129V AC, 6A max, 47 to 64 Hz Optional - 199 to 257 V AC, 3 A max, 47 to 64 Hz AC Power Consumption - 450 watts max

## Mechanical Specifications

Processor Chassis:
Height - $5.25 \mathrm{in} .(13.34 \mathrm{~cm})$
Width - 19.0 in. $(48.26 \mathrm{~cm})$
Depth - 17.5 in. ( 44.45 cm )
Weight - $20 \mathrm{lbs}(9.07 \mathrm{~kg})$
Operator Control Unit:
Height - 3.62 in. $(9.19 \mathrm{~cm})$
Width - 6.12 in. ( 15.54 cm )
Depth - 1.1 in. ( 2.79 cm )
Weight - . 75 lbs (. 34 kg )
Power Supply Chassis:
Height - 5.25 in. ( 13.34 cm )
Width - 19.0 in. $(48.26 \mathrm{~cm})$
Depth - 10.0 in. ( 25.40 cm )
Weight - 25 lbs (11.34 kg)

## Environmental Specifications

Temperature Range - 0 to $50^{\circ} \mathrm{C}$ ( 32 to $122^{\circ} \mathrm{F}$ ) Relative Humidity - 10 to $90 \%$ noncondensing

### 1.3 SYSTEM ARCHITECTURE

The POINT 4 MARK 5 and MARK 9 use an architecture that reduces signal interfacing between boards to a minimum. This allows maximum speed of instruction execution. A combination of central processor logic and 64 K words (l28K or 256 K words on MARK 9) of RAM on a single circuit board eliminates time delays due to long, asynchronous, memory access bus paths. The CPU board contains all basic functions of the computer. This leaves only I/O controller boards to be added to the system. Figure l-3 illustrates a typical configuration of a POINT 4 MARK 5 or MARK 9 system.

### 1.3.1 SYSTEM FUNCTIONAL UNITS

POINT 4 MARK 5 and MARK 9 computers utilize five functional units; the CPU and memory board, the processor chassis and front panel, the Mini-Panel, an optional Operator Control Unit, and the power supply. Figure l-4 is a diagram of the computer system showing the functions each unit performs.


*On MARK 9, memory error indicator
085-61

Figure 1-4. POINT 4 MARR 5/9 Computer System Block Diagram

### 1.3.1.1 Central Processor and Memory Board

The central processor board contains the basic elements of the CPU:

- Four general-purpose accumulators
- Arithmetic/logic unit (ALU)
- Instruction register
- Main data bus
- Program counter
- Effective address register
- Timing control
- I/O control

In addition to these basic CPU elements, the CPU board contains a variety of features that are often omitted or housed on separate boards. The compact CPU board contains the following features:

- 64 K words of RAM (MARK 5)
- 128 K or 256 K words of RAM (MARK 9)
- Parity generation and error detection logic (option)
- Error detection and correction (EDAC) circuitry (MARK 9)
- Operator Control Unit interface logic
- Battery Backup interface logic
- Automatic program load (APL) PROMs containing a program to implement the Virtual Control Panel features
- Self-Test PROMs containing a hardware checkout routine
- Switches and indicators allowing onboard Mini-Panel functions (universal CPU model)
- +12v regulators for use in a chassis that does not provide a regulated +12 V supply (universal CPU model)

Figure l-5 is a block diagram of the MARK 5 CPU/memory board. Figure l-6 is a block diagram of the MARK 9 CPU/memory board.


Figure 1-5. POINT 4 MARR 9 CPO/Memory Block Diagram


Pigure 1-6. POINT 4 MARR 9 CPU/Memory Block Diagram

### 1.3.1.2 Processor Chassis and Front Panel

The POINT 4 MARK 5/9 processor chassis is designed to be mounted in a standard l9-inch equipment rack. The chassis contains seven slots spaced on .6-inch centers. The processor chassis is 5.25 inches high, 19 inches wide, and 17.5 inches deep.

Cooling is provided by two whisper-quiet fans. These are mounted on the left side of the chassis behind the Mini-Panel.

The front panel snaps on and off. No screws or hinges hold it in place. No cabling exists between the front panel and the chassis (except optional Operator Control Unit cabling) since the Mini-Panel is mounted directly onto the chassis and its controls are accessible through a slot on the left side of the front panel.

### 1.3.1.3 Processor Mini-Panel

The Mini-Panel on the POINT 4 MARK $5 / 9$ chassis houses an efficient set of controls and indicators for basic processor operation. Mini-Panel indicators include light-emitting diode indicators for monitoring of parity errors (MARK 5), memory errors (MARK 9), the Carry flag, CPU operation, power OK, and battery OK. Processor control switches include a four-position switch controlling ON, AUTO operation, STANDBY, and OFF. Program control switches allow stopping and restarting of program execution and enabling of the Virtual Control Panel. For further details, see Section 3.3 on Mini-Panel operations.

The Virtual Control Panel allows monitoring and control of the processor from a master terminal through use of the manipulator program MANIP. For further details, see Section 3.5 on use of the Virtual Control Panel.

### 1.3.1.4 Operator Control Unit (Optional)

In addition to the basic controls and indicators on the POINT 4 MARK 5 or 9 processor chassis, an Operator Control Unit is available that enhances operator access to the processor. This detachable control unit can be attached to the front panel of the chassis, or can be extended via ribbon cable to any convenient work surface. The compact control unit contains all switches and indicators necessary to monitor and control the processor. See Figure l-7 for a photograph of the Operator Control Unit.


Figure 1-7. Operator Control Unit

Displays include two octal displays for address and data, and eight light-emitting diodes indicating activity in the following areas: data channel, programmable control store, high-speed interprocessor bus, 64 K -word addressing, program execution, interrupts enabled, carry condition, and parity error detected. Sealed membrane switches provide an octal data entry panel, a clear data button, and the following controls:

- Memory is accessible through control switches to examine and deposit in memory, as well as to enable 64K-word addressing
- Accumulators are accessible through examine and deposit controls
- Program execution controls include reset, start, stop
- Automatic Program Load (APL) switch

See Section 3.4 for further description of the Operator Control Unit.

### 1.3.1.5 Power Supply Module

The power supply module is housed in a separate chassis (l9 inches wide, 5.25 inches high, and 10 inches deep) for flexibility of installation. The power supply consists of two units: a regular power supply for normal use, and a battery backup unit (optional), which is used in case of power failure.

The regular power supply module delivers the power required for the CPU board and front panel logic, the Operator Control Unit, plus the power required for the $I / O$ device controllers housed in the POINT 4 MARK 5 or MARK 9 chassis.

The power supply requires an input voltage of ll7v AC or $234 \mathrm{~V} A C$, 47 to 64 Hz . Power supply output voltages are:

| Voltage | Supplied to |
| :---: | :---: |
| +5V | CPU board, Operator Control Unit, I/O controllers |
| -5V | CPU, I/O controllers* |
| +15V | For use by I/O controllers |
| -15V | For use by I/O controllers |
| $\begin{aligned} & +17 \mathrm{~V} \mathrm{Pk} \\ & 60 \mathrm{~Hz} \end{aligned}$ | CPU slot** |

[^2]These voltages are available for $1 / O$ controller applications. Output current available for each voltage and supply type are:

| Voltage | Output |
| :--- | ---: |
| +5 V DC | 35.0 amps |
| -5 V DC | 1.0 amps |
| +15 V DC | 2.5 amps |
| -15 V DC | 2.5 amps |

Power Supply Type
Switching supply
Switching supply
Switching supply
Switching supply

The +5 V power supply needs a minimum consumption level of 3.5 amps for the other voltages to be in tolerance. The CPU board, when plugged in, will provide this load. The battery backup option protects memory contents for at least 2 hours in the event of a power failure. The battery backup unit is maintained in a charged state by the power supply as long as the unit is plugged in and AC power is available (even if the key switch is in the OFF position). Battery backup voltages are:

Voltage

```
+5V BU
-5V BU
+l2V BU
CPU board, Mini-Panel, memory refresh logic Memory on CPU board (MARK 5 only) Memory on CPU board (MARK 5 only)
```


## Supplied to

These outputs are supplied to the CPU board only. They are low current output.

The power supply is divided into two PCB subassemblies with switching regulators on each board. The Primary Inverter has an "off-line" switcher that works directly off the AC power line. The Battery Backup (BBU) has a "flyback" switcher that operates off a low-voltage output of an AC line transformer. The AC transformer also powers the supply chassis and computer chassis fans. Figure $1-8$ is a block diagram of the power supply unit.

Battery backup interface logic includes a sensor to determine whether the power control cable is connected to the CPU chassis. The power supply unit will not supply power to the processor if this cable is disconnected. The processor may also be nonfunctional if the cable is connected but the CPU Mini-Panel keyswitch is set to the OFF position, disabling all power to the system.

If the Mini-Panel keyswitch is set to any position except OFF, power will be supplied to the system and operation of the unit depends on the presence or lack of the Battery Backup Unit.

When the BBU is installed, the system switches to battery power upon loss of AC. A control signal informs the CPU of the Power Fail condition before the power is out of tolerance. The +5 V BU, -5 V BU and +12 V BU take over supply of power to CPU Memory only.

Logic on the comparator board tests whether output voltages are in tolerance. If a voltage is in tolerance, the appropriate LED on the power supply Mini-Panel is illuminated. If all voltage outputs are in tolerance, a signal is sent to the CPU Mini-Panel which turns on the POWER OK LED. When batteries are charging, the BTRY OK LED on the CPU Mini-Panel is off; it illuminates when installed batteries are fully charged.


Figure l-8. POINT 4 MARR 5/9 Power Supply Block Diagram

### 1.3.2 DATA CHANNEL

An interrupt and the execution of several instructions are required for each word transferred between input/output (I/O) devices and memory via program control. To allow greater transfer rates between memory and external devices, the processor is equipped with a data channel through which a device can, at its own request, access memory directly using a minimum of processor time. A high-speed device, such as a disk or tape drive, can access memory without assistance from the program. Program execution simply pauses momentarily while a data channel transfer takes place on the $1 / O$ bus.

The data channel releases processor time by allowing execution of a program concurrently with data transfers for a device. Many devices may share the data channel.

The POINT 4 MARK 5 and MARK 9 computers have an option that allows jumper selection of data channel speed:

MARK 5 MARK 9
Standard Data Channel

| Input - (nanoseconds) | 1100 | 1600 |
| :--- | :--- | :--- |
| Output - (nanoseconds) | 1483 | 2000 |

High-Speed Data Channel

| Input - (nanoseconds) | 800 | 900 |
| :--- | ---: | ---: |
| Output - (nanoseconds) | 933 | 1200 |

The choice of standard or high-speed data channel depends on the ability of all peripherals to respond within the maximum time allowed. See Section 4.4 for data channel jumpering instructions.

## Section 2 <br> INSTALLATION

### 2.1 ENVIRONMENTAL REQUIREMENTS

Careful consideration must be given to the placement of any computer system prior to installation to ensure that all power and environmental requirements are met. Necessary pre-installation considerations are discussed in the following subsections.

### 2.1.1 POWER REQUIREMENTS

The POINT 4 MARK 5/9 requires a power source of ll7V AC, 47 to 64 Hz with 6 amperes maximum current draw; or a 237 V AC, 47 to 64 Hz power source with 3 amperes current draw. In addition to the power requirements for the POINT 4 MARK 5/9, the power resources and electrical outlets needed to handle all peripheral devices must be considered.

### 2.1.2 TEMPERATURE REQUIREMENTS

Adequate environmental controls are needed to maintain the POINT 4 MARK $5 / 9$ in the desired temperature range of 20 to $30^{\circ} \mathrm{C}$ ( 68 to $86^{\circ} \mathrm{F}$ ). The maximum operating range is 0 to $50^{\circ} \mathrm{C}$ (32 to $122^{\circ} \mathrm{F}$ ).

### 2.1.3 ENCLOSURE REQUIREMENTS

The POINT 4 MARK 5/9 is packaged in a seven-slot chassis. The power supply module is mounted in a separate chassis. This separation provides for flexibility of installation and also helps isolate heat and noise from the processor. Each chassis measures 5.25 inches high. The two chassis are designed to be mounted in a standard l9-inch equipment rack. The units require sufficient free space to allow for cooling air flow.

### 2.2 UNPACKING INSTRUCTIONS

POINT 4 MARK 5/9 Computer products receive a complete test and inspection prior to shipment. It is recommended that each unit be inspected for completeness and shipping damage prior to installation. Each carton should be inspected for any evidence of damage due to dropping, puncturing, or crushing. If damage is evident, contact the carrier and the POINT 4 Data Corporation Sales Representative for further instructions.

The following subsections describe unpacking for separate chassis units. Separate unpacking/installation documents are available for MARK 5 and MARK 9 lowboy and highboy systems.

### 2.2.1 UNPACKING THE CARTONS

The POINT 4 MARK 5 or MARK 9 and the power supply chassis are packaged in double-walled, corrugated cartons. Styrofoam packing inserts surround the chassis. The CPU board is packaged in a cardboard carton and placed on top of the chassis. Figure 2-1 illustrates the processor chassis packaging. Figure 2-2 illustrates the power supply chassis packaging.

### 2.2.2 CONTAINER CONTENTS

Each item removed from the carton should be checked against the packing slip. All items, including cable connectors, should be inspected for damage. If items are damaged or broken, contact the POINT 4 Data Corporation Sales Representative.


Pigure 2-1. POINT 4 MARK 5/9 Processor Chassis Packaging


Figure 2-2. POINT 4 MARK 5/9 Power
Supply Packaging

### 2.3 PROCESSOR AND POWER SUPPLY MOUNTING

The processor and the power supply chassis are designed to be mounted in a standard l9-inch equipment rack. Although the exact procedure may vary, each chassis is mounted according to the following general procedure.

On MARK 5 and MARK 9 lowboy and highboy systems, the chassis are mounted prior to shipment.

### 2.3.1 PRONT PANEL

The POINT 4 MARK 5/9 processor and power supply front panels snap off for easy removal. No screws or hinges hold them in place. Removing the front panel reveals mounting slots on each side of the chassis.

## CAUTION

The POINT 4 MARK 9 airflow system requires the front panels to be in place when the computer is being run.

### 2.3.2 CHASSIS

The chassis has two mounting slots on each side. Figure 2-3 shows the mounting slot locations on both processor and power supply chassis.

## CAUTION

Care must be taken not to crimp, or in any way damage the cables connected to the processor chassis while mounting the chassis.


Figure 2-3. Processor Chassis and Power Supply Chassis Mounting Slots

### 2.3.3 PRINTED CIRCUIT BOARDS

The seven slots on the processor chassis are numbered l-7 from top to bottom. The processor memory board always occupies the top slot. Printed circuit boards are mounted component-side up. A typical board configuration would be:

- POINT 4 MARK 5/9 CPU/memory board
- POINT 4 LOTUS 730 Multifunction Controller Board (or POINT 4 LOTUS 710 Disk Controller, POINT 4 LOTUS 720 Tape Controller)
- POINT 4 MIGHTY MUX (8-port)
- POINT 4 MIGHTY MUX 16-port Asynchronous Expansion Board
- POINT 4 LOTUS Cache Memory

The jumper-free backplane allows for flexibility in board organization. There is no need to jumper data-channel interrupt priority around unused slots. Figure 2-4 illustrates a typical board configuration.

Except for the CPU board (see Section 2.2.l), POINT 4 Data Corporation-manufactured printed circuit boards are shipped in separate cartons. They should be installed in the chassis with care. The card edge connectors must slide smoothly into the backplane sockets.


Figure 2-4. Typical Computer Chassis Configuration

### 2.3.4 POWER SUPPLY CABLING

The POINT 4 MARK 5/9 processor chassis comes with a 6-foot cable assembly attached to the rear of the chassis. This cable assembly consists of a ribbon cable and a wire bundle strapped together. Processor chassis connections are made at the factory. Check to ensure that these cables are properly connected to the chassis. Figure 2-5 illustrates mounting positions on the processor chassis. Connectors and their mounting positions are:

Connector
12-pin wire bundle (main DC power to chassis)

26-pin ribbon cable (Mini-Panel and control cable)

3 sheathed power wires (AC fan power)

Mounting Position
Top center of the POINT 4 MARK 5/9 backplane

Upper right side of the POINT 4 MARK 5/9 backplane

Connected inside of the fan module

The free ends of the cable assembly must be connected to the rear of the power supply. Figure 2-6 illustrates mounting positions on the power supply chassis. The connectors and their mounting positions are as follows:
Connector
25-pin ribbon cable
(power supply control
cable)

15-pin wire bundle (main DC power and (AC fan power)


Figure 2-5. Processor Chassis Backplane
Connector Mounting Positions


Figure 2-6. Power Supply Chassis Rear Connector Mounting Positions

### 2.4 POWERING UP THE SYSTEM

The following steps should be followed when first supplying power to the POINT 4 MARK 5/9 power supply and processor:

1. Connect the red lead to the plus terminal on the battery (removed for shipment).
2. Turn the processor Mini-Panel keyswitch to the OFF position before connecting the 6-foot AC power cable to the AC power source. See Section 3.3 for processor Mini-Panel switch positions.
3. Plug the AC power cable into the AC socket. The AC IN LED on the power supply indicator panel should be illuminated. See Section 3.2 for power supply indicator panel LED positions.
4. If the $A C$ IN LED does not illuminate, check the following:
a. The AC power is properly connected.
b. The power control cable is properly connected to the processor chassis (see Section 2.3.4 for cable connection instructions).
c. The fuse in the power supply fuse box is installed and good.

If the $A C$ IN LED still does not illuminate, do not proceed. Return the power supply for repair.
5. Turn the Mini-Panel keyswitch to the standby (STDBY) position. If the power supply contains battery backup, the +5 BU , the -5 BU , and the +12 BU LEDs should be illuminated. The BTRY OK light may blink; this indicates that the battery is charging. The BTRY OK light is continuously illuminated when the battery is fully charged. See Section 3.2 for positions of LEDs on the power supply indicator panel.
6. Turn the Mini-Panel keyswitch to the ON position. The POWER OK LED on the processor Mini-Panel should illuminate. This indicates that power is available to the processor chassis. The power supply panel LEDs should all be illuminated. This indicates that all voltages are in tolerance. If any LED on the power supply panel does not illuminate, one of the following conditions exists:

- The power supply for that voltage is out of tolerance
- The LED is bad
- Loose cable plug


### 2.4.1 GROUNDING

When the logic ground of a device is connected to the logic ground of a POINT 4 MARK 5/9 chassis, the device frame chassis ground should be isolated from the device logic ground. The device frame ground and the chassis should be tied together by at least a 0.5-inch braided copper strap. The chassis grounds should be isolated from the logic grounds to prevent a pseudo power failure. The POINT 4 MARK 5/9 logic ground is isolated from the frame ground by a lo-ohm, 2-watt resistor at the backplane motherboard.

### 2.4.2 BATTERY SHELP-LIPE

The red lead to the battery is removed from the battery pack prior to shipment. Check the power supply to confirm that the red lead is connected to the positive terminal on the battery. When powering up the system, the BTRY OK light may blink; this indicates that the battery is charging. The blinking stops when the battery is fully charged. When storing the power supply for more than a week, remove the red lead on the battery to increase its shelf-life.

### 2.5 DIAGNOSTIC CHECKS

The POINT 4 MARK 5/9 CPU has a comprehensive, built-in Self-Test diagnostic program contained in PROMs (Programmable Read-Only Memory) .

The Self-Test diagnostic may be used either as a one-pass hardware verifier, or as a continuous reliability test. It contains the following tests:

1. Halt instruction test
2. Compare instruction test
3. ALU and data bus test
4. ALU source operand test
5. Exhaustive ALU instruction test
6. Page 0 and base 3 addressing modes test
7. Relative, base 2, and indirect addressing modes test
8. Auto-indexing test
9. Limited I/O instruction test
10. Multilevel indirect addressing test
11. 64K-word addressing capability test
12. Worst-case test of all memory locations

The following subsections provide general procedures for starting the POINT 4 MARK 5/9 Self-Test. See the POINT 4 (MARK 5) Diagnostic Manual for details on tests executed, expected results, and halt interpretations.

Software diagnostic programs are available for the MARK 5 with EIS option and for the MARK 9. Refer to the MARK 8 (MARK 5 with EIS) Verifier/Diagnostic Document and the MARK 9 Diagnostics Document.

### 2.5.1 NORMAL SELP-TEST OPERATION

1. Snap off the front panel.
2. Locate the Self-Test switch on the front edge of the CPU board. See Figure 2-7 for Self-Test switch location. Press STOP. Press the Self-Test switch while holding the APL switch on the processor Mini-Panel. This loads the Self-Test program into main memory.
3. The first test verifies operation of the halt instruction. Press the CONTinue switch on the processor Mini-Panel to continue execution of Self-Test.
4. After a few preliminary tests, the message POINT 4 CPU SELF-TEST is displayed on the master terminal. If a master terminal is not used, the CARRY indicator will blink with every Self-Test pass.
5. The message $64 \mathrm{~K} C P U O K$ is displayed on the master terminal after testing all instructions, addressing modes, and basic CPU operations.
6. The message MEMORY OK is displayed on the master terminal after completion of the worst-case memory test.
7. A $V$ is displayed on the master terminal each time Self-Test repeats.
8. Replace front panel.


Figure 2-7. POINT 4 MARK 5/9 Self-Test Switch Location

### 2.5.2 HOW TO INTERPRET A HALT

An error is indicated if Self-Test halts (run light goes out) after the initial halt. Refer to the POINT 4 (MARK 5) Diagnostic Manual for detailed information on each step of the Self-Test diagnostic programs, program listings, and interpretations of halts at various locations.

### 2.5.3 SELP-TEST AS A CONTINUOUS RELIABILITY TEST

As previously noted, Self-Test may be used either as a one-pass hardware verifier or as a continuous reliability test.

- If a one-pass execution is desired, wait until the first $V$ appears, then press the STOP switch.
- If a continuous test is desired, do not press the STOP switch. The Self-Test program will continue running until the STOP switch is pressed, or an error is detected.


### 2.6 UNIVERSAL CPU BOARD INSTALLATION

The POINT 4 MARK 5 or MARK 9 universal CPU board is designed to replace CPU and memory boards in a Nova-compatible chassis.

The POINT 4 MARK 5 or MARK 9 universal CPU board can be installed in a single I/O slot of any Nova-type chassis. However, in order to accomplish this, certain requirements and restrictions must be met.

### 2.6.1 UNIVERSAL CPU BOARD VOLTAGE REQUIREMENTS

A POINT 4 MARK 5 universal CPU board requires three voltages for operation: $+5 \mathrm{~V},-5 \mathrm{~V}$, and +12 V . A POINT 4 MARK 9 universal CPU board requires only +5 V for operation. Voltages and backplane pin assignments are listed below:

| Voltage | Current | Backplane Pin |
| :---: | :---: | :---: |
| +5V (regulated) | 4A | A3, A4, B3, B4 |
| -5V (regulated)* | 10 mA * | A6* |
| +12V (regulated)* | 1.25A* | Al0* |

The $+5 V$ and $-5 V$ requirements above are standard on a Nova-type chassis. However, a typical Nova-type chassis has +l5V unregulated supply at pin AlO. Therefore, the POINT 4 voltage regulator option (see Section 6.4) is required for MARK 5 Universal CPU boards. This option converts the unregulated supply to +12 V of regulated voltage.

The POINT 4 voltage regulator option is not required for MARK 9 universal CPU boards.

[^3]
### 2.6.2 RESERVED BACKPLANE PINS

The POINT 4 MARK 5/9 CPU board communicates with its chassis Mini-Panel through a set of reserved backplane pin connections. These backplane pins must remain unconnected when using a POINT 4 MARK 5/9 universal CPU board in a Nova-type chassis. These pins are not normally used in the Nova-type chassis. Any system that does not contain a specially bused backplane will experience no problems in this area. Verify that a chassis does not use the reserved backplane connections listed below.

Signal Name


### 2.6.3 UNIVERSAL CPU BOARD DATA CHANNEL AND INTERRUPT PRIORITY CHAINS

Data channel and interrupt priority chains must be preserved after installation of the POINT 4 MARK 5/9 universal CPU board in the chassis.

Data channel and interrupt priority input (DCHPIN- and INTPIN-; backplane pins A96 and A94, respectively) of the highest priority device(s) are grounded (usually at slot 3) and the data channel/interrupt priority chain is then passed to the input of the next highest priority device. If no data channel/interrupt request exists in the highest priority device, the priority is passed to the next device in the chain.

The POINT 4 MARK 5/9 universal CPU does not pass on data channel or interrupt priorities. If it is necessary to insert the CPU board into a slot that physically interrupts the priority chain, the data channel and interrupt signals must be jumpered past the CPU board.

Standard-speed and high-speed data channel operations are described in Section 4.4. The POINT 4 MARK 5/9 universal CPU is normally delivered with the high-speed data channel enabled. To switch to the standard-speed data channel, ground pin A93 on the CPU backplane slot.

### 2.7 OPERATOR CONTROL UNIT INSTALLATION

The optional Operator Control Unit (OCU) enhances operator access to the CPU. There are two methods of installing the OCU:

1. Attachment to the processor front panel
2. Connection via ribbon cable

### 2.7.1 ATTACHMENT TO THE PROCESSOR FRONT PANEL

The Operator Control Unit can be attached to the center of the processor front panel for location with the processor. The unit has an edge connector protruding from the upper rear of the unit. This connector inserts directly into the slot provided on the center of the front panel, mating with a socket behind the front panel. This socket connects via ribbon cable to a socket on the front edge of the CPU board. See Figure 2-8 for an illustration of this attachment.

### 2.7.2 CONNECTION VIA RIBBON CABLE

The Operator Control Unit can be extended via ribbon cable to any convenient work surface. Extension is via a six-foot ribbon cable. The connector on the rear of the Operator Control Unit attaches to a socket on one end of the ribbon cable. The ribbon cable threads through a slot on the lower edge of the center of the front panel and the other connector connects to the socket on the front edge of the CPU board. See Figure 2-9 for an illustration of the remote connection.


Figure 2-8. Operator Control Unit Attachment to Front Panel


Figure 2-9. Operator Control Unit Remote Attachment

## Section 3 <br> OPERATING PROCEDURES

### 3.1 INTRODUCTION

This section describes the capabilities and operating procedures for the power supply indicator panel and operation control units. Three types of control units exist for the POINT 4 MARK 5/9:

- Processor Mini-Panel
- Detachable Operator Control Unit (optional)
- Virtual Control Panel

Specific procedures for performing common types of operations are provided. The controls and indicators are also described.

### 3.2 POWER SUPPLY INDICATOR PANEL

The POINT 4 MARK 5 or MARK 9 power supply chassis houses a set of light-emitting diode indicators. These indicators monitor power supply voltages and battery backup voltages. The power supply indicator panel is located on the left-hand side of the power supply chassis. Figure 3-1 is an illustration of the power supply indicator panel. Table 3-l explains the meaning of illuminated power supply panel indicators.


085-22
Figure 3-1. Power Supply Indicator Panel

TABLE 3-1. POWER SUPPLY PANEL INDICATORS

| Indicator | Meaning |
| :---: | :---: |
| AC IN | Indicates that $A C$ power has been applied to the power supply unit. |
| +5V | The +5 V output voltage is in tolerance. This output voltage is available for user applications. |
| -5v | The -5V output voltage is in tolerance. This output voltage is available for user applications. |
| +15V | The +15 V output voltage is in tolerance. This output voltage is available for user applications. |
| -15V | The -15V output voltage is in tolerance. This output voltage is available for user applications. |
| +5 BU | The +5v battery backup supply is in tolerance. If the battery backup unit is not installed, this light has the same meaning as the +5 V light. |
| $-5 \mathrm{BU}$ | The - 5V battery backup supply is in tolerance. This output voltage is available only to the POINT 4 MARK $5 \mathrm{CPU} /$ memory board. If the battery backup unit is not installed, this light has the same meaning as the -5 V light. |
| $+12 \mathrm{BU}$ | The +l2V battery backup supply is in tolerance. This output voltage is available only to the POINT 4 MARK 5 CPU memory board. The +l2V supply is operational with or without the battery backup unit. |

### 3.3 PROCESSOR MINI-PANEL

The POINT 4 MARK 5/9 processor chassis houses essential controls and indicators for basic processor control functions. The processor Mini-Panel is located on the left-hand side of the chassis.

### 3.3.1 MINI-PANEL OPERATING FUNCTIONS

The three types of operating functions on the Mini-Panel are: power controls and indicators, processor monitoring indicators, and program execution controls. Figure 3-2 illustrates the processor Mini-Panel controls and indicators.

The POINT 4 MARK 5/9 universal CPU board provides the user with a series of switches and light-emitting diodes on the printed circuit board itself, which are normally found on the POINT 4 Mini-Panel. These include: an APL switch, a CONTinue switch, a STOP switch, a parity error indicator (MARK 5), a memory error indicator (MARK 9), a carry indicator, a run indicator, and a +5 V power indicator.


Figure 3-2. POINT 4 MARR 5/9 Processor Mini-Panel

### 3.3.1.1 Power Controls and Indicators

The lower half of the Mini-Panel is devoted to power control and monitoring.

### 3.3.1.1.1 POWER CONTROLS

The power switch is controlled by a four-position, key-operated rotary switch. This switch controls the four functions described in Table 3-2.

TABLE 3-2. PROCESSOR MINI-PANEL POWER CONTROL SNITCH SETTINGS

| Switch Setting | Function |
| :---: | :---: |
| OFF | Disables the battery backup unit. This switch position is used for storage or extended power-off conditions. The battery charger is on as long as the power supply is plugged in. |
| STDBY | Turns the processor off, leaving the battery backup unit operational (if installed). Voltages for +5 V and +15 V are removed from the chassis but $+5 \mathrm{BU},-5 \mathrm{BU}$, and +12 BU are maintained for CPU slot use only. |
| ON | Turns on power to the processor and places the Mini-Panel in the panel-on mode. In this mode, all controls and indicators on the Mini-Panel are enabled. The power-fail auto-restart feature (available with the battery backup option) is disabled, and the processor must be started manually whenever AC power is turned ON. |
| AUTO | Maintains processor power on and places the Mini-Panel in the panel-off mode. In this mode, all controls on the Mini-panel are disabled, and all indicators remain active. Disabling the controls prevents interference with the operation of the CPU. The power-fail auto-restart feature is enabled if the battery backup option has been installed. This feature causes the processor to resume operation automatically upon AC power restoration following power failure. |

Light-emitting diode (LED) indicators illuminate to indicate an active state for AC power and battery backup power. Table 3-3 gives interpretations for the POWER OK LED for systems without the Battery Backup option.

TABLE 3-3. POWER INDICATOR INTERPRETATIONS WITHOUT BATTERY BACKUP

| Power <br> Supply <br> AC IN | Processor Chassis POWER OK | Interpretation |
| :---: | :---: | :---: |
| OFF | OFF | Power supply is not connected to AC. |
| ON | OFF | Power supply is operational but power is not available to processor chassis. If the keyswitch is in ON or AUTO position, it indicates that one of the power supply voltages is out of tolerance (see Section 3.2, Power Supply Indicator Panel) or that there is a problem in the cabling between the processor and the power supply. |
| ON | ON | All power supply voltages are in tolerance and available to the processor chassis. |

### 3.3.1.1.3 POWER INDICATOR INTERPRETATIONS WITH BATTERY BACKUP

The BTRY OK LED is operational if the Battery Backup option has been installed in the power supply chassis. The meaning of the BTRY OK LED depends on the state of the AC IN LED. These interpretations are shown in Table 3-4.

Figure 3-2 illustrates the positions on the key-operated rotary switch, the POWER OK indicator, and the BTRY OK indicator.

TABLE 3-4. POWER INDICATOR INTERPRETATIONS WITH BATTERY BACKUP

| Power <br> Supply <br> AC IN | Processor <br> Chassis <br> BTRY OK | Interpretation |
| :---: | :---: | :---: |
| OFF | OFF | AC power source is off and the battery <br> backup unit has been fully discharged. |
| OFF | ON | The battery backup unit is supplying <br> +5V BU, -5V BU (MARK 5) and +12V BU <br> (MARK 5) to the CPU/memory board to <br> maintain the contents of memory |
| ON | OFF | The battery backup unit is being <br> recharged but is not yet fully <br> charged. The LED indicator blinks as <br> the batteries are being charged. CPU <br> is not functional. |
| ON | ON | The battery backup unit batteries are <br> fully charged. The CPU is functional. |

### 3.3.2 PROCESSOR OPERATION MONITORING INDICATORS

The Mini-Panel has three LED indicators in addition to the power monitoring indicators. These indicators perform the functions shown in Table 3-5. (See Figure 3-2 for the locations of the operation monitoring LED indicators.)

TABLE 3-5. PROCESSOR OPERATION MONITORING INDICATORS

| Indicator | Function |
| :---: | :---: |
| PAR ERR <br> (MARK 5) | Indicates that a parity error has occurred during a memory-read operation. The LED indicates that the processor has come to a halt pending operator action. pressing the CONTinue or APL switch causes the processor to resume operation and turns off the parity error light. This LED is operational only if the parity error option is installed. |
| PAR ERR <br> (MEM ERR <br> MARK 9) | Indicates type of memory error. This LED blinks when the EDAC circuitry detects and corrects single-bit errors. Double-bit errors cause continuous illumination of this LED. This LED is off when no errors occur. |
| CARRY | Indicates the current state of the processor Carry flag. The LED illuminates when the Carry flag is set to al. |
| RUN | Indicates that the processor is in normal operation (i.e., executing one instruction after another). When the processor is stopped, the LED goes off. |

### 3.3.3 PROGRAM EXECUTION CONTROLS

Three momentary contact switches are available to control program execution in the processor. These switches are enabled in the panel-on mode (keyswitch set to the ON position). They are disabled in the panel-off mode (keyswitch set to the AUTO position). Table 3-6 describes the switches and their functions. (See Figure 3-2 for the locations of the program execution controls.)

TABLE 3-6. PROGRAM EXECUTION CONTROLS

| Switch | Function |
| :---: | :---: |
| STOP | Stops processor operation before executing the next instruction. The processor finishes current instruction, fetches the next instruction and then stops. The program counter (PC) then points to the next instruction to be executed. <br> NOTE <br> This note applies to 32 K -word addressing mode only. If the processor is caught in an infinite indirect addressing loop that prevents completion of the instruction, the STOP control will not work. Press APL to stop processor and load MANIP for debugging (see Section 3.5 for use of MANIP). |
| CONT | Causes program execution to resume, starting at address contained in the PC. |
| APL | The automatic program load (APL) switch performs these functions: <br> 1. Loads contents of an octal debugger/ manipulator PROM (MANIP) into the top 1000 (octal) words of memory. The debugger/ manipulator is used for access to accumulators and memory. Allows examination and deposit of data for operation monitoring and control. Optionally allows loading of system software from disk or other DMA devices. See Section 3.5 for debugger/manipulator program commands. Note that if CPU board switches are set to $2 x x$ (octal), the CPU performs an automatic APL from device $x x$ when the $A P L$ switch is pressed. <br> 2. May also be used in combination with the Self-Test switch (located on front edge of CPU circuit board) to load contents of Self-Test PROM into memory. The Self-Test program performs a complete check of hardware functions and executes a worst-case memory test. Self-Test does not examine MARK 9 map. It can be used either as a hardware verifier or as a continuous reliability test. See Section 2.5 for description of self-test diagnostics. <br> If the CPU is running, press STOP before pressing APL. However, if the processor is performing a multilevel indirect addressing instruction, pressing APL causes the processor to stop without use of STOP switch. |

### 3.4 OPERATOR CONTROL UNIT (OPTIONAL)

In addition to the basic controls and indicators on the POINT 4 MARK 5/9 processor chassis, an Operator Control Unit (OCU) is available that enhances operator access to the processor. This detachable control unit can be extended via ribbon cable to any convenient work surface. The compact control unit contains all switches and indicators necessary to monitor and control the processor. See Figure 3-3 for an illustration of the Operator Control Unit.

The Operator Control Unit measures 6.12 inches wide, 3.62 inches high and 1.10 inches deep. It may be mounted on the front panel at the slot provided in the center of the front panel, or extended to a convenient work surface by mounting a 6-foot ribbon cable to the processor PC board. Instructions for attaching the Operator Control Unit to the processor chassis are provided in Section 6.3.

### 3.4.1 OPERATOR CONTROL UNIT CAPABILITIES

The Operator Control Unit is designed to aid in detecting possible problems in the system, debugging these problems, and for entering program and data changes into the system. The operator can monitor activity on the system via eight lightemitting diode indicators. These indicators monitor the following processor functions: data channel, high-speed interprocessor bus (not used by POINT 4 equipment), 64 K -word addressing, program execution, interrupt enabling, carry condition, and parity error (memory error - MARK 9) detection. Octal displays allow the operator to observe the contents of memory and accumulators as well as the entries made via the data entry switches.

Switches provide the operator with the ability to enter data, access memory to examine and deposit into it, access accumulators to examine and deposit into them, enable 64 K -word addressing, and control program execution. In addition, an APL switch is provided.

### 3.4.2 CPU STATE INDICATORS

Eight light-emitting diode (LED) indicators are used to monitor processor operation, illuminating when the function is active. Table 3-7 describes the function of each LED indicator.

Figure 3-3. Operator Control Unit Controls and Indicators

TABLE 3-7. CPU OPERATION INDICATORS

| $\begin{gathered} \text { LED } \\ \text { Indicator } \end{gathered}$ | Function |
| :---: | :---: |
| PAR ERR | Illuminates when a parity error has occurred during a memory-read operation. The indicator is enabled only when the parity error detection option has been installed. Light indicates that the processor has come to a halt pending operator action. RESET must be pressed to enable use of the other control unit switches when a parity error has occurred. Pressing CONTinue will cause the processor to resume operation, regardless of previous parity error. Error may be investigated and/or corrected through use of examine and deposit capabilities of the Operator Control Unit. <br> NOTE <br> The MARK 9 CPU uses the OCU PAR ERR LED to indicate memory errors. The OCU PAR ERR LED blinks when the EDAC circuitry detects and corrects singlebit errors. Double-bit errors cause continuous illumination of this LED. This LED is off when no errors occur. |
| ION | Interrupts are enabled. Indicates that the processor will respond to interrupt requests from peripheral devices. |
| DCH | Data channel is active. Indicates that a data channel direct memory access transfer is currently taking place. |
| HIP | Not used. |
| 64K | Indicates that 64 K -word addressing mode is enabled. |
| RUN | Indicates that the processor is in normal operation (executing one instruction after another). When the processor is halted, this LED goes off. |
| CARRY | Indicates current state of processor Carry flag. Illuminated when Carry flag is set to 1 . |

### 3.4.3 OCTAL DISPLAYS

Two separate six-digit octal displays are provided: one for address (ADDRESS) and one for data (DATA). These LED displays are located at the upper right-hand corner of the Operator Control Unit (see Figure 3-3). The contents of these displays are controlled by the examine switches and the data entry switches on the control unit.

The ADDRESS display is always equal to the program counter (PC). While in RUN, ADDRESS monitors the program by continuously displaying the program counter. When the processor is halted, ADDRESS displays the PC where execution was stopped. Any control unit operation in which an address is entered, incremented, or decremented (EXAM, EXAM NEXT, etc.) changes the PC and ADDRESS simultaneously.

### 3.4.4 DATA ENTRY AND PROCESSOR MANIPOLATION CONTROLS

All data entry and processor control buttons on the Operator Control Unit are sealed, laminated membrane switches. These buttons are used to monitor and enter data into memory and accumulators and to control program execution. They serve as useful system monitoring and problem debugging tools for system programmers.

Eight membrane switches are provided for data entry in octal form. These buttons are numbered $0,1,2,3,4,5,6$, and 7 , enabling the operator to make six-digit octal entries for deposit in accumulators or memory and entry of memory addresses. The octal digits entered are shifted into the DATA display. The destination of the octal entry is controlled by the accumulator deposit buttons for the accumulators, by EXAM for memory addresses and by DEPosit and DEPosit NEXT for memory data. The number in the DATA display may be read by the CPU via use of a READS ac,CPU instruction.

The l6-bit word is divided into six octal digits. The most significant bit of the 16 bits forms the most significant octal digit. Since this digit consists of only one bit, it can have the values 0 and 1 only. Therefore, if a value greater than 1 is shifted into the most significant bit, that value will be truncated to a l-bit number as follows:

$$
\begin{array}{lll}
\text { any even number } & 0 \\
\text { any odd number } & --> & 1
\end{array}
$$

A CLEAR DATA button is provided to clear the DATA display to 000000. Corrections may also be made by entering zeros followed by the correct octal digits. The most significant digit will be shifted off the left end of the display as new digits are entered. (See Figure 3-3 for positions of the data entry and CLEAR DATA buttons.)

Processor access and program execution controls consist of 20 sealed membrane switches. These controls can be grouped by basic functions into three types: memory access, accumulator access and program execution. (See Figure 3-3 for positions of these controls on the Operator Control Unit.)

Memory access controls (disabled while the processor is in RUN mode) are described in Table 3-8.

TABLE 3-8. OCU MEMORY ACCESS CONTROLS

| Control | Function |
| :---: | :---: |
| EXAM | Examine - the octal value in the DATA display is moved into the ADDRESS display. The contents of memory at the memory location in the ADDRESS display is then displayed in the DATA display. The PC is set equal to the ADDRESS display. Note that pressing EXAM twice corresponds to indirect addressing. |
| $\begin{aligned} & \text { EXAM } \\ & \text { NEXT } \end{aligned}$ | Examine next - the address in the ADDRESS display is incremented by $l$ and the content of the new memory address is displayed in the DATA display. The PC is set equal to the incremented memory address, which is displayed in the ADDRESS display. |
| $\begin{aligned} & \text { EXAM } \\ & \text { PREV } \end{aligned}$ | Examine previous - the address in the ADDRESS display is decremented by 1 and the content of the new memory address is displayed in the octal DATA display. The PC is set equal to the decremented memory address, which is displayed in the ADDRESS display. |
| DEP | Deposit - deposits the value in the DATA display into the memory address displayed in the ADDRESS display. The value in DATA may be a value read from memory, or an accumulator, or a value entered via the data entry buttons. The PC is left equal to the ADDRESS display. |
| DEP <br> NEXT | Deposit next - the address in the ADDRESS display is incremented by 1 and the value in the DATA display is deposited into the incremented memory address. The value in DATA may be a value read from memory, or an accumulator, or a value entered via the data entry buttons. The PC is set equal to the incremented address displayed in ADDRESS. |
| $\begin{aligned} & \text { SET } \\ & 64 \mathrm{~K} \end{aligned}$ | Enable 64K-word addressing - this control enables addresses 100000 through 177777 . Memory addresses are 16 bits long for 64 K -word addressing (instead of 15 bits long as in 32 K -word addressing). In 64 K -word addressing mode, multilevel indirect addressing is not permitted. |

Access to accumulators 0-3 is available through the examine and deposit controls (disabled when the processor is in the RUN mode) described in Table 3-9.

TABLE 3-9. OCU ACCUMULATOR ACCESS CONTROLS

| Control | Function |
| :---: | :---: |
| $\begin{aligned} & \text { EXAM } \\ & \text { AO } \end{aligned}$ | Examine accumulator 0 - displays, in the DATA display, the contents of accumulator 0 (AO). |
| $\begin{aligned} & \text { EXAM } \\ & \text { Al } \end{aligned}$ | Examine accumulator 1 - displays, in the DATA display, the contents of accumulator 1 (Al). |
| $\begin{aligned} & \text { EXAM } \\ & \text { A2 } \end{aligned}$ | Examine accumulator 2 - displays, in the DATA display, the contents of accumulator 2 (A2). |
| $\begin{aligned} & \text { EXAM } \\ & \text { A3 } \end{aligned}$ | Examine accumulator 3 - displays, in the DATA display, the contents of accumulator 3 (A3). |
| $\begin{aligned} & \text { DEP } \\ & \text { A0 } \end{aligned}$ | Deposit in accumulator 0 - deposits in accumulator 0 (AO) the value in the DATA display. The value in DATA may be a value read from memory or an accumulator, or a value entered via the data entry buttons. |
| $\begin{aligned} & \text { DEP } \\ & \text { Al } \end{aligned}$ | Deposit in accumulator l-deposits in accumulator (Al) the value in the DATA display. The value in DATA may be a value read from memory or an accumulator, or a value entered via the data entry buttons. |
| $\begin{aligned} & \text { DEP } \\ & \text { A2 } \end{aligned}$ | Deposit in accumulator 2-deposits in accumulator 2 (A2) the value in the DATA display. The value in DATA may be a value read from memory or an accumulator, or a value entered via the data entry buttons. |
| $\begin{aligned} & \text { DEP } \\ & \text { A3 } \end{aligned}$ | Deposit in accumulator 3 - deposits in accumulator 3 (A3) the value in the DATA display. The value in DATA may be a value read from memory or an accumulator, or a value entered via the data entry buttons. |

The remaining six controls are used for control of program execution. They are described in Table 3-10.

TABLE 3-10. OCU PROGRAM EXECUTION CONTROLS

| Control | Function |
| :---: | :---: |
| RESET | Resets all I/O devices on system to idle state and clears processor $I O N$ flag and 64 K -addressing mode. |
| STOP | Stops processor operation before executing the next instruction. The processor finishes current instruction, fetches next instruction, and then stops. The program counter and ADDRESS display point to next instruction to be executed. Contents of the DATA display are not changed. <br> NOTE <br> If the processor is caught in an infinite indirect addressing loop that prevents completion of the instruction, STOP control will not work. Press RESET to stop processor. |
| START | Moves contents of DATA display to the PC. Processor then begins normal operation by fetching and executing instruction at address just loaded into the PC. RUN light will illuminate. |
| CONT | Causes program execution to resume, starting at address contained in the $P C$ (and in ADDRESS display). |
| $\begin{aligned} & \text { INST } \\ & \text { STEP } \end{aligned}$ | Causes processor to execute one instruction cycle beginning at address in ADDRESS display. When instruction cycle is completed, processor stops. ADDRESS display contains new value of program counter. Information displayed in DATA display depends on type of instruction: |

TABLE 3-10. OCU PROGRAM EXECUTION CONTROLS (Cont)

| Control | Function |
| :---: | :---: |
| APL | The automatic progam load (APL) switch performs two separate functions: <br> 1. Loads contents of an octal debugger/ manipulator PROM into the top 1000 words of memory. The debugger/manipulator serves as a virtual control panel and operates through the master terminal. It offers several higher level functions than the Operator Control Unit, such as memory searches, moves, byte addressing, virtual addressing, etc. It also allows loading of system software from disk or other DMA devices. See Section 3.5 for a description of debugger/manipulator commands. <br> 2. May also be used in combination with the Self-Test switch (located on front edge of CPU circuit board) to load contents of the Self-Test PROM into memory. The Self-Test program performs a complete check of hardware functions and executes a worst-case memory test. It can be used either as a hardware verifier or as a continuous reliability test. See Section 2.5 for description of Self-Test operation. <br> If the CPU is running, press STOP before pressing APL |

### 3.5 VIRTUAL CONTROL PANEL

The POINT 4 MARK $5 / 9$ has the ability to perform many front panel operations plus many extra system monitoring functions from a master terminal. This feature is designed for use by programmers to debug system problems and to manipulate the contents of registers and memory. The feature is implemented in a stand-alone program called MANIP, which is loaded into RAM from a PROM when the APL switch is pressed. Note that if CPU board switches are set to $2 x x$ (octal), MANIP cannot be accessed from memory. Pressing APL causes MANIP to program load from device xx.

MANIP is a simple, but powerful, position-independent memory manipulator and debug package. MANIP occupies only 1000 (octal) words of memory.* All operations are executed by typing one letter followed by octal parameters as required (except a colon (:), which is also preceded by an octal parameter) and ending with a <RETURN>.

Table 3-1l shows the functions provided by MANIP (the number in parentheses indicates the number of parameters required for that particular function). The MANIP functions are described in detail in the following subsections.

MANIP is initially loaded into locations 177000 through 177777.
Location 177000 is reserved for saving the initial value of the program counter (PC) ; that is, the value of PC where the CPU had hal ted before MANIP was started. MANIP may be moved at any time by use of its MOVE (M) instruction.

The carry light flashes while MANIP is waiting for an input character to be entered (except in I mode). This is a signal that MANIP is active and will respond to input.

If an error is made while entering control information, it may be corrected in two ways.

1. Press <ESC> (or any other control character except <RETURN>) to delete the type-in and enable a new type-in.
2. If the error was made in entering an octal value, type a number of zeros followed by the correct octal number, as MANIP uses only the last six octal digits typed in for the octal word.
[^4]TABLE 3-11. MANIP COMHAND FUNCTIONS AND PARAMETERS

| Code | Function | Parameters Required |
| :---: | :---: | :---: |
| A | Type initial PC, accumulators, and carry flip-flop | (0) |
| C | Change accumulator or carry flip-flop | (2) |
| D | Dump (octal, word or byte) | (1 or 2) |
| E | Enter octal into sequential locations | (1 or 2) |
| F | Set up an address offset* | $\begin{aligned} &(0, 1 \\ &\text { or } 2) \end{aligned}$ |
| J | Jump with accumulators and carry restored | (1 or 2) |
| K | Store a constant in a block of memory | (3) |
| M | Move a block in memory | (3) |
| N | Search memory for not-equal (with mask) | (3 or 4) |
| 0 | Output ASCII string on master terminal | (l or 2) |
| P | Program load from disk | (0 or 1) |
| S | Search memory for constant using a mask | (3 or 4) |
| X | Calculate a checksum for a block of memory | (2) |
| Y | Set up an output delay after each RETURN (for proper scrolling) | (1) |
| : | Examine or deposit into a specified location | (2) |
| CTRL | Control characters are used to access CTU | ** |
| *F command is not supported by MARK 9 MANIP. **Refer to the Cassette Tape Unit Hardware Manual for parameters. |  |  |

### 3.5.1 ADDRESSING MODES

For many commands, MANIP allows either word or byte addressing, using either real memory addresses or offset (virtual) memory addresses based on an offset that has been previously entered (via $F$ command). MANIP is designed to allow addressing up to 64 K words of memory. This is accomplished by having two word-addressing modes (real and virtual), and three byteaddressing modes (one virtual plus two real modes: lower 32 K and upper 32 K ).

These modes are invoked by the optional second parameter "a" shown for commands $D, E, J$, and 0 (see Section 3.5.2).

## NOTE

The $J$ command does not permit byte addresses.
When no "a" parameter is given, the addressing mode is "word address, including offset, if any." (If there is no na" parameter, the preceding comma is optional.)

The "a" parameter definitions are as follows:

| a Parameter | Definition |
| :---: | :--- |
| omitted | word address, including offset, if any |
| 0 | word address, absolute |
| 1 | byte address, using offset, if any |
| 2 | byte address, lower 64 KB |
| 3 | byte address, upper 64 KB |

### 3.5.2 COMHAND DESCRIPTIONS

A MANIP command consists of a single letter, which is the command identifier, and parameters that specify addressing modes, memory addresses, and data input. All parameters must be entered in octal form. The letters $a, m, n, x, y$, and $z$ are used on the following pages to represent octal parameters. Press the RETURN key after entering any command.

Table 3-12 shows MANIP commands and descriptions.

TABLE 3-12. MANIP COMMAND DESCRIPTIONS

| Command \& Parameters | Definition |
| :---: | :---: |
| A | Types out initial value of program counter (PC) saved in first location of MANIP, contents of accumulators A0, Al, A2, A3, and carry flip-flop as they were at the time MANIP was entered. |
| Cx,y | Changes accumulator or carry flip-flop: <br> - If $x$ is $0,1,2$, or $3, y$ is stored as saved value for accumulator $x$ (A0, A1, A2, A3, respectively). <br> - If $x$ is 4, saved value of the carry flip-flop is set to 0 if $y=0$; saved value is set to 1 if $\mathrm{y}=1$. <br> - If $x$ is greater than 4 and an address offset has been established (see F command), $x$ is interpreted as a real address using the offset previously established, and typed out on the master terminal. The y parameter is not used in this case. <br> - Parameter Description <br> x - 1 octal digit 0-7 <br> y - 1 word octal |

TABLE 3-12. MANIP COMHAND DESCRIPTIONS (Cont)

| Command \& Parameters | Definition |
| :---: | :---: |
| Dx, a | Dumps memory in octal, beginning at location $x$, using addressing mode a. Eight words (or bytes if a byte address mode is used) are typed per line, with the address of the first word (byte) at the beginning of each line. <br> - Parameter Description <br> $x$ - an octal number representing a 16-bit memory address <br> a - 1 digit ( $0-3$ or omitted) representing an addressing mode |
| Ex, a | Enables entry at address $x$, using addressing mode a. The address (changed to a word address if it was a byte address) is printed, followed by a colon; an octal value may then be entered into the memory location, followed by <RETURN>. The next address $(x+1)$ is then printed and opened for entry. Entry can thus be continued into sequential address locations until ESC is pressed (after <RETURN>) to terminate entry. <br> - If no entry is typed in before <RETURN>, the present contents of the opened location is typed out in octal form, allowing examination of value before entering a new one. If another <RETURN> is entered without an entry, the current value is preserved, and the next address is printed and opened for entry. <br> - If a space character is typed instead of <RETURN, the contents of the previous address is typed and opened. This feature is convenient for confirming an entry just typed in. <br> - Parameter Description <br> $x$ - octal number representing l6-bit memory address <br> a - 1 digit (0-3 or omitted) representing a memory addressing mode |

TABLE 3-12. MANIP COMMAND DESCRIPTIONS (Cont)

| Command \& Parameters | Definition |
| :---: | :---: |
| Fx, ${ }^{\text {P }}$ | Establishes an address offset (i.e., a fixed difference between a real memory address on the one hand and an offset address as entered and listed in MANIP on the other). The difference $x-y$ is added to the offset address entered, and subtracted from the memory address before displaying. If $y$ is not entered, it is assumed to be zero. Whenever a nonzero offset is established, an $F$ is typed at the beginning of eachline. To revert to real memory addressing, type F0. <br> - Parameter Description <br> x - from 1 to 6 digits (octal) representing a real memory address <br> $y$ - from 1 to 6 digits (octal) representing the offset address that is to be made equivalent to the real address specified in $x$ |
| F | Saves the current offset value and reinstates the previous offset in effect before current one was established. Types offset being reinstated. Makes it convenient to toggle back and forth between two different offsets (or one offset and real memory addressing). |
| Jx, a | Jumps to location $x$ (using addressing mode a) with accumulators and carry stored. <br> - Parameter Description <br> $x$ - an octal number representing l6-bit memory address <br> a - 1 digit (0-3 or omitted) representing a memory addressing mode |
| Kx,y,z | Stores the octal constant $z$ in locations $x$ through $y$, inclusive. <br> - Parameter Description <br> x - octal number representing l6-bit beginning memory address <br> $y$ - octal number representing l6-bit ending memory address <br> z-octal number representing constant |

TABLE 3-12. MANIP COMHAND DESCRIPTIONS (Cont)

| Command \& Parameters | Definition |
| :---: | :---: |
| Mx,Y,Z | Moves block in memory. Locations $x$ through $y$ are moved to area starting at location $z$. <br> - Source and destination areas may overlap in either direction without bad effects. <br> - May be used to move MANIP itself as long as destination area does not overlap source area. <br> - Parameter Description <br> x - octal number representing l6-bit beginning memory address <br> $y$ - octal number representing 16 -bit ending memory address <br> $z$ - octal number representing l6-bit beginning memory address of new location |
| $N \mathrm{X}, \mathrm{y}, \mathrm{z}, \mathrm{m}$ | Searches for not-equal (see $S$ command). Searches locations $x$ through y for values not equal to constant $z$. Each word is first ANDed with mask $m$ before comparison with $z$. <br> - If $m$ is not entered, it is assumed to be 177777. <br> - Use of the mask is best explained by an example: The command Nx,Y,0,170000 will search locations $x$ through $y$ for any word whose four MSBs are set to a nonzero value. When such a value is found, its address and contents are displayed in octal form on the CRT. <br> - Parameter Description <br> x - octal number representing l6-bit beginning memory address <br> $y$ - octal number representing 16 -bit ending memory address <br> z - octal number representing constant <br> $m$ - octal number representing mask; the default is 177777 |

TABLE 3-12. MANIP COMMAND DESCRIPTIONS (Cont)

| Command \& Parameters | Definition |
| :---: | :---: |
| Ox, a | Outputs ASCII. Contents of memory starting at location $x$ (using addressing mode a) are typed out as text. Output is terminated if a zero byte is encountered. <br> - Parameter Description <br> x - octal number representing l6-bit memory address <br> a - 1 digit (0-3 or omitted) representing a memory addressing mode |
| Px | Program load from disk or other DMA devices. Performs standard bootstrap APL function (i.e., gives an NIOS instruction with device code $x$ and then idles at location 377 waiting for the disk to overwrite that location). If $x$ is omitted, reads miniswitches at front edge of CPU board and uses their contents as the device code. <br> NOTE <br> If CPU board switches are set to $2 x x$ (octal), MANIP cannot be accessed from memory. Pressing APL causes MANIP to try to boot from device $x x$. <br> - Parameter Description <br> x - 2-digit octal number (0l through 76) representing the disk device code from which the program is to be loaded |


| Command \& Parameters | Definition |
| :---: | :---: |
| Sx,y,z,m | Searches locations $x$ through $y$ for constant $z$. Each word is first ANDed with mask m before comparison with $z$. <br> - If $m$ is omitted, it is assumed to be 177777 . <br> - Use of mask is best explained by an example: The command Sx,y,60025,160077 will search locations $x$ through $y$ for any I/O instruction for device 25. When a comparison is found, its address and contents are typed in octal form on CRT. <br> - Parameter Description <br> x - octal number representing l6-bit beginning memory address <br> $y$ - octal number representing l6-bit ending memory address <br> $z$ - 1 to 6 digits representing octal constant <br> $\mathrm{m}-1$ to 6 digits representing octal mask; the default is 177777 |
| $X X, Y$ | Calculates and types checksum over memory locations $x$ through $y$. Utilizes a revolving checksum (using a SUBL 0,1 instruction, with AO = each word from $x$ through y, and Al = accumulating checksum; initially 0). This ensures that if two words in memory are swapped, the swap will be detected by the checksum. Useful for determining if any word in memory has changed. <br> - Parameter Description <br> $x$ - an octal number representing 16-bit beginning memory address <br> $y$ - an octal number representing a 16-bit ending memory address |

TABLE 3－12．MANIP COMMAND DESCRIPTIONS（Cont）

| Command \＆ Parameters | Definition |
| :---: | :---: |
| Yx | Sets up a RETURN delay，required on some CRTs for proper scrolling．After each subsequent carriage return／line feed，MANIP counts up an accumulator from $x$ to 0 before proceeding．For maximum delay set $x=0$ ，for no delay set $\mathrm{x}=177777$ 。 <br> －Parameter Description <br> x－ 1 to 6 octal digits representing RETURN delay value |
| $x: y$ | Octal value $y$ is stored at location $x$ ，and next cell is opened．See $E$ command for more information． <br> －Parameter Description <br> x－octal number representing l6－bit memory address <br> $y-1$ to 6 digits representing an octal value |
| CTRL（ ） | Any control character（except＜CTRL－W〉）is recognized as a cassette tape unit（CTU） command．MANIP will pass the command to the CTU，with the exception of 〈CTRL－R〉，which it uses to read the CPU．Refer to the Cassette Tape Unit Hardware Manual for CTU commands and command functions． |

$$
-2
$$

## Section 4 <br> INPUT/OUTPUT INTERFACES

### 4.1 INTRODUCTION

This section provides information regarding the basic operating principles and programming methods for the input/output devices that are compatible with the POINT 4 MARK 5/9 computers. Two types of I/O devices are available:

- Those transferring data via I/O programmed instructions only
- Those using the data channel for input/output transfers

The following subsections outline the interrupt handing and priority scheme, conventions for handling the master terminal, programmed transfer handling, and data channel transfer handling. Also provided are I/O bus signal descriptions and I/O transfer timing diagrams.

### 4.2 PROGRAM INTERRUPT AND PRIORITY SCHEME

Many input/output devices require service within a short time after they request it; however, they need service infrequently, relative to the processor speed, and require only a small amount of time for servicing. Failure to service within the specified time (which varies among devices) causes operation of the device to fall below its maximum speed and can result in loss of information.

The use of interrupts in the current program sequence facilitates concurrent operation of the main program and a number of peripheral devices. The program interrupt scheme allows an I/O device to gain control of the processor. When an interrupt occurs, the processor suspends normal program execution and starts a device service routine. When the routine is completed, processing of the interrupted program may resume.

### 4.2.1 INTERRUPT SEQUENCE

When a device needs service, it sets its Interrupt Request flag. The processor begins servicing interrupts if all four of the following conditions exist:

- The processor has just completed an instruction fetch or a data channel transfer
- At least one device has a pending Interrupt Request
- Interrupts are enabled (i.e., ION is set)
- No device is waiting for a data channel transfer

The processor responds to the interrupt request by storing the value of the program counter into memory location 0 and jumping to the instruction addressed by memory location l. Location 1 must contain the address of the interrupt handling routine. Interrupts are disabled at the start of the interrupt service cycle and must be re-enabled by the software at the end of the interrupt service.

### 4.2.2 DEVICE PRIORITY

The processor features a special interrupt acknowledge instruction that eliminates the need for lengthy device polling. This instruction inputs the device code of the interrupting device into an accumulator register, permitting the interrupt service routine to identify the device requesting service. The computer uses a three-way priority system to determine which device (if any) may interrupt the processor at a given moment. First, the processor contains a programmable Interrupt ON (ION) flag. The processor recognizes interrupt requests only when this flag is set. Second, the processor can selectively disable the interrupt capability of each device with the device Interrupt Mask flags (see Section 5.6.2, MSKO instruction). Third, if two or more devices request interrupts simultaneously, the priority resolution is made by the jumper-saver logic on the POINT 4 MARK 5/9 chassis backplane. A device whose controller board is physically closer to the processor is given priority over a device that is further away. See Appendix $E$ for an example of interrupt programming.

### 4.3 PROGRAMMED TRANSFERS

For programmed input/output, the program directly controls the data transfer between the CPU and the I/O device. As discussed in Section 5.6 , each data word is transferred between an accumulator specified in the instruction and an I/O device buffer ( $A$, $B$, or C) specified in the instruction, as shown in Figure 4-1.


## Figure 4-1. Data Word Transfer Between Specified Accumulator and I/O Device Buffer

### 4.3.1 MASTER TERMINAL INTERFACE

The standard Teletype or CRT I/O controller has separate interface logic for input and output. Input and output device codes are also separate. The input logic interfaces to the keyboard and, in some Teletypes, a paper tape reader. The output logic interfaces to the printer or video display and, in some Teletypes, the paper tape punch. When the CRT or Teletype is connected to the computer, a character entered on the keyboard for input to the computer must be "echoed" back to the output interface logic on the terminal in order to appear on the screen or paper.

All alphanumeric and control characters are composed of eight bits. The most significant bit (MSB) is an even parity bit. The remaining seven bits represent the ASCII code (see Appendix C) for an alphanumeric or control character.

### 4.3.2 PROGRAMMING CONVENTIONS

Programming conventions for handling CRT and Teletype terminals are described in the following subsections.

### 4.3.2.1 Instruction Formats

Terminal output and input use separate device codes as specified in bits lo-l5 of the instruction. The $S$ or $C$ pulse may be sent to clear Busy and/or Done flags and control the starting of the transfer between the interface and the device. The data transfer output instructions transmit bits 8-l5 from the specified accumulator to the output interface register. The input instruction loads the input interface register into bits 8-15 and resets bits 0-7 of the specified accumulator.

### 4.3.2.2 Terminal Output

Transmission to the terminal takes place when an $S$ pulse is sent, which sets the output Busy flag. When the character has been printed, the interface clears the Busy flag, sets the Done flag, and requests an interrupt, if interrupts are enabled. Terminal output uses the device code ll, the mnemonic TTO, and uses bit 15 to control the Interrupt Mask flag. To transfer a character from an accumulator to the terminal output buffer, use the instruction DOA ac,TTO
where ac may be any of the four accumulators.
If the NIOS instruction is used to send the $S$ pulse, the instructions must appear in the following sequence:

DOA ac,TTO
NIOS TTO
Normally, this operation is done in one instruction:
DOAS ac,TTO

### 4.3.2.3 Terminal Input Via CRT Keyboard

Terminal input uses octal device code 10 , the mnemonic TTI, and bit 14 to control the Interrupt Mask flag. When a key is pressed on the keyboard, the character is placed in the input buffer, and Done is set. If interrupts are enabled for that device, an interrupt is requested. The program then reads the character with the instruction

DIA ac,TTI
The program then uses an $S$ pulse to clear Done. The $S$ pulse may either be part of the DIA instruction

DIAS ac,TTI
or be generated with an NIO instruction
DIA ac, TTI
NIOS TTI

### 4.3.2.4 Terminal Input Via Paper Tape Reader

When paper tape is used for input, the paper tape reader must be started by the program using the instruction

NIOS TTI
This instruction sets Busy and clears Done in the TTY controller. When the character has been read from paper tape into the controller, the device controller clears Busy and sets Done, producing an interrupt if interrupts are enabled. The program then reads the character with the instruction

DIA ac,TTI
Sequential characters can be read by using the instruction
DIAS ac,TTI
This results in the reading of one character and the restarting of the paper tape reader for reading of the next character.

### 4.4 DATA CHANNEL TRANSFERS

By using the direct memory access (DMA) data channel, mass storage devices, such as tape and disk drives, can transfer blocks of data at high speeds directly into memory without requiring programmed $I / O$ instructions for each word transferred. Data channel device interface logic contains both conventional device registers and flags, and special data channel logic.

The program initiates a data channel transfer by supplying certain parameters to the device registers and starting the device. The device automatically transfers one or more data words to or from memory. When finished with the DMA transfer, the device generates an interrupt if so enabled. At the start of each instruction cycle, the processor checks to see if a device is requesting data channel service. If so, the data channel transfer is performed before going on with the instruction. Several data channel devices can be active at the same time, with devices closest to the processor having channel priority.

The POINT 4 MARK 5 and MARK 9 each have two jumper-selectable data channel speed options:

- Standard data channel (jumper CPU board pin A93 to ground)
- MARK 5

Input - 1100 nanoseconds
Output - 1483 nanoseconds

- MARK 9

Input - 1600 nanoseconds
Output - 2000 nanoseconds

- High-speed data channel (do not jumper CPU board pin A93 to ground; also, ensure that pin $A 93$ is not connected to ground by an etch on the backplane)
- MARK 5

Input - 800 nanoseconds
Output - 933 nanoseconds

- MARK 9

Input - 900 nanoseconds
Output - 1200 nanoseconds

### 4.4.1 SELECTION OF DATA CHANNEL SPEED

CPU logic tests input to pin A93 (top slot of POINT 4 chassis) to determine which speed has been enabled (see Section 4.5.2 for backplane pin assignments). If pin A93 is jumpered to ground, the data channel will operate at standard data channel speeds. If pin A93 is left open, the data channel will operate at high-speed data channel speeds.

### 4.4.2 CRITERION FOR DATA CHANNEL SPEED SELECTION

The high-speed data channel on the POINT 4 MARK 5/9 does not have stringent requirements for controller timing. The controller is given about 200 nanoseconds from the start of DCHA to put its address on the I/O bus. The POINT 4 MARK 5/9 also allows 200 nanoseconds from the start of DCHI before it requires the input data on the I/O bus. (See Section 4.6 .3 on data channel transfer approximate timing.)

The result of this relatively long access time to the I/O bus is that many DMA controllers that cannot operate on a high-speed data channel with other computers can operate on the POINT 4 MARK 5/9 high-speed data channel. Therefore, the high-speed data channel should be used unless the system includes a controller with specifications that indicate otherwise. If operation is inconsistent at high speeds, the user can switch to the standard data channel by jumpering pin A93 of slot occupied by POINT 4 MARK 5 or 9 CPU to ground. If operation is then consistent at the standard data channel speed, this speed should be maintained. Section 2.6.3 contains information on data channel speed selection for the MARK 5/9 universal CPU.

### 4.4.3 DATA CHANNEL ACCESS PRIORITIES

The amount of time a device must wait for data channel access depends on when its request is made within an instruction and how many devices of higher priority are also requesting access. Once the processor reaches a point at which it can pause to handle transfers, a given device must wait until all devices closer to the processor on the bus have been serviced. Under normal conditions, a device can preempt all processor time if it requests access at the maximum rate. An exception is made if power-fail has been sensed, in which case the data channel is allowed only every other cycle. The alternate cycle is used for power-fail interrupt processing. At less than the maximum rate, the closest device never waits longer than the time required for the processor to finish the instruction being performed when the request is synchronized. However, indirect addressing can extend this beyond the normal instruction execution time.

### 4.5 INPUT/OUTPUT BUS INTERFACE SIGNALS

Input/output bus signals connect the processor logic to peripheral device logic. The logic for programmed I/O transfers and data channel transfers forms the interface between the processor main data bus and the peripheral device controller logic. Logic to implement both $I / O$ transfer and $I / O$ skip instructions is present in all device controllers. Data channel transfer logic is present only in those controllers that control devices using the data channel. Device-end control logic for these functions may vary widely, depending on the requirements of the particular device. This subsection describes the POINT 4 MARK 5/9 I/O bus and control signals.

### 4.5.1 INPUT/OUTPUT INTERFACE SIGNALS

Signals on the input/output bus can be grouped into the signal classifications shown in Table 4-1.

Figure 4-2 is a diagram of I/O signals across the I/O bus. Table 4-2 lists these signals by classification group and signal name, indicating direction and describing each signal function.

TABLE 4-1. INPUT/OUTPUT BUS SIGNAL CLASSIPICATIONS

| $\begin{gathered} \text { Signal } \\ \text { Classification } \end{gathered}$ | Number of Lines | Definition |
| :---: | :---: | :---: |
| Bidirectional data bus | 16 | Used for transfer of all data and address words between the CPU and a peripheral device, for both programmed I/O and data channel transfers. |
| Device code | 6 | Code generated by CPU to specify the address of a peripheral device or a controller used for an input/output instruction. |
| Programmed data transfer signals | 6 | These signals, generated by the CPU in response to input/output instructions for data transfers, are used to control data transfers for programmed input/output devices. |
| Device control signals | 4 | These signals are generated by the CPU in response to input/output instructions, and are used to initialize and control I/O devices. The signals affect only the device whose device code is in the instruction, except in the case of the IORST instruction which resets all devices. |
| Skip testing flags | 2 | Flags supplied to the CPU when skip-testing is required. |
| Interrupt control signals | 5 | Signals used to initialize and control the interrupt sequence. |
| Data Channel control <br> signals | 6 | Signals used to control data channel transfers between CPU memory and a peripheral device. |



Figure 4-2. Input/Output Signal Diagram

TABLE 4-2. INPUT/OUTPUT SIGNALS


TABLE 4-2. INPUT/OUTPUT SIGNALS (Cont)

| Signal Group | Signal Name* | Direction | Description |
| :---: | :---: | :---: | :---: |
| Device control signals | IORST+ <br> STRT+ <br> CLR+ <br> IOPLS+ | From CPU <br> From CPU <br> From CPU <br> From CPU | Input/output reset - generated when APL is pressed on the Mini-Panel, when RESET is pressed on the Operator Control Unit, when an IORST instruction is being executed, and during power turn-on. <br> Start - generated when the CTRL field of an input/output transfer instruction contains code 01. It usually clears the Done flag and Interrupt request, and sets the Busy flag in the device whose device code is on the lines. <br> Clear - generated when the CTRL field of an input/output transfer instruction contains code 10. It usually clears the Busy and Done flags and the Interrupt request in the device whose device code is on the lines. <br> I/O pulse - generated when the CTRL field of an input/output transfer instruction contains code ll. The effect, if any, depends on the device. |
| Skip testing flags | SELB- <br> SELD- | From device <br> From device | Selected device busy - supplied to CPU by the device whose device code is on the lines when the Busy flag is set. Indicates that the device is busy. <br> Selected device done - supplied to the CPU by the device whose device code is on the lines when the Done flag is set. Indicates that the device is done. |

TABLE 4-2. INPUT/OUTPUT SIGNALS (Cont)

| Signal Group | Signal Name* | Direction | Description |
| :---: | :---: | :---: | :---: |
| Interrupt control signal | RQENB- | From CPU | Request enable - generated during each memory read/write cycle to synchronize INTR- and DCHR-. In any device, changes in INTR- or DCHR- may only occur following the leading edge (high-to-low transition) of RQENB-. |
|  | INTR- | From device | Interrupt request - this signal goes low (following the leading edge of RQENB-) if the device wants to request an interrupt. |
|  | INTPIN- | From jumper saver | Interrupt priority input - on POINT 4 chassis, this signal is produced by jumper-saver logic on the backplane for highest priority device requesting an interrupt. |
|  |  | Jumpered to ground or from higher priority device | On non-POINT 4 chassis, this signal is produced by a jumper to ground on lowest (highest in priority) I/O board. If the highest priority $I / O$ board in the non-POINT 4 chassis has not requested an interrupt, this signal is output as INTPOUT- to the device next in priority. |
|  | INTA+ | From CPU | Interrupt acknowledge generated by an INTA instruction. Causes the device whose INTPIN- line is low to place its device code in bits 10-15 of the data bus for entry into accumulator specified in the instruction. |
|  | MSKO- | From CPU | Mask out - generated by a MSKO instruction. Commands all I/O devices to set their interrupt disable flags according to the state of the associated mask bit in the word on the data bus. |

TABLE 4-2. INPUT/OUTPUT SIGNALS (Cont)

| Signal Group | Signal Name* | Direction | Description |
| :---: | :---: | :---: | :---: |
| Data <br> channel <br> control <br> signals | DCHR- | $\begin{aligned} & \text { From } \\ & \text { device } \end{aligned}$ | Data channel request - this signal goes low (following the leading edge of RQENB-) if the device wants to request a data channel transfer. |
|  | DCHMO- | $\begin{aligned} & \text { From } \\ & \text { device } \end{aligned}$ | Data channel mode - generated by a device connected to the data channel while DCHA- is low. Indicates the type of data channel cycle being requested as follows: <br> DCHMO <br> Type of Cycle <br> 0 (high) Data out (from CPU) <br> 1 (low) Data in (to CPU) |
|  | DCHPIN- | From <br> jumper <br> saver | Data channel priority input on POINT 4 chassis, this signal is produced by jumper-saver logic on the backplane for highest priority device requesting a data channel transfer. |
|  |  | Jumpered to ground or from higher priority device | On non-POINT 4 chassis, this signal is produced by a jumper to ground on lowest (highest in priority) I/O board. If the highest priority $I / O$ board in the non-POINT 4 chassis has not requested a data channel transfer, this signal is output as DCHPOUT- to the device next in priority. |
|  | DCHA- | From CPU | Data channel acknowledge generated by CPU in response to a data channel request. Initiates a data channel cycle in the device whose DCHPIN- is low. The device places the memory address for data channel access on the data bus. |

TABLE 4-2. INPUT/OUTPUT SIGNALS (Cont)

| Signal <br> Group | Signal <br> Name* | Direction | Description |
| :--- | :--- | :--- | :--- |
|  | DCHI+ | From CPU | Data channel in - when the mode <br> is data in, DCHIt is generated <br> during the time the device is <br> placing a data word on the data <br> bus. <br> DCHO+ |
|  | From CPU | Data channel out - when the <br> mode is data out, DCHO+ is <br> generated during the time that <br> the word accessed from memory <br> is on the data bus. |  |

### 4.5.2 BACKPLANE PIN SIGNAL CONNECTORS

All signal connections between the processor and each controller take place via two l00-pin backplane connectors. Figure 4-3 shows the connector pin layout for all I/O signals. The labeled pins refer to the I/O control signals, data transfer signals, and the power lines used by peripheral controllers.

The POINT 4 MARK 5 and MARK 9 have one special signal, STSEL-, which goes through backplane connector A pin 91. It is a remote Self-Test select signal that allows the CPU Self-Test program to be bootstrapped to memory when the signal is at an active low during the APL sequence.

For a MARK 5 or MARK 9 universal CPU, see Section 2.6 .2 for information about backplane connection requirements.


Figure 4-3. Backplane I/O Signals (1 of 2)

-NOT ON CPU SLOT
BACKPLANE SLOTS 2-7

### 4.6 INPUT/OUTPUT TIMING

Three classes of operations take place on the I/O bus: those associated with programmed I/O instructions, those associated with interrupt handling, and those associated with data channel transfers. Timing diagrams in this section represent each signal or group of signals by a horizontal line with a raised section representing the active state. Control signals generated at a specific time to control a particular function show the raised line for the time that the signal is active. For signals carrying binary information, the raised line indicates the amount of time that information remains on the bus. Raised lines may represent either high or low voltage levels, depending on whether the signal is active when low or high. (See Table 4-1 for active voltages on all signals.) Times on timing diagrams are given in nanoseconds.

### 4.6.1 PROGRAMMED I/O INSTRUCTION TIMING

Figures 4-4 through 4-6 are programmed I/O instruction timing diagrams. These figures show the timing for data in (DIx) and data out (DOx) instructions both with and without a control pulse ( $\mathrm{S}, \mathrm{C}$ or P ) specified. In all cases, the processor first places the appropriate device code on the device select lines DSO-DS5. The selected device then responds to the signals that follow.

### 4.6.1.1 Data In

During data-in transfers, the processor generates a DATIA+, DATIB+, or DATIC+ signal. The device selected then places the contents of its appropriate buffer onto the data transfer lines. At the end of the DATIx active signal, the processor strobes the value on the data lines into the appropriate processor accumulator. Following the transfer, the processor generates the pulse for a START (S), CLEAR (C), or PULSE (P), if called for by the instruction.

### 4.6.1.2 Data Out

During data-out transfers, the processor places the contents of the accumulator selected by the instruction onto the data transfer lines. The processor then generates a DATOA+, DATOB+, or DATOC+ signal, which causes the device to strobe in the data to the buffer specified. When the data has been loaded into the buffer, the processor generates the pulse for START (S), CLEAR (C), or PULSE (P), if called for by the instruction.


DIAS
DEVICE SELECT instruction fetch

DATIA+ CLOCK DATA

START+


DOA
DEVICE SELECT INSTRUCTION FETCH

DATA AVAILABLE

DATOA+






Figure 4-5. Programmed I/O Instruction Timing for MARK 5 with EIS



Figure 4-6. Programmed I/O Instruction Timing for MARK 9

### 4.6.2 PROGRAM INTERRUPT TIMING

At the end of every memory cycle, the processor generates the signal RQENB- and places it on the I/O bus. All devices receive the RQENB- signal and each responds according to its need for service. Any device requiring interrupt servicing pulls the signal INTR- low.

Figures 4-7 through 4-9 are timing diagrams of interrupt handling.


[^5]$085-64$

Figure 4-7. Interrupt Timing for MARR 5


RQENB- = REQUEST ENABLE: PROVIDES A CLOCK SIGNAL TO SYNCHRONIZE INTERRUPT REQUESTS (AS WELL AS DATA CHANNEL REQUESTS) FROM PERIPHERAL CONTROLLERS. ITS NOMINAL PERIOD IS 400ns (200ns OFF, 200ns ON). CONTROLLERS MAY CHANGE INTR (INTERRUPT REQUEST) OR DCHR - (DATA CHANNEL REQUEST) ONLY AT THE LEADING EDGE OF RQENB-.

INTR = INTERRUPT REQUEST: SENSED BY CPU APPROXIMATELY 100ns BEFORE THE END OF EACH INSTRUCTION. IF INTR IS PRESENT, THE NEXT THREE MEMORY CYCLES (1200ns) ARE TAKEN TO SAVE PC IN LOCATION $O$ AND TO JUMP TO THE INTERRUPT SERVICE ROUTINE WHOSE ADDRESS IS IN LOCATION 1.

# Figure 4-8. Interrupt Timing for MARK 5 with EIS 



RQENB- = REQUEST ENABLE: PROVIDES A CLOCK SIGNAL TO SYNCHRONIZE INTERRUPT REQUESTS (AS WELL AS DATA CHANNEL REQUESTS) FROM PERIPHERAL CONTROLLERS. ITS NOMINAL PERIOD IS 600ns ( 300 ns OFF, 300 ns ON). CONTROLLERS MAY CHANGE INTR (INTERRUPT REQUEST) OR DCHR - (DATA CHANNEL REQUEST) ONLY AT THE LEADING EDGE OF RQENB-.

INTR = INTERRUPT REQUEST: SENSED BY CPU ABOUT 100ns BEFORE THE END OF EACH INSTRUCTION. IF INTR IS PRESENT, THE NEXT THREE MEMORY CYCLES ( 1200 ns ) ARE TAKEN TO SAVE PC IN LOCATION O AND TO JUMP TO THE INTERRUPT SERVICE ROUTINE WHOSE ADDRESS IS IN LOCATION 1.

085-55

Figure 4-9. Inter rupt Timing for MARK 9

### 4.6.3 DATA CHANNEL TRANSFER TIMING

Data channel transfers are in either the input or output direction (data channel input is a write into memory and data channel output is a read from memory). In either case, the device first requests use of the $I / O$ bus. When the processor acknowledges the request, it stops program execution long enough to conduct the transfer between the device and memory.

Operations in data channel requests are similar to those of an Interrupt request. At the end of every memory cycle, the processor generates the signal RQENB- and places it on the I/O bus. All devices receive the RQENB- signal and each responds according to its need for service. Any device requiring data channel service pulls the DCHR- line low. The jumper saver logic on the POINT 4 chassis backplane then determines which is the highest priority device requesting data channel service, and sends DCHP- (data channel priority) to that device. Devices whose DCHP- lines are inactive (high) ignore subsequent data channel control signals.

When the processor is ready to process the data channel request, it activates the signal DCHA- (data channel address). The device whose DCHP- line is active (low) places the address for the DMA transfer on the $I / O$ bus during DCHA-. At the same time, the device also activates or negates DCHMO- to specify whether an input or output transfer is to take place.

When DCHA- terminates, the processor strobes the address into its memory address register. From this point on, the operation depends on the direction of the data channel transfer.

- Data channel input - when a data input transfer is required, the processor transmits DCHIt immediately following the trailing edge of DCHA-. The device then places the data word onto lines DATAO through DATAl5. Near the trailing edge of DCHIt, the processor stores the data word into memory, and the device removes the data word from lines DATA0- through DATAl5-.
- Data channel output - in an output transfer, the processor starts a read memory cycle at the trailing edge of DCHA-. When the data has been fetched from memory, the processor places the word on lines DATAO- through DATAl5- and activates a DCHO+ signal. The device then fetches the data from the data lines.

When the transfer required is a single-word transfer, the device clears DCHR- the next time it receives RQENB-. If the transfer required is several words in consecutive data channel cycles, the DCHR- flag should remain active until the leading edge of RQENBfollowing the DCHA- of the last transfer desired.

Figures 4-10 through 4-12 are timing diagrams of standard data channel operations and Figures 4-13 through 4-15 are timing diagrams of high-speed data channel operations.



Figure 4-10. Standard Data Channel Timing for MARR 5


Figure 4-11. Standard Data Channel Timing
for MARK 5 with EIS



Figure 4-12. Standard Data Channel Timing for MARK 9


Figure 4-13. High-Speed Data Channel Timing


Figure 4-14. High-Speed Data Channel Timing for MARR 5 with EIS


Figure 4-15. High-Speed Data Channel Timing for MARK 9

### 4.7 INPUT/OUTPUT CONNECTORS

Four connector sockets may be found on the rear of the POINT 4 MARK 5/9 processor chassis. Figure 4-l6 illustrates the positions of these connectors on the processor backplane.

### 4.7.1 POWER CONNECTORS

Two of these sockets on the processor chassis receive power cables carrying power supply voltages from the POINT 4 MARK 5 or MARK 9 Power Supply. These connector sockets are:

Socket
Mounting Position
12-pin Top center of the POINT 4 MARK 5/9 backplane
26-pin Upper right side of POINT 4 MARK 5/9 backplane
Instructions for the connection of these cables between the POINT 4 MARK 5/9 power supply chassis and the POINT 4 MARK 5/9 processor chassis are found in Section 2.3.4.

### 4.7.2 EXTERNAL I/O DEVICE CONNECTOR

I/O bus signals from external peripheral controllers (i.e., controllers not housed inside the POINT 4 MARK $5 / 9$ chassis) are carried to the processor via a 50-connector cable. The connector for this cable is located on the lower right-hand side of the POINT 4 MARK 5/9 backplane. This I/O connector is high priority. Pin assignments for this connector are shown in Table 4-3.


Figure 4-16. Input/Output Connector Locations

TABLE 4-3. EXTERNAL I/O DEVICE CONNECTOR PIN ASSIGNMENTS

| Pin Number | Signal Name | Backplane Reference |
| :---: | :---: | :---: |
| 1 | GND | Al, 2 |
| 2 | CLR+ | A50 |
| 3 | DATA0- | B62 |
| 4 | DATAl- | B65 |
| 5 | DATA2- | B82 |
| 6 | DATA3- | B73 |
| 7 | DATA4- | B61 |
| 8 | DATA5- | B57 |
| 9 | DATA6- | B95 |
| 10 | DATA7- | B55 |
| 11 | DATA8- | B60 |
| 12 | DATA9- | B63 |
| 13 | DATAl0- | B75 |
| 14 | DATAl1- | B58 |
| 15 | DATAl2- | B59 |
| 16 | DATAl3- | B64 |
| 17 | DATAl 4- | B56 |
| 18 | DATAl5- | B66 |
| 19 | DATIA+ | A44 |
| 20 | DATIB+ | A42 |
| 21 | DATIC+ | A54 |
| 22 | DATOA + | A5 8 |
| 23 | DATOB+ | A56 |
| 24 | DATOC+ | A48 |
| 25 | DCHA- | A60 |
| 26 | DCHI+ | B37 |
| 27 | DCHMO- | Bl7 |
| 28 |  | B21 |
| 29 | DCHO+ | B33 |
| 30 | DCHPIN- | JUMPER SAVER |
| 31 | DCHR- | JUMPER SAVER |
| 32 | DSO- | A72 |
| 33 | DSI- | A6 8 |
| 34 | DS2- | A66 |
| 35 | DS4- | A46 |
| 36 | DS4- | A62 |
| 37 | DS5- | A64 |
| 38 | INTA+ | A40 |
| 39 | INTPIN- | JUMPER SAVER |
| 40 | INTR- | JUMPER SAVER |
| 41 | IOPLS+ | A74 |
| 42 | IORST+ | A70 |
| 43 | MSKO- | A3 8 |
| 44 | * | B38 |
| 45 | RQENB- | B41 |
| 46 | SELB- | A82 |
| 47 | SELD- | A80 |
| 48 | STRT+ | A52 |
| 49 | +5V | A3, 4 |
| 50 | GND | Al, 2 |
| *Not used by POINT 4 MARK 5 or 9 CPU |  |  |
| $\begin{aligned} & 85-0023-01 \\ & \text { JT } 4 \text { Data Cc } \end{aligned}$ | on 4-3 | INPUT/OUTPUT INTER MARK 5/9 Reference |

### 4.7.3 MASTER TERMINAL CONNECTOR

The master terminal can be interfaced to the POINT 4 MARK 5/9 via a cable connected at the upper left-hand corner of the backplane. To use this connector, the controller (standard I/O, device code lo/ll) must be in CPU slot 2 or 3 (second or third from top). If the controller board is in slot 3, slot 2 must not be used. Pin assignments for master terminal interface are shown in Table 4-4. Note that POINT 4 MUX boards do not use these pins.

TABLE 4-4. MASTER TERMINAL INTERFACE PIN ASSIGNMENTS

| Pin Number | Signal Name | Backplane Reference |
| :---: | :--- | :--- |
| 1 | Not Connected | - |
| 2 | Not Connected | - |
| 3 | TTYIN | 2 B69 |
| 4 | $-5 V$ | A6 |
| 5 | Not Connected | - |
| 7 | TTYOUT | 2 A85 |
| 8 | STPV | Al0 |
| 9 | GND | $2 A 87$ |

# Section 5 <br> STANDARD INSTRUCTION SET 

### 5.1 INTRODUCTION

This section explains the function and use of POINT 4 MARK 5/9 instructions. Included is a discussion of two's complement notation, addressing modes, and the individual instructions in the memory reference, arithmetic/logic, and input/output instruction groups. Input/output instructions and interrupt handling instructions are presented, with details given for special code-77 (CPU) instructions.

### 5.2 OCTAL REPRESENTATION AND TWO'S COMPLEMENT NOTATION

The computer uses l6-bit binary words for program instructions and data. The bits are numbered 0 through 15 with bit 0 the most significant bit (MSB) and bit 15 the least significant bit (LSB). For convenience, binary words are represented in 6-digit octal form. Each octal digit represents three bits and can have values between 0 and 7, except the most significant digit, which represents a single bit and has a maximum value of l. The POINT 4 MARK 5/9 l6-bit binary word format is shown in Figure 5-1.


Figure 5-1. POINT 4 MARR 5/9 16-bit Binary Word Format

The reader is presumed to be familiar with binary and octal notations. For a simple review, the following example shows the correspondence between decimal, binary, and octal representation:

Decimal

| 0 | 0000000000000000 | 000000 |  |
| :--- | :--- | :--- | :--- |
| 1 | 0000000000000001 | 000001 |  |
| 2 | 000000000000010 | 000002 |  |
| 8 | 0000000000001000 | 000010 |  |
| 64 | 0000000001000000 | 000100 |  |
| 5407 | 0001010100011111 | 012437 |  |
| 32,767 | 011111111111111 | 077777 | (15 bit max.) |
| 65,535 | 11111111111111111 | 177777 | (16 bit max.) |

The computer represents negative numbers in two's complement form. Signed positive and negative numbers are used both as l6-bit operands and as 8-bit address displacements in memory reference instructions. A review of two's complement arithmetic follows.

In two's complement arithmetic, positive and negative values are distinguished by a or 0 in the leftmost bit position (sign bit). Positive numbers have a sign bit of 0 , with the numerical value expressed in ordinary binary form by the remaining bits. Negative numbers have a sign bit value of 1 and the numerical value expressed in two's complement form. The two's complement is found by taking the one's complement or logical complement of the number including the sign bit (changing all $0 s$ to $1 s$ and all ls to $0 s$ ) and adding 1.

The number zero is represented by 0 s in all bit positions. There is only one representation for zero, since the two's complement of zero is also zero. zero is a nonnegative value. For this reason also, there is one more negative number than there are nonzero positive numbers.

The range of signed, 8-bit fields is as follows:

| Binary |  |  | Octal |
| :---: | :---: | :---: | :---: |
| Representation |  |  | Value |
| 01 | 111 | 111 | +177 |
| 01 | 111 | 110 | +176 |
|  | - |  |  |
|  | - |  |  |
| 00 | 000 | 001 | +1 |
| 00 | 000 | 000 | 0 |
| 11 | 111 | 111 | -1 |
| 11 | 111 | 110 | -2 |
|  | - |  |  |
|  | - |  |  |
| 10 | 000 | 001 | -177 |
| 10 | 000 | 000 | -200 |

### 5.3 INSTRUCTION TYPES

From the programmer's point of view, the POINT 4 MARK 5/9 Computer contains four accumulators, 64 K words memory, and an input/output bus. The instructions control and manipulate the data flowing between these elements.

Instruction words can be classified into one of the following three categories:

1. Memory reference instructions are instructions that reference a memory location. These include:
LDA - Load an accumulator from memory
STA - Store an accumulator into memory
JMP - Jump to another location in memory
JSR - Jump to a subroutine in memory
ISZ - Increment memory and skip if zero
DSZ - Decrement memory and skip if zero
2. Arithmetic/logic instructions are instructions that specify a particular arithmetic or logical operation to be performed on one or two operands stored in the accumulators, and allow for testing the result for skip conditions.
3. Input/output instructions are instructions for input/output operations with a specific peripheral device.

Figure 5-2 is an overview of the formats for each type of instruction. Each of these three classes is discussed in detail in the following subsections.




,
童

085-30

Figure 5-2. POINT 4 MARR 5/9 Instruction Format Summary Figure5

### 5.4 MEMORY REFERENCE INSTRUCTIONS

Six memory reference instructions are used to move data between memory locations and accumulators, to transfer program control to a new location, and to modify and test memory words. The memory reference instructions fall into three general categories, as follows:

1. Move data instructions: LDA, STA
2. Jump instructions: JMP, JSR
3. Modify memory instructions: ISZ, DSZ

Before describing the function of each instruction in this group, it is necessary to describe the way in which they address memory.

### 5.4.1 MEMORY ADDRESSING

Each memory reference instruction uses one of several addressing modes to determine an effective memory address, E. The processor accesses the location specified by the effective memory address and uses the contents as the operand of the instruction.

The jump instructions (JMP, JSR) and the modify memory instructions (ISZ, DSZ) both use the binary format shown in Figure 5-3.


I=INDIRECT
X=INDEX MODE
085-12
Figure 5-3. Jump and Modify Memory Instruction Binary Word Format

Bits 0-4 of the instruction word are the OPCODE field. Bit 5 is the indirect or $I$ field; bits 6 and 7 are the index mode or $X$ field; and bits 8-15 are the displacement or $D$ field.

The move data instructions (LDA, STA) use the binary format shown in Figure 5-4.

| 0 | 3 | 4 | 5 | 6 |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| OPCODE | ac | 1 | $\times$ |  | DISPLACEMENT |

I=INDIRECT
X=INDEX MODE
085-13

Figure 5-4. Move Data Instruction Binary Word Format

All addresses, both direct and indirect, are entered into the Effective Address Register. When this register contains the effective address $E$, the instruction specified in bits 0 through 4 of the command is executed.

Table 5-1 defines the memory reference instructions, indicating bits, their fields, and field definitions.

TABLE 5-1. MEMORY REFERENCE INSTRUCTIONS

| Bits | Field | Definition |
| :---: | :---: | :---: |
| 0-2 | OPCODE | Determines which instruction is performed. For the move data instructions (LDA, STA), bits 0,1 and 2 make up the OPCODE field. For the jump instructions (JMP, JSR), and modify memory instructions (ISZ, DSZ), bits 0-4 make up the OPCODE field. |
| 3,4 | Accumulator (ac) | The ac field for the Move Data instructions (LDA, STA) specifies one of the four general accumulators. The specified accumulator will either have data stored in it or data transferred from it. |
| 5 | ```Indirect (I)``` | Determines whether the X and D fields specify the effective address (E) directly or whether indirect addressing is to be used. |
| 6,7 | Index Mode (X) | Defines one of the four addressing modes. Each addressing mode may be thought of as a page of 256 words that the instruction can address directly. |
| 8-15 | Displacement (D) | Specifies the word addressed on the selected page. |

### 5.4.1.1 Indexing Mode

The $X$ field selects one of the indexing modes shown in Table 5-2. TABLE 5-2. INDEXING MODES

| $\begin{aligned} & \text { Bits } \\ & 6-7 \end{aligned}$ | Definition |
| :---: | :---: |
| 00 | Page zero - defined as the first 256 memory locations (addresses in the range from 000000 to 000377 octal). The effective memory address in page zero addressing is equal to the value of the $D$ field, which is an unsigned binary integer that can have values from 000 octal to 377 octal. |
| 01 | Relative addressing - in the relative addressing mode, the address placed in the Effective Address Register is equal to the address in the program counter (PC) plus the value of the displacement in the $D$ field. In this case, the displacement $D$ is a signed binary integer. Bit 8 is the sign ( $0=$ positive $1=$ negative) and the integer may have any value in the range from -200 to +177 octal (decimal -128 to +127). The address in PC can be visualized as the center of a 256 -word page and any address between the bottom (128 words below the PC) and top (l27 words above PC) of the page can be specified by the displacement $D$. |
| $\begin{aligned} & 10 \\ & \text { or } \\ & 11 \end{aligned}$ | Base register addressing - in the base register addressing mode, the address placed in the Effective Address Register is equal to the address in accumulator register A2 (code l0) or A3 (code ll) plus the value of the displacement in the $D$ field. In this case the displacement $D$ is a signed binary integer. Bit 8 is the sign $(0=$ positive, $1=$ negative) and the integer may have any value in the range from -200 octal to +177 octal (decimal -128 to +127). The address in A2 or A3 can be visualized as the center of a 256 -word page and any address between the bottom ( 128 words below A2 or A3) and top ( 127 words above A2 or A3) of the page can be specified by the displacement $D$. |

### 5.4.1.2 Indirect Addressing Operations

When the $I$ field (bit 5) of the memory reference instruction contains a l, an indirect addressing sequence is required. In this case, the address in the Effective Address Register (determined by the $X$ and $D$ fields) is the memory address from which a second address word is to be fetched.

This address word can be interpreted as follows:

- If the most significant bit of the address word equals 0, this address word is the effective address, $E$.
- If the most significant bit of the address word equals l, the action taken depends on whether the processor is set in 32 K or 64 K -addressing mode, as described below.

When the processor is in 32 K (normal) mode, a second level of indirect addressing is allowed. In this case, if the most significant bit (bit 0) of the address word fetched from memory contains a l, another level of indirect addressing is required, and the address word in the Effective Address Register specifies the address word to be fetched from memory. The process continues until an address word with bit $0=0$ is found. Through programming error, it is possible to become caught in an infinite loop of indirect addressing. Caution should be taken to avoid this problem when using indirect addressing.

When the processor is in 64 K mode, a second level of indirect addressing is not permitted. In this case, all 16 bits of the word fetched from memory are used as the effective address. A l in bit 0 of the address word simply indicates an address in the upper 32 K words (100000-177777) of memory.

### 5.4.1.3 Automatic Incrementing and Decrementing of Locations

If at any time during the indirect addressing sequence the Effective Address Register contains an address in the range from 000020 octal to 000037 octal, the following auto-indexing action is performed:
l. The contents of the memory location specified by the Effective Address Register are fetched, and the contents are either incremented or decremented by one, as follows:

- If the address is in the range 000020 octal through 000027 octal, the contents are incremented.
- If the address is in the range 000030 octal through 000037 octal, the contents are decremented.

2. The incremented or decremented value is written back into the same memory location from which the value was fetched in step 1.
3. The incremented or decremented value produced in step lis stored in the Effective Address Register and used for the next level of indirect addressing (if bit $0=1$ and the processor is set to 32 K -addressing mode), or for the effective address (if bit $0=0$ or the processor is in 64K-addressing mode).

NOTE
The value of bit 0 following incrementing or decrementing controls continuation of indirect addressing.

### 5.4.2 TYPES OF MEMORY REFERENCE INSTRUCTIONS

When the Effective Address Register contains the effective address $E$, one of two groups of memory reference instructions is performed as determined by the operation codes. Refer to Section 5.4.l for basic memory reference instruction formats and field definitions. Refer to Appendix A (Von Neumann Map of the POINT 4 MARK 5/9 Command Structure) for octal formats of each instruction, and to Appendix B (POINT 4 MARK 5/9 Instruction Reference Chart) for octal-to-symbolic conversion of memory reference instructions.

### 5.4.2.1 Move Data Instructions

When the code in bits 0-2 of the OPCODE field is not 000, and the effective address (E) is in the Effective Address Register, two operations are performed, as shown in Table 5-3.

TABLE 5-3. MOVE DATA INSTRUCTIONS

| Bits <br> $0-2$ | OPCODE | Definition |
| :--- | :--- | :--- |
| 001 | LDA | Load accumulator instruction - the contents <br> of memory location E are stored in the <br> accumulator specified by the ac field <br> (bits 3 and 4). The contents of E are <br> unaffected; the original contents of the <br> accumulator are lost. |
| 010 | STA | Store accumulator instruction - the data in <br> the accumulator specified by the ac field <br> is transferred to memory location E. The <br> contents of the accumulator are unaffected; <br> the original contents of E are lost. |

### 5.4.2.2 Jump and Modify Memory Instructions

When bits 0,1 and 2 are all zero, and the effective address (E) is in the Effective Address Register, one of four operations is performed. The operation is specified by the code in bits 3 and 4 of the OPCODE extension field. These jump and modify memory instructions are shown in Table 5-4.

TABLE 5-4. JUMP AND MODIFY MEMORY INSTRUCTIONS

| $\begin{aligned} & \text { Bits } \\ & 0-4 \end{aligned}$ | OPCODE | Definition |
| :---: | :---: | :---: |
| 00000 | JMP | Jump instruction - the effective address E is transferred from the Effective Address Register to the program counter (PC). The next instruction is then fetched from jump address $E$ and sequential execution is continued from there. |
| 00001 | JSR | Jump to subroutine instruction - after the effective address $E$ has been calculated, the address in PC is incremented and the incremented value is stored in accumulator A3. Then the effective address $E$ is transferred from the Effective Address Register to the program counter (PC). The next instruction is then fetched from jump address E. Execution of another JMP or JSR instruction that specifies A3 will cause the program to return to the address in $A 3$ plus or minus any desired displacement D . |
| 00010 | ISZ | Increment and skip if zero - the contents of effective address are fetched, incremented, and written back into address E. If the incremented value is equal to zero, PC is incremented by one to skip the next instruction. |
| 00011 | DSZ | Decrement and skip if zero - the contents of the location specified by effective address $E$ are decremented and written back into address E. If the decremented value is equal to zero, PC is incremented by one to skip the next instruction. |

### 5.4.2.3 Assembler Language Conventions and Addressing Examples

The assembler language memory reference instruction consists of the instruction OPCODE mnemonic (STA, LDA, JMP, etc.) followed by symbols that specify the accumulator, the addressing mode, and the memory address. The assembler program translates these statements into binary code which the processor executes. Table 5-5 shows the programming conventions for memory reference instructions.

The format for modify memory and jump instructions requires the instruction mnemonic and a memory address, including displacement, indexing, and indirect addressing indicators. The assembly language instruction will be formatted as follows:


The move data instructions LDA and STA also require that an accumulator (AO-A3) be specified. For example


Fields that are not specified will be assembled containing 0s. An "@" symbol denotes indirect addressing and places a 1 in bit 5 of the instruction. An example of indirect page-zero (X Field $=00$ ) addressing is as follows:

LDA 1,020
Relative addressing is formatted as follows:
LDA 0,. +15
The symbol "." indicates $X=01$ (relative addressing) and thus "." represents the current value of the program counter.

TABLE 5-5. ASSEMBLER LANGUAGE CONVENTIONS FOR MEMORY REFERENCE INSTRUCTIONS

| Instruction Function | OPCODE <br> Mnemonic | Separator Space or Tab | Accumulator Number | , | Memory Address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Indirect | Displamt | , | Index |
| Load accumulator <br> Store accumulator | LDA <br> STA |  | ac* | , |  |  |  | blank |
| Jump | JMP |  |  |  | blank or | Displace ment | , | 1** |
| Jump <br> subroutine | JSR |  |  |  |  |  |  | 2 |
| Increment and skip if Zero | ISZ |  | none |  |  |  |  |  |
| Decrement and skip if zero | DSZ |  |  |  |  |  |  |  |
| $* a c=0,1 \text {, }$ <br> **Instead of ". $\pm$ displac | *"Instead of "displacement,1" the following sequence may be used: ".土displacement" |  |  |  |  |  |  |  |

### 5.5 ARITHMETIC/LOGIC INSTRUCTION GROUP

The eight arithmetic/logic instructions perform binary addition, subtraction and logical functions on l6-bit operands. These instructions are:

- Arithmetic: ADD, ADC, INC, SUB, NEG
- Logic: MOV, COM, AND

All arithmetic and logic instructions contain a in bit 0 and have their basic arithmetic/logic unit (ALU) function specified by bits 5-7, as shown in Figure 5-5. The fields of the arithmetic/logic instruction format are as follows:

- Source accumulator (ACS)
- Destination accumulator (ACD)
- OPCODE
- Shifter/swapper (SH)
- Carry preselect (CY)
- No-load (NL)
- Skip condition tester (SK)


085-14

Figure 5-5. Arithmetic/Logic Instruction Format

### 5.5.1 ARITHMETIC/LOGIC PROCESSING

The organization of the arithmetic/logic processing unit must be described before discussion of the eight arithmetic and logic instructions and their auxiliary control fields. Subsystem organization is shown in Figure 5-6 and described in the following subsections.


Figure 5-6. Arithmetic/Logic Operations

### 5.5.1.1 Arithmetic/Logic Operations

The heart of the subsystem is the arithmetic/logic unit (ALU), which performs the actual addition, subtraction, or logical operation. It has provision for two inputs:

- Input 1 - comes from the accumulator selected by the ACD field and is used only in the operations that require two operands (ADD, SUB, ADC, and AND).
- Input 2 - comes from the accumulator selected by the ACS field and is used in all operations.

The ALU performs the arithmetic or logical operation specified by the OPCODE field (bits 5-7). The result of this operation may cause a carry-out (COUT) to occur from the most significant bit of the ALU. In the case of an operation that adds unsigned integers, a carry-out is equivalent to overflow; however, this is not always true. See Section 5.5.1.2 for a more complete discussion of carry and overflow operation.

If the result of the arithmetic or logical operation involves a carry-out, the carry preselected by the Cy field of the instruction (CSEL) is complemented. The resulting carry (CRES) along with the l6-bit operation result generated by the ALU is applied as a l7-bit operand to the shifter, where a shift-left, shift-right, or swap may occur as determined by the SH field of the instruction. After shifting, the carry (CNEW) and the l6-bit operation result are loaded into the Carry flag (C) and the destination accumulator (ACD) unless this is prevented by a 1 in the No-Load (NL) field. In either case, they are tested for a skip condition (i.e., to determine if the next instruction should be skipped) as specified in the $S K$ field of the instruction.

### 5.5.1.2 Overflow and Carry-Out Operations

The l6-bit numbers processed by the ALU may be thought of as unsigned integers between 0 and 65535 or as signed integers between -32768 and +32767 .

Binary Number

| ( in ALU) | Octal | Decimal | Octal | Decimal |
| :---: | :---: | :---: | :---: | :---: |
| llllllllllllllll | 177777 | 65535 | -00001 | -1 |
| 1111111111111110 | 177776 | 65534 | -00002 | -2 |
| - |  |  |  |  |
| - |  |  |  |  |
| 1000000000000001 | 100001 | 32769 | -77777 | -32767 |
| 1000000000000000 | 100000 | 32768 | -100000 | -32768 |
|  | 077777 | 32767 | +77777 | 32767 |
| O111111111111110 | 077776 | 32766 | +77776 | 32766 |
| - |  |  |  |  |
|  |  |  |  |  |
| 0000000000000001 | 000001 | 1 | +00001 | 1 |
| 0000000000000000 | 000000 | 0 | 00000 | 0 |

When working with either interpretation, there is the possibility of an overflow (answer greater than the maximum number that can be represented) or underflow (less than the minimum). In general, the ALU will produce the correct result if no overflow or underflow occurs, and will produce 65536 more than or less than the correct result if there is underflow or overflow, respectively.

The relationship between underflow/overflow and the carry-out from the ALU MSB is shown in the following paragraphs.

1. Unsigned integers:

$$
\begin{array}{ll}
\text { Decimal: } & 0<=x<=65535 \\
\text { Octal: } & 0<=x<=177777
\end{array}
$$

When ADDing two numbers, if the true result is less than or equal to 65535, the ALU will produce the correct result and no carry-out will result. If the true result is greater than 65535, the ALU will produce 65536 less than the true result (i.e., the true result truncated to 16 bits) and a carry-out will result. Note that in these cases, a carry-out is synonymous with overflow and indicates that the ALU output is not the true result.

SUBtraction is accomplished in the ALU by complementing the subtrahend and adding it to the minuend with a carry-in. Therefore, when SUBtracting one unsigned integer from another, if the true result is positive or zero, the ALU will produce the true result and will also produce a carry-out.

If the true result is negative, the ALU will produce the true result plus 65536 (since all numbers are interpreted as positive) and no carry-out will result. Note that, in these cases, a carry-out is the opposite of underflow and indicates that the ALU output is the true result.
2. Signed integers:

$$
\begin{array}{ll}
\text { Decimal: } & -32768<=x<=32767 \\
\text { Octal: } & -100000<=x<=77777
\end{array}
$$

When ADDing two positive integers (or suBtracting a negative integer from a positive one), if the true result is less than or equal to 32767, the ALU will produce the true result and no carry-out. If the true result is greater than 32767, the ALU output will appear negative (since the MSB=1), will be 65536 less than the true result, and no carry-out will occur. Note that, in this case, an overflow is not signaled by a carry-out.

When ADDing two integers with opposite signs (or SUBtracting two numbers having the same sign) the ALU will always produce the true result since the true result must be between - 32768 and +32767. A carry-out will occur if the result is positive and not if it is negative.

When ADDing two negative numbers (or SUBtracting a positive number from a negative one), if the true result is greater than or equal to -32768, the ALU will produce the true result. If the true result is less than -32768, the ALU output will appear positive ( $M S B=0$ ) and will be 65536 greater than the true result. In either case, a carry-out will always occur.

These relationships are illustrated in Figure 5-7.


Figure 5-7. Overflow and Carry Operations
Analysis for Signed Integers

### 5.5.2 ARITHMETIC/LOGIC FUNCTIONS

The OPCODE field (bits 5 through 7) defines one of eight arithmetic/logic operations to be performed by the l6-bit ALU, as shown in Table 5-6.

TABLE 5-6. ARITHMBTIC/LOGIC FUNCTIONS

| $\begin{aligned} & \text { Bits } \\ & 5-7 \end{aligned}$ | OPCODE | Definition |
| :---: | :---: | :---: |
| 000 | COM | Complement - complement the contents of ACS. Do not modify the preselected carry bit. |
| 001 | NEG | Negate - produce the two's complement of the contents of ACS. If ACS=0, complement the preselected carry bit. |
| 010 | MOV | Move - supply the unmodified contents of ACS. Do not modify the preselected carry bit. |
| 011 | INC | Increment - add 1 to the contents of ACS. If the result is 0 , complement the preselected carry bit. |
| 100 | ADC | Add complement - add the complement of ACS to ACD. Complement the preselected carry bit if ACS is less than ACD.* |
| 101 | SUB | Subtract - subtract ACS from ACD. Complement the preselected carry bit if ACS is less than or equal to ACD.* |
| 110 | ADD | Add - add the contents of ACS to the contents of ACD. If the unsigned sum is greater than or equal to 2 to the l6th power, complement the preselected carry bit. |
| 111 | AND | And - logically AND the contents of ACS with the contents of ACD. Do not modify the preselected carry bit. |
| *Using a l6-bit unsigned integer interpretation. |  |  |

### 5.5.3 SECONDARY FUNCTIONS

The shift (SH), carry (CY), no-load (NL), and skip (SK) fields specify secondary operations performed on the ALU result produced by the OPCODE field. These fields are discussed in the following sections.

### 5.5.3.1 Shift Field (SH)

The SH field (bits 8 and 9) determines the shifting action (if any) produced by the shifter on the result of the calculation produced by the $A L U$, as shown in Table 5-7.

TABLE 5-7. SHIFT FIELD DEFINITIONS

| $\begin{aligned} & \text { Bits } \\ & 8-9 \end{aligned}$ | Mnemonic | Definition |
| :---: | :---: | :---: |
| 00 | - | No shift - do not modify the ALU result. The carry resulting from the ALU operation is unaffected. |
| 01 | L | Left rotate - shift the result one place to the left and insert the state of the carry resulting from the ALU (CRES) in the LSB (bit 15) position. Insert the out-shifted MSB (bit 0) into the carry bit (CNEW). |
| 10 | R | Right rotate - shift the result one place to the right and insert the state of the carry resulting from the ALU (CRES) into the MSB (bit 0) position. Insert the out-shifted LSB (bit 15) into the carry bit (CNEW). |
| 11 | S | Swap - swap the eight MSBs of the result with the eight LSBS. The carry resulting from the ALU is unaffected. |

### 5.5.3.2 Carry Control Field (CY)

The CY field (bits 10 and ll) specifies the base to be supplied to the ALU for carry calculation, as shown in Table 5-8.

TABLE 5-8. CARRY CONTROL FIELD

| Bits <br> lo-11 | Mnemonic | Definition |
| :--- | :--- | :--- |
| 00 | - | No change - the current state of the <br> Carry flag is supplied to the ALU as a <br> base for carry calculation. |
| 01 | $Z$ | Zero - the value o is supplied to the <br> ALU as a base for carry calculation. |
| 10 | 0 | One - the value l is supplied to the ALU <br> as a base for carry calculation. |
| 11 | C | Complement - the complement of the <br> current state of the Carry flag is <br> supplied to the ALU as base for carry <br> calculation. |

The three logical functions (MOV, COM, AND) supply the values listed above as the carry bit to the shifter. The five arithmetic functions (ADD, ADC, INC, SUB, NEG) supply the complement of the base value if the ALU operation produces a carry-out of bit 0; otherwise, they supply the value listed above.

### 5.5.3.3 No-Load Field (NL)

The NL field (bit 12) determines whether the output of the shifter is stored in $A C D$ and in carry. If bit $12=0$, the shifter output is stored in $A C D$ and in carry. If bit $12=1$, no storage action occurs.

### 5.5.3.4 Skip Control Field (SK)

The SK field determines the type of skip test to be performed on the shifter output. If the selected skip test is affirmative, the next instruction is skipped. The skip tests that can be selected by the SK field (bits 13-15) are shown in Table 5-9.

TABLE 5-9. SKIP CONTROL FIELD

| Bits <br> $13-15$ | Mnemonic | Definition |
| :--- | :--- | :--- |
| 000 | - | No skip test (never skip) |
| 001 | SKP | Skip unconditionally (no skip test <br> required) |
| 010 | SZC | Skip if carry bit is zero |
| 011 | SNC | Skip if carry bit is nonzero |
| 100 | SZR | Skip if result is zero |
| 101 | SNR | Skip if result is nonzero |
| 110 | SEZ | Skip if either carry bit or result is <br> zero |
| 111 | SBN | Skip if both carry bit and result are <br> nonzero |

### 5.5.4 ASSEMBLERR LANGUAGE CONVENTIONS AND EXAMPLES

The assembler language arithmetic or logic instruction consists of the instruction OPCODE mnemonic (ADD, NEG, COM, etc.) followed by symbols that specify the carry indicator, the shift indicator, the load/no-load indicator, a source and a destination accumulator, and the skip conditions. Table 5-10 shows the programming conventions for arithmetic and logical instructions.

The format is as follows:


The CY, SH, NL, and SK fields are specified by adding the appropriate mnemonic symbols. None of these four fields has to be specified, but their symbols must appear in the proper order and place, if they are included. Those fields not specified will be assembled containing 0 s. For example,

ADDCL 0,1
performs the following operation: Add AO to Al and supply the complement of the Carry flag to the ALU. Shift the l7-bit output to the left, and store it into Al and the Carry flag.

## TABLE 5-10. ASSEMBLER LANGUAGE CONVENTIONS FOR ARITHMETIC AND LOGIC INSTRUCTIONS

| Instruction Function | OPCODE Mnemonic | Optional Secondary Functions |  |  | Separator Space or Tab | Accumulators |  |  |  | Optnl Skip SK* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CY* | SH* | NL* |  | ACS | , | ACD | , |  |
| Add | ADD |  |  |  |  |  |  |  |  | blank |
| Subtract | SUB |  |  |  |  |  |  |  |  | SKP |
| Move | MOV | none | none |  |  | 0 |  | 0 |  | SZC |
| Increment | INC | Z | L | none |  | 1 |  | 1 |  | SNC |
| Negate | NEG | 0 | R | \# |  | 2 |  | 2 |  | SZR |
| Complement | COM | C | S |  |  | 3 |  | 3 |  | SNR |
| Add <br> Complement | ADC |  |  |  |  |  |  |  |  | SEZ |
| $\begin{aligned} & \text { Logical } \\ & \text { And } \end{aligned}$ | AND |  |  |  |  |  |  |  |  | SBN |
| *Omission of a mnemonic symbol for these fields will cause the field to be assembled as all zeros. |  |  |  |  |  |  |  |  |  |  |

### 5.6 INPUT/OUTPUT INSTRUCTION GROUP

The input/output instructions enable the processor to communicate with the peripheral devices on the system and also perform various operations within the processor. I/O instructions transfer data between accumulators and devices, start or reset device operation, or check the status of each device. Each I/O instruction contains a 6-bit device code field that specifies the particular device for this data transfer. The system allows up to 63 peripheral devices. Each device is assigned a unique code from 00 through 76 octal. The 77 octal code denotes a special class of instructions that controls certain CPU functions such as interrupt handling. Use of the 00 code is not recommended, since a device with that code would give a default response to an interrupt acknowledge instruction.

All instruction words in this category have the format shown in Figure 5-8.


085-17
Figure 5-8. Input/Output Instruction Format

An instruction in this class is designated by 011 in bits 0-2. The OPCODE and control (CTRL) fields define the I/O operation to be performed. If a data transfer operation is involved, the ac field (bits 3 and 4) specifies the accumulator involved in the data transfer (otherwise it has no effect). Bits 10-15 select the device that is to respond to the instruction.

### 5.6.1 REGULAR I/O INSTRUCTIONS

Regular $I / O$ instructions apply to all device codes except code 77. These instructions fall into two basic categories, depending on whether they transfer data or test the state of the device:

1. I/O transfer: NIO, DIA, DOA, DIB, DOB, DIC, DOC
2. I/O skip: SKPBN, SKPBZ, SKPDN, SKPDZ

The POINT 4 MARK $5 / 9$ input/output system provides for specification of the following functions:

- Full l6-bit data transfer:
- Three input channels (DIA, DIB, DIC)
- Three output channels (DOA, DOB, DOC)
- Control functions:
- Three outgoing control pulses (START, CLEAR, or IOPULSE designated by $S, C$, or $P$, respectively).
- Two device flags (Busy and Done) that can be sensed by I/O skip instructions

These input/output functions are illustrated in Figure 5-9.
Each device interface contains a-bit address decoder (bits lo-l5). When the processor executes an I/O instruction, it places the specified device code onto the Device Select lines of the I/O bus. The appropriate device will recognize its own code and thus respond to the $I / O$ instruction. All other devices ignore the instruction.

The control (CTRL) field can have two different functions, depending on the category into which the instruction falls:

- In conjunction with a data transfer instruction, one of the three different control pulses may be sent to the device--START, CLEAR, or IOPULSE
- In conjunction with I/O skip instructions, the control field determines which of the two flags in the I/O device will be tested--Busy or Done


Figure 5-9. CPU-I/O Device Input/Output Functions

### 5.6.1.1 I/O Transfer and Device Control Instructions

I/O transfer instructions move data between the processor and the device interface. There are six possible device buffers, labeled $A, B$ and C. Each label may refer to two separate buffers: an input (read) and an output (write) buffer.

The OPCODE field (bits 5-7) of the instruction specifies the type of transfer to take place (data in, data out, no transfer, etc.). Bits 3 and 4 specify the accumulator that supplies or receives the data, and bits 8 and 12 specify a control function (if any). The type of transfer is determined by the code in the OPCODE field as shown in Table 5-11.

TABLE 5-11. I/O TRANSFER-TYPE SPECIFICATION

| $\begin{aligned} & \text { Bits } \\ & 5-7 \end{aligned}$ | OPCODE | Definition |
| :---: | :---: | :---: |
| 000 | NIO | No data transfer involved; device control only. |
| 001 | DIA | Move the contents of the $A$ buffer in device $D$ to the accumulator specified in the ac field, and send the control pulse specified by the control field to the selected device. |
| 010 | DOA | Move the contents of the accumulator specified in the ac field to the A buffer in device $D$, and send the control pulse specified by the control field to the selected device. The original contents of ac are unaffected. |
| 011 | DIB | Move the contents of the $B$ buffer in device $D$ to the accumulator specified in the ac field, and send the control pulse specified by the control field to the selected device. |
| 100 | DOB | Move the contents of the accumulator specified in the ac field to the $B$ buffer in device $D$, and send the control pulse specified by the control field to device $D$. The original contents of ac are unaffected. |
| 101 | DIC | Move the contents of the $C$ buffer in device $D$ to the accumulator ac, and send the control pulse specified by the control field to device D . |
| 110 | DOC | Move the contents of the accumulator specified in the ac field to the $C$ buffer in device $D$, and send the control pulse specified by the control field to device $D$. The original contents of ac are unaffected. |

The control field (bits 8 and 9) for $1 / 0$ transfer instructions determines which control pulse should be transmitted, if any. The processor first performs the data transfer and then outputs the pulse. The control field is defined for regular I/O transfer instructions, as shown in Table 5-12.

TABLE 5-12. CONTROL FIELD SPECIFICATION

| $\begin{aligned} & \text { OPCODE } \\ & \text { Bits } \\ & 5-7 \end{aligned}$ | $\begin{aligned} & \text { Control } \\ & \text { Bits } \\ & 8-9 \end{aligned}$ | Control <br> Mnemonic | Definition |
| :---: | :---: | :---: | :---: |
| 000-110 | 00 | None | None |
| 000-11.0 | 01 | S | Produce the STRT pulse. Typically, this starts the device by clearing its Done flag, setting its Busy flag, and clearing its interrupt request flag. |
| 000-110 | 10 | C | Produce the CLR pulse. Typically this clears both the Busy and Done flags, and the interrupt request flag, idling the device. |
| 000-110 | 11 | P | Pulse the special $I / O$ bus control line (IOPLS). The effect, if any, depends upon the device. |

### 5.6.1.2 I/O Skip Instructions

When the OPCODE field (bits 5-7) contains lll, the control field (bits 8 and 9) selects the flag to be tested in the conditional I/O skip. The control codes for skip operations are shown in Table 5-13.

TABLE 5-13. I/O SKIP INSTRUCTIONS

| OPCODE <br> Bits <br> $5-7$ | Control <br> Bits <br> $8-9$ | Control <br> Mnemonic | SKPBN inition |
| :--- | :--- | :--- | :--- |
| 111 | 00 | Skip the next instruction if <br> the Busy flag in the device <br> is nonzero. |  |
| 111 | 01 | SKPBZ | Skip the next instruction if <br> the Busy flag in the device <br> is zero. |
| 111 | 11 | SKPDN | Skip the next instruction if <br> the Done flag in the device <br> is nonzero. |
| 111 | SKPDZ | Skip the next instruction if <br> the Done flag in the device <br> is zero. |  |

### 5.6.1.3 Assembler Language Conventions and Examples

An assembler language $I / O$ transfer statement consists of the instruction mnemonic, an optional control function, an accumulator, and octal device code. Table 5-14 shows the programming conventions for regular input/output instructions. For example,


This instruction performs the function: Move the data from register $A$ of device 10 into A2. Clear (reset) the device.

The device code may be represented by a device mnemonic. Thus,
DIAC 2,TTI
is equivalent to the previous example because TTI represents device 10 (input buffer for a Teletype or CRT terminal).

A no I/O (NIO) or $I / O$ skip instruction will not specify an accumulator since no data transfer occurs:

NIOS TTI
SKPBZ TTI

TABLE 5-14. ASSEHBLER LANGUAGE CONVENTIONS FOR INPUT/OUTPUT INSTRUCTIONS

| Instruction Function | OPCODE Mnemonic | Optional <br> Device Function | Separator Space or Tab | Ac | , | Device Code |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| No input/ output | NIO |  |  | None | None |  |
| Data in buffer A <br> Data out buffer A <br> Data in buffer B <br> Data out buffer B <br> Data in buffer C <br> Data out buffer C | DIA <br> DOA <br> DIB <br> DOB <br> DIC <br> DOC | S <br> Start* <br> C <br> Clear* <br> P <br> General pulse* |  | 0 <br> 1 <br> 2 <br> 3 | , | 00-76 octal |
| Skip if Busy flag is nonzero <br> Skip if Busy flag is zero <br> Skip if Done flag is nonzero <br> Skip if Done flag is zero | SKPBN <br> SKPBZ <br> SKPDN <br> SKPDZ |  |  |  |  |  |

### 5.6.2 SPECIAL CODE 77 (CPU) INSTRUCTIONS

Certain system functions, setting and testing of processor flags, and inter rupt processing control are accomplished via I/O instructions with the octal code 77 in bits lo-l5. These instructions do not directly address a particular device and the device code mnemonic is CPU.

CPU instructions have the same general format as regular I/O instructions. The OPCODE field and control field, however, are interpreted differently.

- OPCODE field:
- Channel A (DIA) is used to read the miniswitches at the front edge of the CPU board, or the DATA display on the optional Operator Control Unit. DOA is not defined.
- Channel B addresses all I/O devices simultaneously for certain interrupt control functions.
- Channel C does no data transfer. DIC and DOC are used for resetting all I/O devices and for halting the computer, respectively.
- Control pulses:
- S and $C$ are used to enable or disable interrupts.
- $P$ is used to set 32 K or 64 K -addressing mode, depending on the state of the LSB of A0. See Table 5-15.

The CPU has two flags which can be tested by the I/O skip instructions:

- Busy $=$ ION set (interrupts are enabled)
- Done = power failure has been detected (will cause interrupt if ION set)

The assembler also recognizes several special mnemonics for CPU instructions.

Table 5-15 gives both the regular instruction mnemonic and the special mnemonic. It also provides a definition of the special function of the CPU instructions.

TABLE 5-15. SPECIAL CPU INSTRUCTIONS

| Instruction | Special <br> Mnemonic | Definition |
| :---: | :---: | :---: |
| NIO CPU |  | No action. |
| NIOS CPU | INTEN | Sets the processor's Interrupt on (ION) flag. The processor will now respond to interrupt requests from devices, after execution of one more instruction. |
| NIOC CPU | INTDS | Clears the Interrupt on flag, so that the processor will not respond to interrupt requests. |
| NIOP CPU | None | Sets 32 K or 64 K -addressing mode, depending on the LSB value of AO. An LSB value of 0 sets 32 K mode; a value of 1 sets 64 K mode. <br> Enables Extended Instruction Set. Depends on the MSB value of AO. Enables Extended Instruction Set when $M S B=1$. Disables Extended Instruction Set when MSB=0. This applies to the MARK 5 with EIS and MARK 9 CPUs only. Refer to Sections 6.2 and 6.3 for further information. |
| DIA ac, CPU | READS ac | Reads the setting of the miniswitches at the front edge of the CPU board (or the value in the DATA readout of the optional operator Control Unit, if installed) into accumulator ac. |
| DIB ac, CPU | INTA ac | Reads the device code of the highest priority device requesting an interrupt into accumulator ac. |
| DOB ac, CPU | MSKO ac | Sets up interrupt disable flags in all devices simultaneously, according to the mask code in accumulator ac. Each device is associated with one of the bits in the accumulator, and its flag is set (mask bit=l) disabling interrupt from that device, or cleared (mask bit=0) enabling interrupts from it. A MSKO with ac=l77777 disables interrupts from all devices. |

TABLE 5-15. SPECIAL CPU INSTRUCTIONS (Cont)

| Instruction | Special <br> Mnemonic | Definition |
| :--- | :--- | :--- |
| DICC ac, CPU | IORST | Generate I/O reset to clear the Busy, <br> Done, and Interrupt Disable flags in all <br> devices. This instruction also clears <br> the processor's ION flag and sets it to to <br> 32K-addressing mode. (Does not change <br> contents of selected accumulator.) |
| DOC ac, CPU | HALT | Halt the processor. Requires manual <br> action to restart processor. |

Note that the special mnemonic does not allow the programmer to specify the $S$ and $C$ functions. For example,

READS 3
when executed, deposits the value entered via the Operator Control Unit or miniswitches into A3. If the programmer wishes to also set ION, the assembler instruction memonic would have to be used:

DIAS 3,CPU
This instruction sets ION after reading the DATA display on the Operator Control Unit, or the miniswitches.

The instruction IORST, however, assumes the $C$ function. All I/O device flags are reset and the ION flag is cleared. In order to reset the I/O devices without clearing the ION flag, the regular assembler instruction must be used:
DIC 0,CPU

As with regular $1 / 0$ instructions, a value of lll in bits 5-7 signifies a conditional skip instruction. The function field in this case indicates which processor flag (Interrupt On or Power Fail) will be tested, as shown in Table 5-16.

TABLE 5-16. CONDITIONAL SKIP INSTRUCTIONS

| Bits <br> $8 \& 9$ | Instruction | Definition |
| :--- | :--- | :--- |
| 00 | SKPBN CPU | Skip next instruction if ION is <br> nonzero. |
| 01 | SKPBZ CPU | Skip next instruction if ION is zero. |
| 10 | SKPDN CPU | Skip next instruction if the Power <br> Failure flag is nonzero. |
| 11 | SKPDZ CPU | Skip next instruction if the Power <br> Failure flag is zero. |

### 5.6.2.1 Assembler Language Conventions

CPU instructions are usually written using the special mnemonics shown in Section 5.6.2; however, they may also be written in the same manner as regular $I / O$ instructions, specifying the instruction mnemonic, optional control function, optional accumulator, and a device code of 77 octal (mnemonic CPU). For example,

NIOS CPU
sets the ION flag in the processor.

### 5.7 INSTRUCTION EXECUTION TIMES

One of the outstanding features of the POINT 4 MARK 5 or MARK 9 Computer is the substantial reduction in instruction time over execution time in comparable minicomputers. Table 5-17 gives instruction execution times for the POINT 4 MARK 5 Computer. Table 5-18 lists instruction execution times for the POINT 4 MARK 5 Computer with EIS option. Table 5-19 lists instruction execution times for the POINT 4 MARK 9 Computer.

These times are exclusive of three types of overhead:

1. A 500-nanosecond (200-nanosecond for the MARK 9) refresh cycle takes place once every 16 microseconds - this adds about $3 \%$ overhead.
2. Arithmetic/logic instructions on RAM page boundaries (two least significant digits of address $=76$ or 77) take an extra 100 nanoseconds - this results in approximately 0.25\% overhead. This does not apply to the MARK 9.
3. If the optional Operator Control Unit is connected to the CPU, a l.8-microsecond address display cycle occurs once every 600 microseconds, resulting in $0.3 \%$ overhead.

TABLE 5-17. INSTRUCTION EXECUTION TIMES FOR MARR 5

| Instruction Category | Instruction (generic type) | $\begin{aligned} & \text { Execution } \\ & \text { Time } \\ & \text { (ns) } \end{aligned}$ |
| :---: | :---: | :---: |
| MEMORY REFERENCE | Load or store accumulator (LDA,STA) <br> Increment or decrement if zero (ISZ,DSZ) <br> Jump (JMP) <br> Jump to subroutine (JSR) <br> Additional times for various <br> addressing modes: <br> - Each level of indirect addressing <br> - Auto-indexing | $\begin{array}{r} 800 \\ 1100 \\ 400 \\ 400 \\ \\ 400 \\ 200 \end{array}$ |
| $\begin{aligned} & \text { ARITHMETIC/ } \\ & \text { LOGIC } \end{aligned}$ | Arithmetic/logic instructions (COM, NEG, MOV, INC, ADC, SUB , ADD, AND) - for skip (SKP) add | $\begin{array}{r} 400 \\ 0 \end{array}$ |
| INPUT/ OUTPUT | Input <br> - for START, CLEAR, or PULSE add <br> Output <br> - for START, CLEAR, or PULSE add <br> No I/O transfer (NIO) <br> - for START, CLEAR, or PULSE add <br> I/O skips (SKPBN, SKPBZ, SKPDN, SKPDZ) <br> Interrupt acknowledge (INTA) <br> Interrupt response | 900 600 1200 400 1200 400 900 1000 1200 |
| DATA CHANNEL TRANSFERS | Standard data channel transfers: <br> - Input <br> - Output <br> High-speed data channel transfers: <br> - Input <br> - Output | $\begin{array}{r} 1100 \\ 1700 \\ \\ 900 \\ 1300 \end{array}$ |

TABLE 5-18. INSTRUCTION EXECUTION TIMES FOR MARR 5 WITH EIS

| Instruction Category | Instruction (generic type) | Execution Time (ns) |
| :---: | :---: | :---: |
| MEMORY REFERENCE | Load or store accumulator (LDA,STA) <br> Increment or decrement if zero (ISZ, DSZ) <br> Jump (JMP) <br> Jump to subroutine (JSR) <br> Additional times for various addressing modes: <br> - Each level of indirect addressing <br> - Auto-indexing | $\begin{array}{r} 800 \\ 1100 \\ 400 \\ 400 \\ \\ 400 \\ 200 \end{array}$ |
| ARITHMETIC/ LOGIC | Arithmetic/logic instructions (COM, NEG, MOV, INC, ADC, SUB , ADD, AND) - for skip (SKP) add | $\begin{array}{r} 400 \\ 0 \end{array}$ |
| INPUT/ OUTPUT | Input <br> - for START, CLEAR, or PULSE add <br> Output <br> - for START, CLEAR, or PULSE add <br> No I/O transfer (NIO) <br> - for START, CLEAR, or PULSE add <br> I/O skips (SKPBN, SKPBZ, SKPDN, SKPDZ) <br> Interrupt acknowledge (INTA) <br> Interrupt response | $\begin{array}{r} 900 \\ 600 \\ 1200 \\ 400 \\ 1200 \\ 400 \\ 900 \\ 1000 \\ 1200 \end{array}$ |
| DATA CHANNEL TRANSFERS | Standard data channel transfers: <br> - Input <br> - Output <br> High-speed data channel transfers: <br> - Input <br> - Output | $\begin{array}{r} 1100 \\ 1700 \\ \\ 900 \\ 1300 \end{array}$ |

TABLE 5-19. INSTRUCTION EXECUTION TIMES FOR MARK 9

| Instruction Category | Instruction (generic type) | $\begin{aligned} & \text { Execution } \\ & \text { Time } \\ & \text { (ns) } \end{aligned}$ |
| :---: | :---: | :---: |
| MEMORY REFERENCE | Load accumulator (LDA) <br> Store accumulator (STA) <br> Increment if zero (ISZ) <br> Decrement if zero (DSZ) <br> Jump (JMP) or Jump to subroutine (JSR): <br> - One level <br> - Two levels <br> - Three levels <br> Additional times for various <br> addressing modes: <br> - Indirect addressing <br> - Auto-indexing | $\begin{array}{r} 600 \\ 625 \\ 825 \\ 900 \\ \\ 425 \\ 925 \\ 1425 \end{array}$ |
| $\begin{aligned} & \text { ARITHMETIC/ } \\ & \text { LOGIC } \end{aligned}$ | Arithmetic/logic instructions (COM, NEG, MOV, INC, ADC, SUB , ADD, AND) - for skip (SKP) add | $\begin{aligned} & 300 \\ & 375 \end{aligned}$ |
| INPUT/ OUTPUT | Input <br> - for START, CLEAR, or PULSE add <br> Output <br> - for START, CLEAR, or PULSE add <br> No I/O Transfer (NIO) <br> - for START, CLEAR, or PULSE add <br> I/O skips (SKPBN, SKPBZ, SKPDN, SKPDZ) <br> Interrupt acknowledge (INTA) <br> Interrupt response | $\begin{array}{r} 1125 \\ 300 \\ 1500 \\ 300 \\ 1500 \\ 300 \\ 1000 \\ 1675 \\ \\ 1175 \end{array}$ |
| DATA CHANNEL TRANSFERS | Standard data channel transfers: <br> - Input <br> - Output <br> High-speed data channel transfers: <br> - Input <br> - Output | $\begin{array}{r} 1600 \\ 2000 \\ \\ 900 \\ 1200 \end{array}$ |

## Section 6 EXTENDED INSTRUCTION SET

### 6.1 INTRODUCTION

This section describes the Extended Instruction Set, which is standard on the MARK 9 and is available as an option on the MARK 5 Computer. The POINT 4 Extended Instruction Set is upward compatible with the Standard Instruction Set. Any software that runs on the Standard Instruction Set will run on the Extended Instruction Set with the exception of software that uses an arithmetic no-op skip instruction.

The following subsections describe the operation of each instruction. Recommended mnemonics and syntax for the instructions are also provided.* See Appendices $F$ and $G$ for octal values and execution times of the extended instructions.
*The recommended mnemonics and syntax are not supported by the current assembler supplied by POINT 4. However, the SYMBOLS file may be extended to include definitions that will be helpful in their use.

### 6.2 ENABLING/DISABLING EXTENDED INSTRUCTION SET

### 6.2.1 ENABLING EIS

The MARK 9 requires no hardware changes to enable the use of the Extended Instruction Set. To enable the software, issue a NIOP command to device code 77 (octal) with the MSB of accumulator zero set to 1.

The MARK 5 requires the following hardware and software changes to enable the use of the Extended Instruction Set:

- CPU board jumper W7, located at l7c on the CPU/memory board, should be in position 3. This allows the most significant bit (MSB) to be used as an enabling factor for the Extended Instruction Set.
- CPU board jumper W3, located at 4 f on the CPU/memory board, should be in position 2. This enables the NIOP instruction to be used as an enabling factor for the Extended Instruction Set.
- A NIOP command to device code 77 (octal) with the MSB of accumulator zero set to $l$ enables the Extended Instruction Set.


### 6.2.2 DISABLING EIS

A NIOP command to device code 77 (octal) with the MSB of accumulator zero set to 0 disables the Extended Instruction Set. An I/O reset (IORST) command also disables the Extended Instruction Set (see Table 4-2).

### 6.3 EXTENDED INSTRUCTION IMPLEMENTATION

The extended instructions are implemented on a MARK 5/9 using the NOP skip command, which is formatted as shown in Figure 6-1.

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | $x$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 6-1. NOP Skip Command Format

The values in bits 1 through 11 have no effect on the Standard Instruction Set. In the Standard Instruction Set, each instruction having a $l$ in the most significant bit and 1001 (binary) in the four least significant bits is a no-op instruction, but causes the next location in sequence to be skipped.

Certain instructions require or generate a 32-bit value. In such cases, the accumulators are specified in the form "AH, AL" where accumulator $A H$ contains the high-order 16 bits and AL contains the low-order 16 bits of the value. For example, "Al, A2" indicates that accumulator Al contains the high-order half of the value and A2 contains the low-order half of the value.

This Extended Instruction Set includes two-word (32-bit) instructions. In such cases, the first word is formatted as in the diagram above, but the second word is an unrestricted l6-bit operand. These two-word instructions cannot be used following any kind of skip instruction, because a skip instruction only skips over one word and would then attempt to execute the second word (l6-bit operand) as an instruction.

### 6.3.1 PAGE ZERO LOCATIONS

Certain page zero locations are used by the POINT 4 MARK 5 with EIS and MARK 9 as follows:

40 Base address for XGETBYTE, XSGETBYTE, XLOAD and XTRANSLATE (see Sections 6.3.7 and 6.3.9)

41 Base address for XPUTBYTE, XSPUTBYTE, and XSTORE (see Sections 6.3.7 and 6.3.9)

45 Stack base pointer (see Section 6.3.5)
46 Stack frame pointer (see Section 6.3.5); Trap instruction (see Section 7.6)

47 Stack limit pointer (see Section 6.3.5); Trap instruction (see Section 7.6)

The contents of these cells are not affected by and do not affect the operation of the computer except as described in the referenced portions of this section.

### 6.3.2 IMMEDIATE COMPARE INSTRUCTIONS

These instructions each contain an 8-bit, unsigned, literal data field within the instruction itself. This field is referred to as the immediate constant in the following descriptions. All these instructions compare the entire contents of accumulator AO (a l6-bit unsigned integer) with the immediate constant, and cause the next instruction in sequence to be skipped if the conditions are met. Note that the next location must contain a one-word instruction. Table 6-l lists each instruction and its function. Figure 6-2 shows the binary format for immediate compare instructions. For a complete list of binary formats for all extended instructions and definitions of format terms, see Appendix H .

TABLE 6-1. IMNEDIATE COMPARE INSTRUCTIONS

| Instruction | Definition |
| :--- | :--- |
| SLEI constant | Skip if less than or equal to immediate <br> constant. Skips if the contents of AO are <br> less than or equal to the value of the <br> immediate constant. |
| SGRI constant | Skip if greater than immediate constant. <br> Skips if the contents of AO are greater than <br> the immediate constant. |
| SEQI constant | Skip if equal to immediate constant. Skips <br> if the contents of AO are equal to the <br> immediate constant. |
| SNEI constant | Skip if not equal to immediate constant. <br> Skips if the contents of AO are not equal to <br> the immediate constant. |

SLEI
SGRI
SEQI
SNEI

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

085-31

## Figure 6-2. Binary Format for Immediate Compare Instructions

### 6.3.2.1 Other Immediate Operations

As with the immediate compare instructions, these instructions have a literal constant within the instruction itself. However, these instructions allow loading, adding, or subtracting any 8-bit unsigned constant to or from accumulator AO. No other accumulator is affected.

Table 6-2 defines other immediate operations. Figure 6-3 shows the binary format for these instructions.

TABLE 6-2. OTHER IMMEDIATE OPERATIONS

| Instruction | Definition |
| :---: | :---: |
| LDI constant | Load immediate constant. Loads the literal constant into accumulator A0. The eight most significant bits of $A 0$ are zeroed. Carry is not affected. |
| ADI constant | Add immediate constant. The literal constant is added to the contents of AO. Carry is then propagated as in an ADD instruction, and carry is toggled if overflow occurs. |
| SBI constant | Subtract immediate constant. The literal constant is subtracted from the contents of AO. Borrow is propagated as with a SUB instruction, and the carry is toggled if borrow does not occur (if the result is not negative). This is equivalent to adding the l6-bit two's complement of the literal constant to AO with carry propagated. |

LDI
ADI
SBI


085-32

Figure 6-3. Binary Format for Other
Immediate Operations

### 6.3.3 BIT MANIPULATION AND TEST INSTRUCTIONS

These instructions allow setting, clearing, toggling, and testing one or more selected bits within the operand. The operand is normally the contents of accumulator A0. However, if an @ symbol is appended to the instruction mnemonic, the contents of location (Al) $+(A 2$ ) becomes the operand and the result is left in $A 0$ as well as in the addressed location. These are two-word instructions. The second word in each instruction is the mask which selects the bits to be acted upon. These instructions must not be preceded by any form of a skip instruction, and must not be followed by any two-word instruction. No accumulators other than AO are changed in any case. Table 6-3 defines the bit manipulation and test instructions. Figure 6-4 shows the binary format for these instructions.

TABLE 6-3. BIT MANIPULATION AND TEST INSTRUCTIONS

| Instruction | Definition |
| :---: | :---: |
| CLRB mask | Each "l" bit in the mask causes the corresponding bit in the operand to be cleared to " 0 ". |
| SETB mask | Each "l" bit in the mask causes the corresponding bit in the operand to be set to "1". |
| TOGB mask | Each "l" bit in the mask causes the corresponding bit in the operand to be toggled. An exclusive OR is performed between the operand and the mask. |
| SBZ mask | Skip the next location in sequence if all "l" bits in the mask correspond to zero bits in the operand, or if there are no "l" bits in the mask. The operand is not changed. |
| SBO mask | Skip the next location in sequence if any "l" bit in the mask corresponds to a "l" bit in the operand. The operand is not changed. |

CLRB

SETB

TOGB

SBZ

SBO

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | 1 | 2 | 3 | 4 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | 0 | e | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 1 | 0 | 0 | 0 | e | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 1 | 0 | 0 | 0 | e | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 1 | 0 | 1 | 0 | e | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 1 | 0 | 1 | 1 | ¢ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

$085-33$

Figure 6-4. Binary Format for Bit Manipulation and Test Instructions

### 6.3.4 BIT TEST INSTRUCTION COMBINATIONS

The bit test (skip) instruction may also be combined with the clear, set, or toggle instructions. Table 6-4 shows the possible combinations. Figure 6-5 shows the binary format for these instructions.

TABLE 6-4. BIT TEST INSTRUCTION COMBINATIONS

| Instruction | Definition |
| :---: | :---: |
| SBZC mask | Performs an SBZ, followed by a CLRB |
| SBOC mask | Performs an SBO, followed by a CLRB |
| SBZS mask | Performs an SBZ, followed by a SETB |
| SBOS mask | Performs an SBO, followed by a SETB |
| SBZT mask | Performs an SBZ, followed by a TOGB |
| SBOT mask | Performs an SBO, followed by a TOGB |

SBZC

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | 11 |  | 13 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 1 | 0 | e | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 1 | 0 | 1 | 1 | e | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 1 | 0 | 1 | 0 | e | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 1 | 0 | 1 | 0 | e | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 1 | 0 | 1 | 1 | e | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MASK |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

085-34

Figure 6-5. Binary Format for Bit Test Instruction Combinations

### 6.3.5 POINT 4 EIS STACK INSTRUCTIONS

The POINT 4 EIS stack instructions are supported by the MARK 5 with the EIS option and by the MARK 9. For MARK 9-exclusive stack instructions, see Section 7.3.

The POINT 4 EIS stack instructions utilize the stack pointer (SP) and three reserved page zero cells. Their location, tags, and names are shown below:

| LOC | Tag | Name |
| :--- | :--- | :--- |
| 45 | SB | Stack base pointer |
| 46 | FP | Frame pointer; used by trap instruction in <br> MARK 9 (refer to Section 7.6) |
| 47 | SL | Stack limit pointeri used by trap <br> instruction in MARK 9 (refer to <br> Section 7.6) |

Another special cell, the stack fault vector (SF), must be set by the software at (SB) +l. Due to the sequence in which the stack overflow test is performed, the cell at location (SL)-l must be reserved. The stack organization for new registers is shown in Figure 6-6.

Table 6-5 defines the instructions used for new registers. Figure 6-7 shows the binary format for these instructions.


Figure 6-6. Stack Organization for New Registers

TABLE 6-5. INSTRUCTIONS USED FOR NEW REGISTERS

| Instruction | Definition |
| :---: | :---: |
| SETSP ac | Set stack pointer. The contents of accumulator ac (where ac=0, 1,2 , or 3) are loaded into the $S P$ register. No other register is affected. |
| REDSP ac | Read stack pointer. The current contents of the SP are copied into accumulator ac (where ac=0, 1, 2, or 3). No other register, including the $S P$, is affected. |
| PUSH ac | Push data onto stack. The SP is decremented, and the contents of accumulator ac are stored at SP. If (SP) $>$ (SL), stack overflow has occurred, in which case (PC)+l is stored at SB, and PC is loaded with SF at (SB) +l. Specifically: $\begin{aligned} & \text { SP }<=(S P)-1, \quad(S P)<=(\mathrm{ac}) \\ & \text { If }(S P)<(S L) \text { then }(S B)<=(P C)+1, P C<=(S F) \end{aligned}$ |
| POP ac | Pop data from stack. The contents of the location pointed to by the SP are loaded into accumulator ac (where ac $=0,1,2$, or 3 ), and the $S P$ is incremented. If $(S P)>(F P)$, then stack underflow has occurred, in which case (PC) +1 is stored at $S B$, and PC is loaded with SF to do a fault branch. Specifically: $\begin{aligned} & \text { ac }<=((S P)), S P<=(S P)+1 \\ & \text { If }(S P)>(F P) \text { then }(S B)<=(P C)+1, P C<=(S F) \end{aligned}$ |
| PUSHJUMP <br> Address | Push and jump. This two-word instruction pushes a return address onto the stack and jumps to the absolute address given in the second word of the instruction. Specifically: $\begin{aligned} & S P<=(S P)-1,(S P)<=(P C)+2, \\ & P C<=((P C)+1) \\ & \text { If }(S P)<(S L) \text { then }(S B)<=(P C)+1, P C<=(S F) \end{aligned}$ |

TABLE 6-5. INSTRUCTIONS USED FOR NEN REGISTERS (Cont)

| Instruction | Definition |
| :---: | :---: |
|  | NOTE <br> The relative address, as well as the displacement in the following two instructions, is added to the contents of the specified register and any overflow is ignored. Therefore, the relative address or displacement may be considered by the programmer to be either an unsigned or a signed integer. |
| RPUSHJUMP <br> Displacement | Relative push and jump - this is similar to PUSHJUMP except that it jumps to (PC) +displ acement. |
| I2 PUSHJUMP <br> Displacement | Indexed (A2) push and jump - this is similar to PUSHJUMP except that it jumps to location (A2) +displ acement. |
| I3PUSHJUMP Displacement | Indexed (A3) push and jump - this is similar to PUSHJUMP except that it jumps to location (A3) +displ acement. |
| POPJUMP | Pop and jump - this is the normal return from a subroutine called by a PUSHJUMP. The stack is popped into PC. Specifically: $\begin{aligned} & \text { SP }<=(S P)+1 \\ & \text { If }(S P)>(F P) \text { then }(S B)<=(P C)+1, P C<=(S F) \\ & \text { el se } P C<=((S P)-1) \end{aligned}$ |

SETSP
REDSP
PUSH
POP
PUSHJ
RPUSH
I2PUS
I3PUS
POPJ

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 1 | 0 | $A C C U$ | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |  |
| 1 | 1 | 0 | $A C C U$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |  |
| 1 | 1 | 1 | $A C C U$ | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |  |
| 1 | 1 | 1 | $A C C U$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |  |
| 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |

### 6.3.6 NYBBLE MANIPULATION INSTRUCTIONS

A nybble is a four-bit data group (half a byte), and each l6-bit word holds four nybbles. When data is manipulated in binary coded decimal (BCD), each BCD digit occupies one nybble. These instructions facilitate easy handling of $B C D$ data. Table 6-6 defines the nybble manipulation instructions. Figure 6-8 shows the binary format for these instructions.

TABLE 6-6. NYBBLE MANIPULATION INSTRUCTIONS

| Instruction | Definition |
| :---: | :---: |
| NYBSL | Nybble shift left. A2 indicates the operand's memory location, and AO indicates the size of the operand (number of words-l). The word at A2 contains the most significant four nybbles. The (AO) +l words starting at (A2) +(AO) and working back through A2 are shifted left one nybble (four bits), and the low-order nybble of Al is shifted in. The old high-order nybble of the word at A2 is returned in the low-order nybble of Al. The new high-order nybble of the word at A2 is returned in the high-order nybble of AO. The rest of Al and A0 is zeroed. Accumulators A2 and A3 are unchanged. Carry is not preserved. |
| NYBSR | Nybble shift right. The (AO) +1 words starting at A2 are shifted right one nybble (four bits), and the low-order nybble of Al is shifted into the top of the word at A2. If the nybble shifted out of the last word is five or greater, the carry is set; otherwise the carry is cleared. Accumulator AO is -l; Al is destroyed; A2 points to the last word+1 of the operand and A3 is unchanged. |
| DECADD | Decimal add. The BCD numbers in accumulators AO and Al are added with the carry, and the result is stored in accumulator A0 with the overflow stored in carry. Accumulators Al, A2, and A3 are unchanged. Specifically: <br> $(\mathrm{A} 0)<=(\mathrm{A} 0)+(\mathrm{Al})+(\mathrm{C})$ <br> (C) <= carry out |


| Instruction | Definition |
| :---: | :---: |
| DECSUB | Decimal subtract. The BCD number in accumulator $A l$ and the complement of the carry are subtracted from the $B C D$ number in accumulator A0. The result is stored in accumulator AO. This sets the carry if there is no borrow. Accumulators A1, A2, and A3 are unchanged. Specifically: $\begin{aligned} & A 0<=(A 0)-(A 1)-(C-) \\ & C<=\text { borrow out- } \end{aligned}$ |
| CONVERT | Convert BCD to binary. This instruction is designed for use as a step in a conversion process from a $B C D$ number to a binary number, using Al and A2 as a two-word binary accumulator for the conversion product. The 32-bit unsigned binary number in A1, A2 is multiplied by ten (decimal), and the value in AO is added to the result. Carry is set if overflow occurs, otherwise carry is cleared. Accumulators AO and A3 are unchanged. $\mathrm{A} 1, \mathrm{~A} 2<=(\mathrm{Al}, \mathrm{~A} 2) * 10+(\mathrm{A} 0)$ |

NYBSL
NYBSR
DECAD
DECSU
CONVE

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

Figure 6-8. Binary Format for Nybble Manipulation Instructions

### 6.3.7 EXTENDED LOAD AND STORE INSTRUCTIONS

These instructions load or store accumulator AO to/from the address in A2 relative to the base address in location 40 or 41 octal. Table 6-7 defines the extended load and store instructions. Figure 6-9 shows the binary format for these instructions.

TABLE 6-7. EXTENDED LOAD AND STORE INSTRUCTIONS

| Instruction | Definition |
| :---: | :---: |
| XLOAD | Extended load. Loads AO with the contents of <br> location (40) +(A2). Only accumulator AO is <br> changed. |
| XSTORE | Extended store. Stores the contents of AO at <br> location (41)+(A2). No accumulators are <br> changed. |


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

Figure 6-9. Binary Format for Extended Load and Store Instructions

### 6.3.8 VECTORED JUMP TO SUBROUTINE INSTRUCTION

A vectored jump-to-subroutine instruction (VJSR subnum) performs a JSR to a subroutine via a vector table that immediately precedes the interrupt service routine. It is assumed that memory location $l$ contains a pointer to the interrupt service routine. Specifically:

$$
(\mathrm{A} 3)<=(\mathrm{PC})+1,(\mathrm{PC})<=((1)-\text { subnum-1) }
$$

where the subnum is in the range of 0 to 37 octal. Figure 6-10 shows the binary format for this instruction.

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: |
| 1 | 1 | 0 | V | V | V | V | V | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |

Figure 6-10. Binary Format for Vectored Jump to Subroutine Instruction

### 6.3.9 BYTE ACCESS INSTRUCTIONS

All these instructions operate only on accumulator AO using a byte address in accumulator Al, as described for the particular instruction.

The only exceptions to this are SGETBYTE and XSGETBYTE, which use a byte address in accumulator A2. When a byte address is used, it is shifted one bit to the right to form a word address. The bit shifted out selects the byte of the word (indicated by the address). Byte zero is the high-order byte of each word.

All get byte instructions load the addressed byte into the low-order half of $A 0$, and the high-order half of AO is zeroed. The addressed word is unchanged.

All put byte instructions store the byte from the low-order half of $A 0$ and ignore the high-order half. A0 is unchanged, and the other byte in the addressed word is unchanged. Table 6-8 defines the byte access instructions. Figure 6-ll shows the binary format for these instructions.

TABLE 6-8. BYTE ACCESS INSTRUCTIONS

| Instruction | Definition |
| :---: | :---: |
| GETBYTE | Gets the byte from byte address (Al). |
| PUTBYTE | Stores the byte at byte address (Al). |
| SGETBYTE | Sequential get byte - gets the byte from byte address (A2), and A2 is then incremented. |
| SPUTBYTE | Sequential put byte - stores the byte at byte address (Al), and Al is then incremented. |
| XGETBYTE | Extended get byte - gets the byte from byte address (Al) relative to the base word address in location 40 octal. |
| XPUTBYTE | Extended put byte - stores the byte at byte address (Al) relative to the base word address in location 41 octal. |
| XSGETBYTE | Extended sequential get byte - similar to SGETBYTE except relative to the base word address in location 40 octal. |
| XSPUTBYTE | Extended sequential put byte - similar to SPUTBYTE except relative to the base word address in location 41 octal. |
| IGETBYTE d <br> (displacement) | Indirect get byte - the contents of location (A2)+displacement are used as the byte address, where displacement is in the range 0 to 17 octal. If this byte address is greater than or equal to (Al), the instruction is a no-op and does not skip. If the byte address is less than (Al), it is incremented and the resulting byte address is stored at (A2) +displacement. The byte from that byte address is loaded into the low-order half of AO. The high-order half of $A O$ is zeroed, and a skip occurs. Only accumulator AO is changed. |

TABLE 6-8. BYTE ACCESS INSTRUCTIONS (Cont)

| Instruction | Definition |
| :---: | :---: |
| IPUTBYTE d <br> (displacement) | Indirect put byte - the contents of location (A2) +displacement are used as the byte address, where displacement is in the range 0 to 17 octal. If this byte address is greater than or equal to (Al), the instruction is a no-op and does not skip. If the byte address is less than (Al), it is incremented and the resulting byte address is stored at (A2) +displacement. The byte in the low-order half of AO is stored at the resulting byte address, and a skip occurs. All accumulators are unchanged. |
| XTRANSLATE | Extended sequential translate byte - a translation table, which consists of up to 256 single-word translation values, immediately follows this instruction. The instruction loads a byte into accumulator AO from the byte address (Al) relative to the base word address at location 40 octal. Al is incremented. The contents of the word at word address (PC)+(AO) are compared with octal 377. If the value of the loaded word is greater than octal 377 , the PC jumps to the word address. If the value is less than or equal to octal 377 , it is loaded into accumulator $A 0$ and a jump is performed using (A3) as the word address. |

GETBY
PUTBY
SGETB
SPUTB
XGETB
XPUTB
XSGET
XSPUT
IGETB
IPUTB
XTRAN

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

085-40
Figure 6-11. Binary Format for Byte Access Instructions

### 6.3.10 BINARY MULTIPLY AND DIVIDE INSTRUCTIONS

Table 6-9 defines the binary multiply and divide instructions for the Extended Instruction Set. Figure 6-12 shows the binary format for these instructions.

TABLE 6-9. BINARY MULTIPLY AND DIVIDE INSTRUCTIONS

| Instruction | Definition |
| :---: | :---: |
| ABINMULTIPLY | Accumulative binary multiply - the unsigned l6-bit binary integers in AO and A2 are multiplied to form a 32-bit binary product. The 16 -bit value in Al is added to the product, and the result is returned in Al,A2. Accumulators AO and A3 are unchanged. Carry is not preserved. $A 0 * A 2+A 1-->A 1, A 2$ |
| BINDIVIDE | Binary divide - the 32-bit unsigned dividend in Al,A2 is divided by the 16-bit unsigned divisor in AO. The quotient is returned in A2, and the remainder is returned in Al. Accumulators A0 and A3 are unchanged. Carry is set to one if overflow occurs (i.e., if A0 is not greater than Al). If overflow does not occur, carry is zeroed. <br> $\mathrm{A}, \mathrm{A} 2 / \mathrm{AO}-->\mathrm{A} 2 \mathrm{R}$ Al |

ABINM
BINDI

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

Figure 6-12. Binary Format for Binary Multiply and Divide Instructions

### 6.3.11 MOVE AND SEARCH INSTRUCTIONS

The move and search instructions operate on a block of words in memory. Table 6-10 defines the move and search Instructions. Figure 6-13 shows the binary format for these instructions.

TABLE 6-10. MOVE AND SEARCH INSTRUCTIONS

| Instruction | Definition |
| :---: | :---: |
| MOVEWORDS | Move block of words. Moves a specified number of words from one contiguous area in memory to another specified area. Before executing the MOVEWORDS instruction, the accumulators must be set up as follows: <br> $A 0=$ one less than the number of words to be moved <br> Al $=$ address of beginning of source area <br> A2 $=$ address of beginning of destination area <br> The word at $(A 1)+(A 0)$ is stored at (A2)+(AO), and $A O$ is decremented. The process continues if (AO) is not $=-1$. After completion of the cycle, the carry is zero and (AO) = -1. All other registers are unchanged. Note that the last word is moved first. |
| RMOVWORDS | Reverse move words. Should be used instead of MOVEWORDS if the destination area ends within the source area. Because MOVEWORDS moves from the end of the source area to the beginning, the source would be overlayed. Before executing the RMOVWORDS instruction, the accumulators must be set up as follows: <br> A0 $=\begin{aligned} & \text { one less than the number of words to } \\ & \text { be moved }\end{aligned}$ A1 $=$ address of end of source area A2 $=$ address of end of destination area <br> The word stored at (Al)-(AO) is stored at (A2)-(AO), and AO is decremented. The process repeats if (AO) is not $=-1$. After completion of the instruction, ( $A 0$ ) $=-1$, and the carry is zero. All other accumulators are unchanged. |


| Instruction | Definition |
| :---: | :---: |
| TABLSEARCH | Performs a search of a specified area of memory for a given value. Before executing this instruction, the accumulators must be set up as follows: $\begin{aligned} A 0= & \text { value to be searched for } \\ A 1= & \text { increment value } \\ A 2= & \text { address of beginning of area to } \\ & \text { search } \\ A 3= & \text { address one greater than end of area } \\ & \text { to search } \end{aligned}$ <br> The contents of location (A2) are compared with the value in AO. If equal, execution is complete and a skip is executed. If not equal, (Al) is added to (A2) and the instruction is repeated. If (A2) becomes greater than or equal to (A3) without finding a match, execution is complete and no skip occurs. |

MOVEW
RMOVW
TABLS

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

Figure 6-13. Binary Format for Move and Search Instructions

### 6.3.12 TRACE INSTRUCTION

The MARK 9 CPU does not support this instruction.
TRACE is a two-word instruction that allows the remote execution of an instruction while operating in a host program. The second word of the instruction contains the address of the remote instruction to be executed. When an instruction is traced, the following sequence occurs using a new hardware register, XPC.
$\mathrm{XPC}<=(\mathrm{PC})+1$
PC <= ( $(X P C))$
Execute the instruction at (PC).
( XPC ) <= ( PC )
PC $<(X P C)+1$
Resume execution at PC.
Figure 6-14 shows the binary format for the trace instruction.

TRACE

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

Figure 6-14. Binary Format for Trace Instruction


## Section 7 MARK 9 EXCLUSIVE INSTRUCTIONS

### 7.1 INTRODUCTION

This section describes the additional instructions and hardware that are contained in the MARK 9 CPU (which are not available on the MARK 5 CPU). The additional instructions are: hardware multiply, divide, and stack instructions. In addition, the MARK 9 contains a Mapped Memory that is capable of providing up to 256 lK-word pages of physical memory; up to 64 of these lK-word pages may be mapped to logical memory at any given time. The MARK 9 CPU contains additional hardware and instructions which provide for the effective management of this memory map.

### 7.2 HARDWARE MULTIPLY AND HARDWARE DIVIDE

The following instruction multiplies a l6-bit unsigned number in accumulator 1 and a l6-bit unsigned number in accumulator 2:

DOCP 2,1
The final product is added to the unsigned number in accumulator 0 and the result is placed in accumulators 0 and l. Bit 0 of accumulator 0 is the most significant bit of the product. Bit 15 of accumulator $l$ is the least significant bit of the product. Figure 7-1 illustrates the bit format for this instruction. The unsigned number in accumulator 2 is not changed.

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |
| $089-9$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 7-1. Hardware Multiply Instruction Format

The following instruction divides a 32-bit unsigned number contained in accumulators 0 and 1 by a l6-bit unsigned number in accumulator 2 (accumulator 0 contains the most significant bits of the dividend):

DOCS 2,1
Before division occurs, accumulators 0 and 2 are compared. If the number in accumulator 0 is less than the number in accumulator 2 , division occurs, the quotient is stored in accumulator 1 , accumulator 0 stores the remainder, and the carry bit is set to zero. The contents of accumulator 2 do not change. If the number in accumulator 0 is greater than or equal to the number in accumulator 2 , the carry bit is set to 1 , the operation is terminated, and all operands remain unchanged. Figure 7-2 illustrates the bit format for this instruction.

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |
| $089 \cdot 10$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 7-2. Hardware Divide Instruction Format

HM-085-0023-01
POINT 4 Data Corporation

### 7.3 STACK OPERATION

Before performing the first stack operation, the stack and frame pointers must be initialized as follows:

1. The stack pointer must be initialized to the beginning address of the stack area minus 1 .
2. If the main program uses the frame pointer, the frame pointer must be initialized to the same value as the stack pointer. Otherwise, the frame pointer can be initialized in a subroutine by the SAVE instruction.

During every instruction that pushes data onto the stack, a check is made for stack overflow. If the instruction places data in a word whose address is an integral multiple of 256 (decimal), a stack overflow is indicated. When a stack overflow is indicated, the following actions occur:

1. The current instruction is completed.
2. The internal Stack Overflow flag is set to l.
3. A stack fault routine is performed if the Interrupt On flag is l. If the Interrupt On flag is 0, the Stack Overflow flag remains set to 1 . When interrupts are enabled, the stack fault routine is performed.

The stack fault routine performs the following actions:

1. Inhibits program map if enabled.
2. Sets Interrupt On flag to 0 .
3. Sets Stack Overflow flag to 0.
4. Updates program counter.
5. Places updated program counter in physical location 0 .
6. Executes jump indirect to physical location 3.

The stack instructions follow standard I/O instruction format. Stack manipulations occur within the CPU and memory. No data transfers take place in response to these instructions.

The MARK 9 CPU supports two sets of stack instructions: the EIS stack instructions described in Section 6.3.5, and the MARK 9exclusive stack instructions described here.

The MARK 9-exclusive stack instructions are:

| DIB ac,l | Push accumulator |
| :--- | :--- |
| DIBC ac,l | Pop accumulator |
| DIC 0,1 | Save |
| DOA ac,l | Move to stack pointer |
| NIO ac,l | Move to frame pointer |
| DOAC ac,l | Move from stack pointer |
| NIOC ac,1 | Move from frame pointer |
| DICC 0,1 | Return |

### 7.3.1 PUSE ACCUMULATOR

The following instruction pushes the contents of the designated accumulator on top of the stack:

DIB ac,l
The contents of the accumulator do not change. Figure 7-3 illustrates the format for this instruction.


Figure 7-3. Push Accumulator Instruction Format

### 7.3.2 POP ACCUMULATOR

The following instruction pops the top word in the stack:
DIBC ac,l
The popped word is placed in the designated accumulator. Figure 7-4 illustrates the format for the pop accumulator instruction.


Figure 7-4. Pop Accumulator Instruction Format

### 7.3.3 SAVE

The following instruction saves the value of the stack pointer in the frame pointer and accumulator 3:

DIC 0,1
Figure 7-5 illustrates the format for this instruction.


Figure 7-5. Save Instruction Format

When using 32 K -word mode, the Save instruction pushes a five-word return block on the stack. Table 7-l describes the destination of these five words.

TABLE 7-1. 32K-WORD MODE STACK RETURN BLOCK DESTINATIONS

| Word | Destination |
| :---: | :---: |
| 1 | Contains the contents of accumulator 0 |
| 2 | Contains the contents of accumulator 1 |
| 3 | Contains the contents of accumulator 2 |
| 4 | Bit 0 - always 0 <br> Bits l-15 - contain the value of the frame pointer before execution of this instruction |
| 5 | Bit 0 - represents Carry flag <br> Bits l-l5 - contain the contents of accumulator 3 |

When using 64 K -word mode, the Save instruction pushes a six-word return block on the stack. Table 7-2 describes the destinations of these six words.
table 7-2. 64k-word mode stack return block destinations

| Word | Destination |
| :---: | :---: |
| 1 | Contains the contents of accumulator 0 |
| 2 | Contains the contents of accumulator 1 |
| 3 | Contains the contents of accumulator 2 <br> before execution of this instruction |
| 4 | Contains the contents of accumulator 3 <br> 6 |
| Bits 0 | represents carry flag not defined |

After the last word of the return block is placed on the stack, the value of the stack pointer is placed in the frame pointer and accumulator 3. The contents of accumulators 0,1, and 2 do not change.

### 7.3.4 MOVE TO STACK POINTER

The following instruction moves bits 0 through 15 of the designated accumulator into the stack pointer:

DOA ac,l
The contents of the accumulator do not change. Figure 7-6 illustrates the format for this instruction.


Figure 7-6. Move to Stack Pointer Instruction Format

### 7.3.5 MOVE TO FRANE POINTER

The following instruction moves bits 0 through 15 of the designated accumulator into the frame pointer:

NIO ac,l
The contents of the accumulator do not change. Figure 7-7 illustrates the format for this instruction.


Figure 7-7. Move to Frame Pointer Instruction Format

### 7.3.6 MOVE FROM STACK POINTER

The following instruction moves the contents of the stack pointer into bits 0 through 15 of the designated accumulator:

DOAC ac,l
The contents of the stack pointer do not change. Figure 7-8 illustrates the format for this instruction.

| 0 |  | 2 | 3 | 4 | 5 | 7 | 8 | 9 | 10 |  |  |  |  | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 1 | ac | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |

089-32

Figure 7-8. Move from Stack Pointer Instruction Format

### 7.3.7 MOVE FROM FRAME POINTER

The following instruction moves the contents of the frame pointer into bits 0 through 15 of the designated accumulator:

NIOC ac,l
The contents of the frame pointer do not change. Figure 7-9 illustrates the format for this instruction.

| 0 |  | 2 | 3 | 4 | 5 |  | 7 | 8 | 9 | 10 |  |  |  |  | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 1 | ac | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |

Figure 7-9. Move from Frame Pointer Instruction Format

$$
52+2.212
$$

### 7.3.8 RETURN

The following instruction places the contents of the frame pointer in the stack pointer:

## DICC 0,1

Figure 7-10 illustrates the format for this instruction.

| 0 |  | 2 | 3 | 4 | 5 |  | 7 | 8 | 9 | 10 |  |  |  |  | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |

089-34

Figure 7-10. Return Instruction Format

When using 32 K -word mode instructions, five words are popped from the stack after the frame pointer contents are stored in the stack pointer. Table 7-3 describes the destinations of these five words.

TABLE 7-3. 32K-WORD MODE RETURN DESTINATIONS

| Word | Destination |
| :---: | :---: |
| 1 | Bit 0 - placed in the carry flag <br> Bits $1-15-$ placed in the program counter |
| 2 | Bits 1-15-placed in the frame pointer <br> Bits 0-15-placed in accumulator 3 |
| 3 | Placed in accumulator 2 |
| 4 | Placed in accumulator 1 |
| 5 | Placed in accumulator 0 |

When using 64 K -word mode instructions, six words are popped from the stack after the frame pointer contents are stored in the stack pointer. Table 7-4 describes the destinations of these six words.
table 7-4. 64k-word mode return destinations

| Word | Destination |
| :---: | :---: |
| 1 | Bit 0 - placed in the carry flag |
| Bits 1-15-not defined |  |
| 2 | Placed in accumulator 3 |
| 3 | Placed in frame pointer |
| 4 | Placed in accumulator 2 |
| 5 | Placed in accumulator 1 |
| 6 | Placed in accumulator 0 |

### 7.4 MAPPED MEMORY OPERATION

The map manages the MARK 9 memory. Two user maps with 32 pages of 1 K -word blocks and two data channel maps with 32 pages of lK-word blocks are available when using 32 K -word addressing mode. Two user maps with 64 pages of lK-word blocks, one data channel map with 64 pages of lk-word blocks, and one utility map with 64 pages of 1 K -word blocks are available when using 64 K -word addressing mode.

A particular map--user or data channel-may be enabled or not. If the map is enabled, then all memory references for that operation--user or data channel--are mapped. If the map is not enabled, then all memory references for that operation will access the lower 32 K or 64 K words of memory.

The data channel maps are enabled or disabled if a Write Map Status instruction occurs with bit lof the designated accumulator set to 1 or 0 , respectively.

The user or program map is enabled in two stages: first, a Write Map Status instruction must occur with bit 0 of the designated accumulator set to 1 . Then, the user map is enabled after the first indirect memory reference following the Write Map Status instruction.

### 7.4.1 DEVICE INTERRUPT PROCESSING

The Map has been designed to allow for orderly processing of I/O interrupt requests by a supervisor program. When an I/O device requests an interrupt, the inhibit program map bit in the read-map status word is set to l. This immediately disables the translating of user addresses so that the remainder of the interrupt process happens in the same manner as in those computers that have no address translation hardware. That is, the Interrupt on flag is set to 0 , the updated program counter is placed in physical memory location 0 , and the CPU executes a jump indirect to physical memory location 1. A similar process occurs for stack overflow, and normal trap instructions.

### 7.5 MEMORY MAP INSTRUCTIONS

The following instructions are used to support the mapped memory features of the POINT 4 MARK 9 CPU:

```
DOB <f> ac,MAP
DOA <f> ac,MAPI
DIA <f> ac,MAPI
DIA <f> ac,MAP
DOA <f> ac,MAP
NIOP MAP
NIOC MAPI
DOC ac,MAP
DIC ac,MAP
```

(load map)
(initiate page check)
(page check)
(read map status)
(write map status)
(map single-cycle)
(clear map)
(load map memory from main memory)
(load main memory from map memory)

Map instructions follow the standard $I / O$ instruction format. Data transfers take place between the CPU and map. No data transfers take place between the CPU and peripheral devices, although the instructions follow the $I / O$ instruction format. Refer to Section 5.6 for detailed information on the $I / O$ instruction format.

Device codes 2 and 3 are reserved for the memory mapped unit. The mnemonic MAP refers to device code 2. The mnemonic MAPl refers to device code 3. The following flag control commands are used by device code 2:
$f=S$ - reserved for future use
f = C - reserved for future use
$f=P$ - the second non-data channel memory address is mapped after issuing this command; the proper map is indicated by the single-cycle select bit in the map status word

The following flag control commands are used by device code 3:
$f=S$ - reserved for future use
$f=C-t h e ~ p r o g r a m$ map and data channel sections of the map are disabled; all internal map logic is initialized
$f=P$ - reserved for future use

### 7.5.1 LOAD MAP

The following instruction loads the map memory by transferring the contents of the designated accumulator to the map memory:

DOB [f] ac, MAP
The contents of the accumulator do not change. Figure 7-11 illustrates the format for this instruction.


089-11

Figure 7-11. Load Map Instruction Pormat

Figure 7-12 illustrates the format for the designated accumulator. Table 7-5 describes the function of the accumulator bits.

| 0 | 5 | 6 | 7 | 8 | 0 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SEL | LOGICAL PAGE | A/B | 0 | 0 |  | PHYSICAL PAGE |

089-12

Figure 7-12. Accumulator Format for Load Map Instruction

TABLE 7-5. ACCUMULATOR FUNCTIONS FOR LOAD MAP INSTRUCTION

| Bit | Name | Function |
| :--- | :--- | :--- |
| 0 | SEL (map <br> select) | 0 - address translation for the <br> program map <br> 1 - address translation for the data <br> channel map |
| $1-5$ | Logical <br> page <br> number | Range: 0-37 (octal) <br> 6 |
| $7-8$ | A- address translation for map A of <br> map selected by bit 0 |  |
| $9-15$ | Reserved <br> Physical <br> page <br> number selected by bit 0 | Mast be set to 0 0 |

### 7.5.2 INITIATE PAGE CHECK

The following instruction initiates a page check by transferring the contents of the designated accumulator and the map to a temporary register:

DOA [f] ac,MAPl
The contents of the accumulator do not change. Figure 7-13 illustrates the instruction format for this instruction.


089-1 3

Figure 7-13. Initiate Page Check Instruction Format

Figure 7-14 illustrates the format for the designated accumulator. Table 7-6 describes the functions of the accumulator bits.

| 0 | 1 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SEL |  | 7 |  |  |
| $089-14$ |  |  |  |  |

Figure 7-14. Accumulator Format for Initiate Page Check Instruction

TABLE 7-6. ACCUMULATOR FUNCTIONS FOR INITIATE PAGE CHECK INSTRUCTION

| Bit | Name | Function |
| :--- | :--- | :---: |
| 0 | SEL (map <br> select) | 0 - page check is for program map <br> 1 - page check is for data channel map |
| $1-5$ | Logical <br> page | Range: 0-37 (octal) |
| 6 | A/B | 0 - page check for map A of map <br> selected by bit 0 |
| $7-15$ | Reserved | Should be set to 0 0 |

### 7.5.3 PAGE CHECK

The following instruction places the physical page number of the logical page in bits 9 through 15 of the designated accumulator:

DIA [f] ac,MAPI
Bits 0 through 8 of the designated accumulator for the last Initiate Page Check instruction are placed in bits 0 through 8 of the designated accumulator. The initiate page check instruction (DOA [f] ac,MAPl) specifies the logical page. Figure 7-15 illustrates the format for this instruction.


089-15

Figure 7-15. Page Check Instruction Format

Figure 7-16 illustrates the format for the designated accumulator. Table 7-7 describes the functions of the accumulator bits.

| 0 |  | 6 | 7 | 8 | 0 |  | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SEL | LOGICAL PAGE | A/B | 0 | 0 |  | PHYSICAL PAGE |  |

Figure 7-16. Accumulator Format for Page Check Instruction

TABLE 7-7. ACCUMULATOR FUNCTIONS FOR PAGE CHECK INSIRUCTION

| Bit | Name | Function |
| :---: | :---: | :---: |
| 0 | SEL (map select) | Copied from initiate page check instruction: <br> 0 - page check for program map <br> 1 - page check for data channel map |
| 1-5 | Logical page | Range: 0-37 (octal); copied from initiate page check instruction |
| 6 | A/B | Copied from initiate page check instruction: <br> 0 - page check for map $A$ of map selected by bit 0 <br> 1 - page check for map $B$ of map selected by bit 0 |
| 7-8 | Reserved | Should be 0 |
| 9-15 | Physical page number | Physical page number - Range: 0-177 (octal); this page number is the physical page number of the logical page specified in the initiate page check instruction |

### 7.5.4 READ MAP STATUS

The following instruction reads map status:
DIA [f] ac,MAP
The l6-bit map status word is placed in the designated accumulator. Figure 7-l7 illustrates the format for this instruction.


089-17

Figure 7-17. Read Map Status Instruction Format

Figure 7-18 illustrates the format for the designated accumulator. Table 7-8 describes the functions of the accumulator bits.

| 0 | 1 | 2 | 3 |  | 5 | 6 | 78 | 0 | 10 | 11 |  |  | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PM | DCM | PMI | 0 | 0 | 0 | UME | $\begin{aligned} & \text { TBL } \\ & \text { LOAD } \end{aligned}$ | 0 | $\begin{gathered} \mathbf{S C} \\ \mathbf{S E L} \end{gathered}$ | 0 | 0 | 0 | 0 | A/B |

Figure 7-18. Accumulator Format for Read Map Status Instruction

TABLE 7-8. ACCUYULATOR FUNCTIONS FOR READ MAP STATUS INSTRUCTION

| Bit | Name | Function |
| :---: | :---: | :---: |
| 0 | PM | 0 - disables program map <br> l - enables program map |
| 1 | DCM | 0 - disables data channel map <br> 1 - enables data channel map |
| 2 | PMI | 0 - program map not inhibited <br> 1 - inhibits program map; overrides bit 0 |
| 3-5 | Reserved | Reserved for future use; set to 0 during normal operation* |
| 6 | UME | 0 - disables utility map <br> 1 - enables utility map; overrides program map and map select (PM and A/B) |
| 7-8 | TBL Load | ```Specifies map for next DOC instruction: 00 - map A 01 - map B 10 - data channel map ll - utility map``` |
| 9 | Reserved | Reserved for future use; should be 0 |
| 10 | SC SEL | $\begin{aligned} & \text { Single-cycle select: } \\ & 0-A \\ & 1-B \end{aligned}$ |
| 11-14 | Reserved | Reserved for future use; should be 0 |
| 15 | A/B | $\begin{aligned} & \text { Program map select: } \\ & 0-A \\ & 1-B \end{aligned}$ |

*bit 5 is used during diagnostic testing

### 7.5.5 WRITE MAP STATUS

The following instruction places the contents of the designated accumulator in the map status word:

DOA [f] ac, MAP
The inhibit program map bit (bit 2) in the status word is set to 0 . Figure 7-19 illustrates the format for this instruction.


089-19

## Figure 7-19. Write Map Status Instruction Format

Figure 7-20 illustrates the format for the designated accumulator. Table 7-9 describes the functions of the accumulator bits.

| 0 | 1 | 2 |  |  | 5 | 6 | 78 | 9 | 10 | 11 |  |  | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PM | DCM | 0 | 0 | 0 | 0 | UME | $\begin{array}{r} \text { TBL } \\ \text { LOAD } \\ \hline \end{array}$ | 0 | $\begin{gathered} \mathrm{SC} \\ \mathrm{~A} / \mathrm{B} \end{gathered}$ | 0 | 0 | 0 | 0 | A/B |

Figure 7-20. Accumulator Format for Write Map Status Instruction

TABLE 7-9. ACCUMULATOR FUNCTIONS FOR WRITE MAP STATUS INSTRUCTION

| Bit | Name | Function |
| :---: | :---: | :---: |
| 0 | PM | Enable program map |
| 1 | DCM | Enable data channel map |
| 2-5 | Reserved | Reserved for future use; set to 0 during normal operation* |
| 6 | UME | Enables utility map; overrides program map and map select (PM and A/B) |
| 7-8 | TBL Load | ```Specifies map for next DOC instruction: 00 - map A 01 - map B 10 - data channel map ll - utility map``` |
| 9 | Reserved | Reserved for future use; set to 0 |
| 10 | SC A/B | $\begin{aligned} & \text { Single-cycle select: } \\ & 0-A \\ & 1-B \end{aligned}$ |
| 11-14 | Reserved | Reserved for future use; set to 0 |
| 15 | A/B | $\begin{aligned} & \text { Program map select: } \\ & 0-A \\ & 1-B \end{aligned}$ |
| *bit 5 is used during diagnostic testing |  |  |

### 7.5.6 MAP SINGLE CYCLE

The following instruction maps the second nondata channel memory reference with the map indicated by the single-cycle select bit in the map status word:
NIOP MAP

Figure 7-21 illustrates the format for this instruction.


Figure 7-21. Map Single-Cycle Instruction Format

### 7.5.7 CLEAR MAP

The following instruction clears the map:
NIOC MAPI
This instruction disables the program and data channel maps. All map logic is initialized. Figure 7-22 illustrates the format for this instruction.


Figure 7-22. Clear Map Instruction Format

### 7.5.8 LOAD MAP MEYORY FROM MAIN MEYORY

The following instruction loads the map memory from main memory:
DOC ac, MAP
The accumulator contains the address of the first memory location to use in loading the map. The map will continue to load until either 64 words are loaded or a -1 (177777 octal) is located. This instruction is used with the TBL bits in the Read Map Status instruction. Figure 7-23 illustrates the format for this instruction.


Figure 7-23. Load Map Memory From Main Memory Instruction Format

Figure 7-24 illustrates the format for each entry of the table. Table 7-10 describes the function of each entry of the table.

| 0 | 5 | 7 | 7 |  |
| :--- | :--- | :--- | :--- | :--- |
| LOGICAL PAGE | 0 | 0 |  | PHYSICAL PAGE |

Figure 7-24. Table Format for Load Map Memory from Main Memory Instruction

# TABLE 7-10. TABLE FUNCTIONS FOR LOAD MAP MEMORY FROM MAIN MEMORY INSTRUCTION 

| Bit | Name | Function |
| :---: | :--- | :--- |
| $0-5$ | Logical <br> page number | Range 0-77 (octal) |
| $6-7$ | Reserved | Reserved for future use; <br> set to 0 |
| $8-15$ | Physical <br> page number | Range 0-377 |

### 7.5.9 LOAD MAIN MEMORY FROM MAP MEMORY

The following instruction loads memory from the map memory:
DIC ac,MAP
64 words of the map will be stored into memory starting at the address in ac. This instruction is used with the TBL bits in the status word. Figure 7-25 illustrates the format for this instruction.


089-29

## Pigure 7-25. Load Main Memory from Map Memory Instruction Format

Figure 7-26 illustrates the format for each entry of the table. Table 7-1l describes the function of each entry of the table.

| 0 | 5 | 6 | 7 | 8 |
| :---: | :---: | :---: | :---: | :---: |
| LOGICAL PAGE | 0 | 0 |  | PHYSICAL PAGE |

089-28

# Figure 7-26. Table Format for Load Main Memory from Map Memory Instruction 

TABLE 7-11. TABLE FUNCTIONS FOR LOAD MAIN MEMORY
PROM MAP MEHORY INSTRUCTION

| Bit | Name | Function |
| :---: | :---: | :---: |
| $0-5$ | Logical <br> page number | Range 0-77 (octal) |
| $6-7$ | Reserved | Reserved for future use; <br> should be 0 |
| $8-15$ | Physical <br> page number | Range 0-377 |

### 7.6 TRAP INSTRUCTION

The following instruction causes ALU traps when in 32 K mode:
ALU NO LOAD, NO SKIP
The logical address of this instruction is placed in bits 0 through 15 of memory location 46 (octal). The processor places the contents of location 47 (octal) into the program counter. This instruction is disabled when either the 64 K mode (MARK 5/9) or the Extended Instruction Set is enabled. Figure 7-27 illustrates the format for this instruction. Table 7-12 describes the functions of the instruction bits.

| 0 | 12 | 34 | 5 | 11 | 12 | 13 |  | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | ACS | ACD | TRAP NUMBER |  | 1 | 0 | 0 | 0 |

Figure 7-27. Trap Instruction Format

TABLE 7-12. TRAP INSTRUCTION FUNCTIONS

| Bit | Name | Function |
| :--- | :--- | :--- |
| 0 | None | Set to li indicates arithmetic/logic <br> instruction group |
| $1-2$ | ACS | Designates source accumulator <br> $3-4$ ACD |
| $5-11$ | Trap | Designates destination accumulator |
| 12 | NL | No-load field; set to l; does not <br> store shifter output <br> Section 5.6) |
| $13-15$ | None | Skip control field; set to of does <br> not allow skip test (refer to <br> Section 5.5) |

## CAUTION

Destruction of data may result if care is not exercised when using this instruction. The MARK 5 CPU executes an ALU NO LOAD, NO SKIP instruction as a no operation. The 32 K mode in the MARK 9 CPU executes the ALU NO LOAD, NO SKIP instruction as a trap. The EIS mode in MARK 5 and MARK 9 CPUs uses locations 46 (octal) as the frame pointer and 47 (octal) as the stack limit pointer. These locations are checked when a stack operation is performed.

## Section 8 <br> OPTIONAL FEATURES

### 8.1 INTRODUCTION

This section describes the following optional features:

- Battery Backup
- Operator Control Unit
- Voltage Regulator
- Micro-programmed Floating Point Unit (MFPU)
- Mapped Memory

NOTE
Unless otherwise noted, information in this section applies to the MARK 5, MARK 5 with EIS, and MARK 9 computers.

### 8.2 BATTERY BACKUP

The Battery Backup option provides three features:

- Memory contents protection for at least 2 hours in case of power failure
- Power fail auto-restart after resumption of power service
- Standby mode, which removes Main Power Regulator +5 V , $\pm 15 \mathrm{~V}$ and -5 V power, but maintains $+5 \mathrm{~V} B \mathrm{~B},-5 \mathrm{~V} \mathrm{BU}$, and +12 V BU power to the CPU slot to preserve memory contents

NOTE
The MARK 9 CPU only uses +5 V and +5 V BU.

### 8.2.1 BATTERY BACKUP VOLTAGES

The battery unit is maintained in a charged state by the power supply as long as the unit is plugged in, and AC power is available. The battery backup module includes one 12 V sealed lead acid battery which provides the following voltages to the CPU/memory board and Mini-Panel in case of power failure:

Voltage
Supplied to
+5 V BU $\quad$ CPU board memory refresh logic, Mini-Panel

- 5V BU For memory on CPU board (MARK 5)
+12 V BU For memory on CPU board (MARK 5)
Battery backup voltages can be monitored on the power supply chassis Mini-Panel by the light-emitting diode (LED) labeled as $B U$ voltages. Illumination of these LED indicators signifies that these voltages are in tolerance. If one or more of these LED indicators is not illuminated, one of the following conditions exists:

AC Power
ON
OFF Batteries are discharged and memory contents are lost

[^6]
### 8.2.2 POWER MONITOR AUTO-RESTART HANDLING

When AC power fails, an unmaskable interrupt is produced. A power-fail interrupt is indicated if the CPU Done flag is set to l. Two input/output CPU instructions are associated with a power-fail interrupt:

Instruction
SKPDN Skip if a power-fail interrupt has occurred

SKPDZ Skip if a power-fail interrupt has not occurred

These instructions may be used to transfer control to a routine for handling power-fail conditions, and performing the following functions:

- Save the accumulators, Carry flag, and program counter (PC) where the interrupt occurred. The PC is in location 0 of memory, and must be moved to another location.
- Perform other cleanup functions that may be necessary.
- Put an appropriate auto-restart instruction in memory location 0 .
- Halt.

While the power-fail condition exists, the Backup Battery Unit retains the contents of memory for at least 2 hours, if the batteries were fully charged when the power-fail occurred.

When AC power is restored, the CPU will begin execution at memory location 0 if the processor Mini-Panel keyswitch is set to AUTO. If the keyswitch is not set to AUTO, the processor will halt, with the program counter equal to 0 , pending operator action.

### 8.3 OPERATOR CONTROL UNIT (OCU)

The OCU enhances operator access to the CPU. An extensive discussion of Operator Control Unit capabilities and operating procedures is in Section 3.4. Section 2.7 describes installation of the OCU .

### 8.4 VOLTAGE REGULATOR

The Voltage Regulator option provides the user with a l2-volt regulator on the PC board itself. This option is designed for use in a chassis that does not provide a regulated +l2v supply, as in a typical Nova-type chassis with a +15 V unregulated supply. This regulator converts an unregulated supply of at least +13.2 volts to +12 volts of regulated voltage.

NOTE
The MARK 9 CPU requires only +5 V . The +12 V is not used by the MARK 9 CPU.

### 8.5 MICRO-PROGRAMMED FLOATING POINT UNIT

The Micro-Programmed Floating Point Unit (MFPU) is a firmware option designed to serve as a floating point binary arithmetic unit, which significantly reduces floating-point computation time. MFPU is available only on MARK 5 CPUs that also have the EIS option.

### 8.5.1 MPPU FORMATS

The MFPU allows two number formats: single precision (two words) and double precision (four words). In both formats, the first word contains the sign, exponent, and most significant eight bits of the mantissa. The exponent is 7 bits long, in excess-64 notation, and represents a power of l6. Data used for a calculation is assumed to be normalized (i.e., the first four bits of the mantissa are not all 0); after the calculation, the result is normalized and stored. If the first word of a number is equal to 0 , the MFPU interprets the entire number as equal to 0 . The MFPU formats are shown in Figure 8-1.


085-48

Figure 8-1. MPPU Formats

### 8.5.2 MPPU COMIMANDS

Ten MFPU commands for single and double precision may be specified. Table 8-1 defines these commands. Their binary formats are shown in Table 8-2.

TABLE 8-1. MFPU COMMANDS

| Command | Definition |
| :--- | :--- |
| FPADD | Add single precision |
| FPSUB | Subtract single precision |
| FPMUL | Multiply single precision |
| FPDIV | Divide single precision |
| FDADD | Add double precision |
| FDSUB | Subtract double precision |
| FDMUL | Multiply double precision |
| FIX* | Divide double precision <br> FLT*Convert floating single precision to <br> one-word, fixed-point unsigned integer <br> (truncated) |
| Convert one-word, fixed-point unsigned <br> integer to floating single precision |  |

*Double-precision forms of FIX and FLT are not provided because:

- FIX - the last two words have no effect on the answer; the single-precision floating form is already more precise than a one-word integer.
- FLT - for a double-precision answer, set the last two words to 0 .

TABLE 8-2. MPPU COMIMAND FORMATS

| Command* | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FPADD | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| FPSUB | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| FPMUL | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| FPDIV | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| FDADD | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| FDSUB | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| FDMUL | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| FDDIV | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| FIX | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| FLT | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |

*These commands would be no-op skips in a MARK 5 (with EIS) without MFPU.

### 8.5.3 OPERAND ADDRESSING

All MFPU commands are two-address instructions:

- AO holds the address of the source operand
- Al holds the address of the destination operand

For example, if $A O=S$ and $A l=D$, MFPU commands would result in the following operations:

| ADD | D $<--$ |
| :--- | :--- |
| S+S |  |
| SUB | D $<--$ |
| MUL | D $<--$ |
| D*S |  |
| DIV | D $<--$ |
| D/S |  |
| FIX | D $<--$ |
| S (converted) |  |
| FLT | D $<--$ |
| S (converted) |  |

Note that $S$ remains unchanged in all cases. Accumulators $A 2$ and A3 are not changed by the MFPU, but the carry is left in an undefined state.

### 8.5.4 OVERFLOW AND UNDERFLON

All commands (except FLT) when executed without error (overflow condition) cause the next instruction in the sequence to be skipped; the next instruction is executed in case of error/overflow, as shown in Table 8-3.

## TABLE 8-3. ERROR OVERFLOW

| Command | Overflow |
| :---: | :---: |
| FPADD, FDADD | Absolute value of result $\geq 16^{63}$ |
| FPSUB,FDSUB | Absolute value of result $\geq 16^{63}$ |
| FPMUL,FDMUL | Absolute value of result $\geq 16^{63}$ |
| FPDIV,FDDIV | Divisor $=0$ or result $\geq 16^{63}$ |
| IX | Value $\geq 2^{16}$ |
| FLT | No error possible |

In case of underflow (result $<16^{-65}$ ), the result is set $=0$ and no error indication is given.

### 8.5.5 ENABLING AND DISABLING

MFPU instructions are enabled and disabled at the same time as the Extended Instruction Set (see Section 6.2).

### 8.6 256K WORD MEMORY

The MARK 9 is equipped with 128 K words of memory. Optional memory may be purchased to increase main memory size to 256 K words.

APPENDICES

## Appendix A <br> VON NEUMAN MAP OF POINT 4 MARK 5/9 STANDARD INSTRUCTIONS



## Appendix B <br> POINT 4 MARK 5/9 STANDARD INSTRUCTION REFERENCE CHART

| ARITH/LOGIC |  | MEMORY R | REFERENCE | INPUT/OUTPUT |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 100000 | COM | 0 | JMP | 60000 | NIO |
| 100400 | NEG | 4000 | JSR | 60400 | DIA |
| 101000 | MOV |  |  | 61000 | DOA |
| 101400 | INC | 10000 | ISZ | 61400 | DIB |
| 102000 | ADC | 14000 | DSZ | 62000 | DOB |
| 102400 | SUB |  |  | 62400 | DIC |
| 103000 | ADD | 20000 | LDA | 63000 | DOC |
| 103400 | AND | 40000 | STA |  |  |
|  |  |  |  | ACCUMULATOR |  |
| SOURCE |  | ACCUMULATOR |  | 0 | 0 |
| 0 | 0 | 0 | 0 | 4000 | 1 |
| 20000 | 1 | 4000 | 1 | 10000 | 2 |
| 40000 | 2 | 10000 | 2 | 14000 | 3 |
| 60000 | 3 | 14000 | 3 |  |  |
|  |  |  |  | I/O PULSE |  |
| DESTINATION |  | INDIRECT |  | 100 | S |
| 0 | 0 | 2000 | @ | 200 | C |
| 4000 | 1 |  |  | 300 | P |
| 10000 | 2 | ADDRESS | MODE |  |  |
| 14000 | 3 | 0 | ABS | I/O SKIP |  |
|  |  | 400 | REL | 63400 | SKPBN |
| SHIFT100 |  | 1000 | BASE2 | 63500 | SKPBZ |
|  |  | 1400 | BASE 3 | 63600 | SKPDN |
| 200 | R |  |  | 63700 | SKPDZ |
| 300 | S | DISPLACEMENT$0-177$ POS. |  |  |  |
|  |  |  |  | DEVICE | ODDE |
|  |  | 200-377 N | NEG. | 10 | TTI |
| $20$ | $z$ |  |  | 11 | TTO |
| 40 | 0 |  |  | 12 | PTR |
| 60 | C | SPECIAL ARITHMETIC |  | 13 | PTP |
|  |  |  |  | 14 | RTC |
| NO-LOAD |  | TESTS |  | 17 | LPT |
| 10 | \# | 101014 | SKZ |  |  |
| SKIP CONDITION |  | 101015 | SNZ |  |  |
|  |  | 101112 S | SSP | INSTRUCTIONS |  |
| 1 | SKP | 101113 | SSN | 60177 | INTEN |
| 2 | SZC | 102032 S | SGE | 00277 | INTDS |
| 3 | SNC | 102033 S | SLS | 60477 | READS |
| 4 | SZR | 102414 S | SEO | 61477 | INTA |
| 5 | SNR | 102415 S | SNE | 62077 | MSKO |
| 6 | SEZ | 102432 S | SGR | 62677 | IORST |
| 7 | SBN | 102433 S | SLE | 63077 | HALT |

082-38

## Appendix C ASCII CODE CHART

ASCII CODE in OCTAL

| 000 | NUL | <CTRL-@> | 040 | BLANK | 100 | @ | 140 | , |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 001 | SOH | <CTRL-A> | 041 | ! | 101 | A | 141 | a |
| 002 | STX | <CTRL-B> | 042 | " | 102 | B | 142 | b |
| 003 | ETX | <CTRL-C> | 043 | \# | 103 | C | 143 | C |
| 004 | EOT | <CTRL-D> | 044 | \$ | 104 | D | 144 | d |
| 005 | ENO | <CTRL-E> | 045 | \% | 105 | E | 145 | e |
| 006 | ACK | <CTRL-F> | 046 | \& | 106 | F | 146 | f |
| 007 | BEL | <CTRL-G> | 047 | 1 | 107 | G | 147 | g |
| 010 | BKSP | <CTRL-H> | 050 | $($ | 110 | H | 150 | h |
| 011 | HTAB | <CTRL-I> | 051 | ) | 111 | I | 151 | i |
| 012 | LF | <CTRL-J> | 052 | * | 112 | J | 152 | j |
| 013 | VTAB | <CTRL-K> | 053 | + | 113 | K | 153 | k |
| 014 | FF | <CTRL-L> | 054 | , | 114 | L | 154 | 1 |
| 015 | CR | <CTRL-M> | 055 | - | 115 | M | 155 | m |
| 016 | SO | <CTRL-N> | 056 | - | 116 | N | 156 | n |
| 017 | SI | <CTRL-0> | 057 | 1 | 117 | 0 | 157 | 0 |
| 020 | DLE | <CTRL-P> | 060 | 0 | 120 | P | 160 | p |
| 021 | XON | <CTRL-Q> | 061 | 1 | 121 | Q | 161 | q |
| 022 | AUXON | <CTRL-R> | 062 | 2 | 122 | R | 162 | r |
| 023 | XOFF | <CTRL-S> | 063 | 3 | 123 | S | 163 | S |
| 024 | AUXOFF | <CTRL-T> | 064 | 4 | 124 | T | 164 | t |
| 025 | NAK | <CTRL-U> | 065 | 5 | 125 | U | 165 | u |
| 026 | SYN | <CTRL-V> | 066 | 6 | 126 | V | 166 | v |
| 027 | ETB | <CTRL-W> | 067 | 7 | 127 | W | 167 | w |
| 030 | CAN | <CTRL-X> | 070 | 8 | 130 | X | 170 | x |
| 031 | ENDMD | <CTRL-Y> | 071 | 9 | 131 | Y | 171 | Y |
| 032 | SUB | <CTRL-Z> | 072 | : | 132 | Z | 172 | z |
| 033 | ESC | <CTRL-[> | 073 | ; | 133 | [ | 173 |  |
| 034 | F SEP | <CTRL-\> | 074 | $<$ | 134 | 1 | 174 | 1 |
| 035 | G SEP | <CTRL-]> | 075 | $=$ | 135 | ] | 175 | \} |
| 036 | R SEP | <CTRL-^〉 | 076 | > | 136 | $\cdots$ | 176 | $\sim$ |
| 037 | U SEP | 〈CTRL-_> | 077 | ? | 137 | - | 177 | DEL |

## Appendix D <br> VIRTUAL CONTROL PANEL COMMANDS (MANIP)

|  | APL does Auto-Boot if mini-switches are set to 200 + device code |
| :---: | :---: |
| A | Display PC, A0, Al, A2, A3, and carry |
| $C x, y(x<5)$ | Change accumulator $x$ (or carry if $x=4$ ) to value $y$ |
| Cx ( $\mathrm{x}>4$ ) | Convert real address x to virtual |
| Dx, a | Dump memory in octal, beginning at address $x$, using addressing mode a |
| Ex,a | Enable entry at address $x$, using addressing mode a |
| Fx, y | Establish offset $x-y$, where $x=r e a l$ memory address, $y=v i r t u a l$ (listing) address |
| J X | Jump to location $x$, after restoring accumulators and carry |
| $K x, y, z$ | Store constant $z$ in memory locations $x$ through $y$ |
| Mx, Y, z | Move memory block $x$ through y to location $z$ |
| Nx, Y, z,m | Search memory $x$ through $y$ for not-equal to $z$, using mask m (optional) |
| Ox, a | Output memory in ASCII, starting at location $x$, using addressing mode $a$, until a zero byte is encountered |

where a is an addressing mode parameter, defined as follows:
a Parameter
omitted
0
1
2

## Definition

Word address, including "F" offset, if any
Word address, absolute
Byte address, using offset, if any Byte address, lower 64 KB

Program load from DMA device code x; if $x$ is omitted, reads switches
$S x, Y, z, m$ Search memory $x$ through $y$ for the value $z$, using mask m (optional)
$X x, Y \quad$ Calculate checksum over $x$ through $y$
YX
$x: y$
Set up a delay after each CR/LF; $x=0$ for maximum delay; $x=177777$ for none

Enter value $y$ at address $x$, and open next cell for entry

Open previous cell for entry
CTRL ( ) Transmit control character to CTU

## Appendix E PROGRAMMING EXAMPLES

## E. 1 NUMBER HANDLING

## E.1.1 GENERATING NUMBERS

Six numbers can be generated with single instructions:

| SUB | 0,0 | $-->$ | 0 |
| :--- | :--- | :--- | :--- |
| SUBZL | 0,0 | $-->$ | 1 |
| SUBZR | 0,0 | $->100000$ |  |
| ADC | 0,0 | $->177777$ | $(=-1)$ |
| ADCZL | 0,0 | $->177776$ | $(=-2)$ |
| ADCZR | 0,0 | $->77777$ |  |

## E.1. 2 NUMBER TESTING

Twenty different sets of numbers can be tested with a single instruction. Figure E-l shows the conditions under which each of the basic arithmetic test instructions will skip. Figure E-2 shows which instructions to use to test the 20 sets of numbers. The skip condition can be changed from a zero-test to a nonzero-test to obtain the complements of the 20 sets.

| Instruction | SZR skips if: | SZC skips if: |
| :---: | :---: | :---: |
| MOVZ | 0 | all |
| MOVO | 0 | none |
| MOVZL | 0,100000 | $>=0$ |
| MOVOL | none | $>=0$ |
| MOVZR | 0,1 | even |
| MOVOR | none | even |
| COMZ | -1 | 0 |
| СОМО | -1 | none |
| COMZ L | -1,-2 | $<0$ |
| COMOL | none | <0 |
| COMZR | -1,77777 | odd |
| COMOR | none | odd |
| INCZ | -1 | not -1 |
| INCO | -1 | -1 |
| INCZL | 77777 | -1<=x<=77777 |
| INCOL | -1 | $-1<=x=77777$ |
| INCZR | 0 | odd |
| INCOR | -1 | odd |
| NEGZ | 0 | not 0 |
| NGEO | 0 | -1 |
| NEGZL | 100000 | $-77777<=\mathrm{X}<0$ |
| NEGOL | 0 | -77777<=x<0 |
| NEGZ R | -1 | even |
| NEGOR | 0 | even |
| ADDZ | 0,100000 | $>=0$ |
| ADDO | 0,100000 | <0 |
| ADDZ $L$ | 0 | 2d bit $=0$ |
| ADDOL | 100000 | 2d bit $=0$ |
| ADDZ R | 0 | all |
| ADDOR | 100000 | all |

NOTE
For $A D D$ instructions, $A C S$ and $A C D$ must be the same.

Figure E-1. Conditions Under Which Each of the BASIC Arithmetic Test Instructions Will Skip


## E. 2 BIT TESTING

Any bit in a word can be tested with a maximum of three instructions, without requiring another accumulator. Three bit positions can be tested with just one instruction (bits 0, 1 , and 15). Seven bit positions (bits 2, 3, 7, 8, 9, 10, and 14) require two instructions; the other six bit positions require three. Figure E-3 shows which instructions to use to test for any bit in a word.


## E. 3 ACCUMULATOR HANDLING

## E.3.1 TO "OR" TWO ACCUMULATORS

The following routine forms the inclusive-OR of AO and Al in Al. The routine uses the fact that an arithmetic ADD is equivalent to an OR if corresponding bits in the two operands are not both 1 .

COM 0,0
AND 0,1 ; remove those bits where both are 1
ADC 0,1 ;then add original value

## E.3.2 TO "EXCLUSIVE-OR" TWO ACCUMULATORS

This routine utilizes the fact that an arithmetic ADD is the same as an exclusive-OR except for the carry bits.

| MOV | 1,2 |  |
| :--- | :--- | :--- |
| ANDZL | 0,2 | ;form the carry bits |
| ADD | 0,1 | ;add the original operands |
| SUB | 2,1 | iremove the carry bits |

This routine destroys the Carry flag. To preserve the carry at the expense of an additional instruction, use the following:


## E.3.3 TO "DECREMENT" AN ACCUMULATOR

The following routine is used to decrement an accumulator:
NEG 0,0

## E.3.4 TO "COMPLEMENT" THE MOST SIGNIFICANT BIT

The following instruction complements the MSB and clears the carry bit:

ADDOR 0,0

## E. 4 PARITY GENERATION OR CHECKING

The two-instruction loop

$$
\begin{array}{ll}
\text { ADD } & 0,0, S Z R \\
\text { JMP } & -1
\end{array}
$$

will complement the original carry if AO had odd parity, and leave it unchanged if $A 0$ had even parity.

## E. 5 I/O PROGRAMMING FOR THE MASTER TERMINAL

The assembler listings in Figure E-4 provide examples of inputting and outputting to a master terminal (Teletype or CRT), using the standard device code lo/ll-type controller. They also illustrate byte handling and interrupt handling conventions. For further information on I/O interfaces, see Section 4.

```
; PROGRAMMING EXAMPLES
    1000.LOC 1000
; INPUT/OUTPUT ROUTINES
; MASTER TERMINAL INPUT - ACCEPTS CHARACTER INTO AO
\begin{tabular}{rrlll}
1000 & 63610 & SRPDN TTI & iIS THERE ANY INPUT AVAILABLE ? \\
1001 & 777 & JMP & © \\
1002 & 60610 & DIAC & \(0, T T I\) & iYES, REEP WAITING
\end{tabular}
; NOTE: FOR PAPER TAPE READER USE DIAS TO START READING NEXT CHARACTER
: MASTER TERMINAL OUTPUT - ASSUMES OUTPUT CHARACTER IS IN AO
```



```
085-44
```

Figure E-4. Master Terminal I/O Programming Examples (1 of 4)

- PAGE 2 -
; SUBROUTINE TO TYPE ASCII TEXT
INITIAL CONDITIONS: NONE
CALLING SEQUENCE:
JSR TYPE
(ASCII TEXT,
PACKED 2 CHARACTERS/WORD
WITH 0 BYTE TERMINATOR)
RETURNS HERE
RETURN CONDITIONS: AO $=0, A 2=$ PRESERVED

| 1006 | 25400 | TYPE: LDA | 1,0,3 | ;PICK UP 2 ASCII CHARACTERS |
| :---: | :---: | :---: | :---: | :---: |
| 1007 | 175420 | INCZ | 3,3 | ; ADV. RETURN PNTR; C=BYTE CNTR |
| 1010 | 20411 | TYPE2 : LDA | 0,C377L | ; LEFT-BYTE MASK |
| 1011 | 123705 | ANDS | 1,0,SNR | : EXTRACT A BYTE - IS IT 0 ? |
| 1012 | 1400 | JMP | 0,3 | ; YES, RETURN TO CALLER |
| 1013 | 63511 | SKPBZ | TTO | NO, WAIT FOR TTO NOT BUSY |
| 1014 | 777 | JMP | . -1 |  |
| 1015 | 61111 | DOAS | 0.TTO | :OUTPUT THE CHARACTER |
| 1016 | 125362 | MOVCS | 1,1,S2C | ; SWAP THE 2 ASCII CHAR.; CK. BYTE CNI |
| 1017 | 771 | JMP | TYPE2 | ; TYPE THE SECOND CHARACTER |
| 1020 | 766 | JMP | TYPE | GET 2 MORE CHARACTERS TO TYPE |
| 1021 | 177400 | C377L:177400 |  | ;OCTAL 377 IN LEFT byte |

```
; SUBROUTINE to type A nUMBER IN OCTAL FORM
INITIAL CONDITIONS: AI = NUMBER TO BE TYPED
CALLING SEQUENCE:
    JSR TPOCT
    RETURNS BERE
RETURN CONDITIONS: N = 0, N2 = PRESERVED, C = 1
```

| 1022 | 20413 | TPOCT:LDA | O,C.BIT |  |
| :---: | :---: | :---: | :---: | :---: |
| 1023 | 101120 | TPOC2: MOV 2 L | 0.0 | ;PRESET CARRY (MSB:1, OTHERS:0) |
| 1024 | 125105 | MOVL | 1,1,5NR | fLEFT-SEIFT A BIT OUT OF Al INTO C |
| 1025 | 1400 | JMP | 0,3 | PRETURN WHEN PUSHER BIT IS GONE |
| 1026 | 101103 | MOVL | 0,0,8NC | ;ASSEMBLE ASCII DIGIT; COMPLETE |
| 1027 | 775 | JMP | . -3 | ; NO, GET MORE BITS |
| 1030 | 63511 | 8KPBZ | TTO | ; WAIT FOR TTO NOT BUSY |
| 1031 | 777 | JMP | -1 |  |
| 1032 | 61111 | DOAS | 0.750 | ;OUTPUT THE ASCII DIGIT |
| 1033 | 20403 | LDA | O,C.OCT |  |
| 1034 | 767 | JMP | TPOC2 | :CONTINUE THE LOOP |

1035140014 C.BIT: 140014 ;CONST. TO STRIP OFF 1 BIT \& CNVT. TO ASCII 103610003 C.OCT:010003;CONST. TO STRIP OFF 3 BITS \& CNVT. TO ASCII

PAGE 3 -
BYTE MOVE SUBROUTINES
ASSUMPTION: ALL BYTE ADDRESSES REFER TO LOWER 32R OF MEMORY

GET A BYTE INTO AO FROM BYTE ADDRESS GIVEN IN Al
INITIAL CONDITIONS: AI = BYTE ADDRESS
CALLING SEQUENCE:
JSR GETBY
RETURNS EERE
RETURN CONDITIONS: AO = DESIRED BYTE, A = UNCHANGED

| 1037 | 131220 | GETBY: MOVZR | 1.2 | ; CONVERT BYTE ADDRESS INTO WORD ADDRESS |
| :---: | :---: | :---: | :---: | :---: |
| 1040 | 21000 | LDA | 0,0,2 | PFETCH WORD CONTAINING DESIRED BYTE |
| 1041 | 101003 | MOV | 0,0,5NC | ;DO WE WANT LEFT BYTE ? |
| 1042 | 101300 | MOVS | 0,0 | 8 YES, SWAP THE WORD |
| 1043 | 30403 | LDA | 2,C377 | : RIGHT BYTE MASK |
| 1044 | 143400 | AND | 2,0 | ;MASR THE RIGHT BYTE |
| 1045 | 1400 | JMP | 0,3 | ;RETURN |
| 1046 | 377 | C377: 377 |  |  |

POT A BYTE FROM AO INTO MEMORY AT BYTE ADDRESS GIVEN IN Al
INITIAL CONDITIONS: AO = GIVEN BYTE IN RIGHT EALF, LEFT HALF IMMATERIAL AI = BYTE ADDRESS
CALLING SEQUENCE:
JSR PUTBY
RETURNS EERE
RETURN CONDITIONS: AO, AI UNCHANGED

| 1047 | 54414 | PUTBY: STA | 3,PUTBR | ; SAVE RETURN ADDRESS |
| :---: | :---: | :---: | :---: | :---: |
| 1050 | 131220 | MOVZR | 1,2 | ; FORM WORD ADDRESS FROM BYTE ADDR. |
| 1051 | 34775 | LDA | 3,C377 | ; GET MASK FOR RIGHT HALF |
| 1052 | 163403 | AND | 3,0,SNC | ; MASK GIVEN BYTE; GOES IN LEFT EALF ? |
| 1053 | 101301 | MOVS | 0,0,SKP | ; YES, SWAP THE BYTE |
| 1054 | 175300 | MOVS | 3,3 | 8 NO, SWAP THE MASK |
| 1055 | 25000 | LDA | 1,0,2 | ;FETCH THE WORD WHERE BYTE IS TO GO |
| 1056 | 167400 | AND | 3.1 | gMARE ROOM FOR THE BYTE |
| 1057 | 107000 | ADD | 0,1 | : INSERT TEE BYTE |
| 1060 | 45000 | 8TA | 1,0,2 | ; PUT THE WORD BACK |
| 1061 | 145100 | MOVL | 2,1 | ;RESTORE Al |
| 1062 | 2401 | JMP | eputbr | ;RETURN |
| 1063 | 0 | PUTBR: 0 |  | : SAVE RETURN ADDRESS |

Figure E-4. Master Terminal I/O
Programming Examples (3 of 4)

- PAGE 4 -
: EIMPLE, SINGLE-LEVEL INTERRUPT VECTORING


Figure E-4. Master Terminal I/O Programming Examples (4 of 4)

## Appendix $F$ OCTAL VALUES FOR EXTENDED INSTRUCTIONS

This appendix applies to the MARK 5 with EIS and MARK 9 only.

## EXTENDED INSTRUCTIONS

| Instr | Octal Value | Instr | Octal Value |
| :--- | :--- | :--- | :--- |
|  |  |  |  |
| SLEI | $100011+$ byte*100 | POPJ | 140271 |
| SGRI | $100031+$ byte*100 | NYBSL | 164271 |
| SEQI | $100051+$ byte*100 | NYBSR | 164671 |
| SNEI | $100071+$ byte*100 | DECAD | 160271 |
| LDI | $140011+$ byte*100 | DECSU | 162271 |
| ADI | $140031+$ byte*100 | CONVE | 166271 |
| SBI | $140051+$ byte*100 | XLOAD | 154271 |
| CLRB | $140471+@ * 2000$ | XSTOR | 156271 |
| SETB | $141071+@ * 2000$ | VJSR | $140371+$ subnum*400 |
| TOGB | $141471+@ * 2000$ | GETBY | 144271 |
| SBZ | $150071+@ * 2000$ | PUTBY | 145271 |
| SBO | $154071+@ * 2000$ | SGETB | 146671 |
| SBZC | $150471+@ * 2000$ | SPUTB | 145671 |
| SBOC | $154471+@ * 2000$ | XGETB | 150271 |
| SBZS | $151071+@ * 2000$ | XPUTB | 153271 |
| SBOS | $155071+@ * 2000$ | XSGET | 150671 |
| SBZT | $151471+@ * 2000$ | XSPUT | 153671 |
| SBOT | $155471+@ * 2000$ | IGETB | $160371+$ disp*400 |
| SETSP | $142171+$ acc*4000 | IPUTB | $170371+$ disp*400 |
| REDSP | $140171+a c c * 4000$ | XTRAN | 160071 |
| PUSH | $162171+a c c * 4000$ | ABINM | 170271 |
| POP | $160171+a c c * 4000$ | BINDI | 170671 |
| PUSHJ | 142271 | MOVEW | 174271 |
| RPUSH | 142671 | RMOVW | 176271 |
| I2PUS | 143271 | TABLS | 172271 |
|  | $I 3 P U S 143671$ | TRACE* | 177471 |
|  |  |  |  |

[^7]
# Appendix G EXECUTION TIMES FOR EXTENDED INSTRUCTIONS 

This appendix lists the execution times of instructions on the MARK 5 with EIS option and the MARK 9 .

## MARK 5 (WITH EIS) EXTENDED INSTRUCTION EXECUTION TIMES

Instruction Execution Time

| SLEI | $700 \mathrm{~ns}+100 \mathrm{~ns}$ if Skip occurs |
| :--- | :--- |
| SGRI | $700 \mathrm{~ns}+100 \mathrm{~ns}$ if Skip occurs |
| SEQI | 700 ns |
| SNEI | $700 \mathrm{~ns}+100 \mathrm{~ns}$ if Skip occurs |
| LDI | 600 ns |
| ADI | 600 ns |
| SBI | 600 ns |
| CLRB | 1500 ns if indirect, +500 ns |
| SETB | 1400 ns if indirect, +500 ns |
| TOGB | 1500 ns if indirect, +500 ns |
| SBZ | 1300 ns if indirect, +400 ns |
| SBO | 1400 ns if indirect, +400 ns |
| SBZC | 1600 ns if indirect, +500 ns |
| SBOC | 1700 ns if indirect, +500 ns |
| SBZS | 1400 ns if indirect, +500 ns |
| SBOS | 1500 ns if indirect, +500 ns |
| SBZT | 1600 ns if indirect, +500 ns |
| SBOT | 1700 ns if indirect, +500 ns |
| SETSP | 700 ns |
| REDSP | 700 ns |
| PUSH | 1300 ns |

## Execution Time

| POP | 1400 ns |
| :---: | :---: |
| PUSHJ | 1900 ns |
| RPUSH | 1900 ns |
| I2PUS | 1900 ns |
| I3PUS | 1900 ns |
| POPJ | 1600 ns |
| NYBSL | $2600 \mathrm{~ns} / \mathrm{word}+1100 \mathrm{~ns}$ overhead |
| NYBSR | $3100 \mathrm{~ns} /$ word + 200 ns overhead |
| DECAD | 900 ns |
| DECSU | 800 ns |
| CONVE | 1600 ns |
| XLOAD | 1400 ns |
| XSTOR | 1400 ns |
| VJSR | 1100 ns |
| GETBY | 1200 ns |
| PUTBY | 1400 ns |
| SGETB | 1200 ns |
| SPUTB | 1400 ns |
| XGETB | 1400 ns |
| XPUTB | 1600 ns |
| XSGET | 1400 ns |
| XSPUT | 1600 ns |
| IGETB | 2400 ns |
| IPUTB | 2600 ns |
| XTRAN | 2100 ns |
| ABINM | 4900 ns |
| BINDI | 15000 ns maximum, 1400 ns minumum |
| MOVEW | $1000 \mathrm{~ns} /$ word +400 ns overhead |
| RMOVW | $1000 \mathrm{~ns} /$ word + 400 ns overhead |
| TABLS | $900 \mathrm{~ns} / \mathrm{word}+400 \mathrm{~ns}$ overhead |
| TRACE | 1700 ns |

## MARK 9 EXTENDED INSTRUCTION EXECUTION TIMES

| Instruction | Execution Time |
| :---: | :---: |
| SLEI | 575 ns + 100 ns if Skip occurs |
| SGRI | $575 \mathrm{~ns}+100 \mathrm{~ns}$ if skip occurs |
| SEQI | 575 ns |
| SNEI | 575 ns + 100 ns if Skip occurs |
| LDI | 525 ns |
| ADI | 525 ns |
| SBI | 525 ns |
| CLRB | 1300 ns if indirect, +550 ns |
| SETB | 1200 ns if indirect, +550 ns |
| TOGB | 1300 ns if indirect, +550 ns |
| SBZ | 1175 ns if indirect, +375 ns |
| SBO | 1250 ns if indirect, +375 ns |
| SBZC | 1375 ns if indirect, +550 ns |
| SBOC | 1475 ns if indirect, +550 ns |
| SBZS | 1275 ns if indirect, +550 ns |
| SBOS | 1375 ns if indirect, +550 ns |
| SBZT | 1375 ns if indirect, +550 ns |
| SBOT | 1475 ns if indirect, +550 ns |
| SETSP | 525 ns |
| REDSP | 525 ns |
| PUSH | 1450 ns |
| POP | 1675 ns |
| PUSHJ | 1850 ns |
| RPUSH | 1850 ns |
| I2PUS | 1850 ns |
| I3PUS | 1850 ns |
| POPJ | 1650 ns |
| NYBSL | $2400 \mathrm{~ns} / \mathrm{word}+300 \mathrm{~ns}$ overhead |
| NYBSR | 2525 ns/word + 100 ns overhead |
| DECAD | 725 ns |
| DECSU | 525 ns |
| CONVE | 678 ns |

Instruction
Execution Time

| XLOAD | 1275 ns |
| :--- | :--- |
| XSTOR | 1175 ns |
| VJSR | 1300 ns |
| GETBY | 1075 ns |
| PUTBY | 1500 ns |
| SGETB | 1075 ns |
| SPUTB | 1500 ns |
| XGETB | 1375 ns |
| XPUTB | 1800 ns |
| XSGET | 1375 ns |
| XSPUT | 1800 ns |
| IGETB | 1700 ns |
| IPUTB | 2325 ns |
| XTRAN | 2150 ns |
| ABINM | 3400 ns |
| BINDI | 8775 ns maximum, 775 ns minumum |
| MOVEW | $1000 \mathrm{~ns} /$ word +275 ns overhead |
| RMOVW | $1000 \mathrm{~ns} /$ word +275 ns overhead |
| TABLS | $875 \mathrm{~ns} /$ word +325 ns overhead |
| * |  |

*The TRACE instruction is not supported by the MARK 9 CPU.

# Appendix H <br> VON NEUMANN CHART OF <br> EXTENDED INSTRUCTIONS 

This appendix applies to the MARK 5 with EIS and MARK 9 only.
KEY:

$$
\begin{aligned}
\text { ACCU } & =\text { Accumulator } & & V=\text { Vector } \\
@ & =\text { Indirect } & & D=\text { Displacement } \\
S & =\text { Sequential } & &
\end{aligned}
$$

$$
\begin{array}{llllllllllllllll}
0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & 10 & 11 & 12 & 13 & 14 & 15
\end{array}
$$

SLEI
SGRI
SEQI
SNEI
LDI
ADI
SBI
CLRB
SETB
TOGB
SBZ
SBO
SBZC
SBOC
SBZS
SBOS
SBZT
SBOT
XTRAN
Rsvd for FPU TRACE*

REDSP
SETSP
POP
PUSH

*TRACE is not supported by the MARK 9 CPU.

|  | 01 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  | 13 |  | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| POPJ | 11 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| PUSHJUMP | 11 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| RPUSHJUMP | 11 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| I2 PUSHJUMP | 11 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| I3PUSHJUMP | 11 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| GETBY | 11 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| [S] PUTBY | 11 | 0 | 0 | 1 | 0 | 1 | S | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| SGETBY | 11 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| X[S] GETBY | 11 | 0 | 1 | 0 | 0 | 0 | S | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| X[S]PUTBY | 11 | 0 | 1 | 0 | 1 | 1 | S | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| XLOAD | 11 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| XSTORE | 11 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| DECADD | 11 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| DECSUB | 11 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| NYBSL | 11 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| NYBSR | 11 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| CONVERT | 11 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| BINMUL | 11 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| BINDIV | 11 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| MOVEWORDS | 11 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| RMOVWORDS | 11 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| TABLSEARCH | 11 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| VJSR | 11 | 0 | V | V | V | V | V | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |
| IGETBY | 11 | 1 | 0 | D | D | D | D | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |
| IPUTBY | 11 | 1 | 1 | D | D | D | D | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |

INDEX

## INDEX

"a" parameter (MANIP) 3-22, D-1
AC IN power supply indicator 2-12, 3-2
accumulator handling E-5
accumulators (ac) 1-17, 3-15, 5-4, 5-6
addressing modes (MANIP) 3-22, D-1
ADI constant 6-6
ALU NO LOAD, NO SKIP instruction 7-29
APL - see automatic program load
APL switch 3-10
architecture 1-9
Arithmetic/Logic instructions 5-3, 5-4, 5-14 thru 5-25
conventions 5-25
execution times 5-38, 5-39, 5-40, 5-41
format 5-14, 5-24
functions 5-20
group 5-14 thru 5-25
Opcode field
ADC (address complement) 5-20
ADD 5-20
AND $5-20$
COM (complement) 5-20
INC (increment) 5-20
MOV (move) 5-20
NEG (negate) 5-20
SUB (subtract) 5-20
operations 5-15, 5-16
overflow and carry-out 5-17 thru 5-19
processing 5-14
secondary control fields
CY (carry) 5-22, 5-24, 5-25
NL (no-load) 5-22, 5-24, 5-25
SH (shift) 5-21, 5-24, 5-25
SK (skip) 5-23, 5-24, 5-25
secondary functions 5-21 thru 5-23
arithmetic/logic unit (ALU) 1-12, $5-14,5-15,5-16,5-17$, $5-18,5-19,5-20,5-21$

ASCII code 4-3, C-1
assembler language conventions/ addressing
arithmetic/logic instructions 5-24 thru 5-25
input/output instructions 5-32 thru 5-33
memory reference instructions 5-12 thru 5-13
AUTO switch (Mini-Panel) 1-15
automatic program load (APL) 1-12,
3-10
on OCU 1-17, 3-11, 3-19
backplane 1-3, 1-4, 2-7
connector mounting positions 2-10
input/output signals 4-16 thru 4-18
reserved pins 2-19
basic arithmetic test instructions E-1, E-2
battery backup unit 1-3, 1-4, 1-17, 1-18, 8-1 thru 8-3
voltage 8-2
battery shelf-life 2-13
bi-directional data bus signals 4-9, 4-10, 4-11
binary multiply and divide
instructions (EIS) 6-20
ABINMULTIPLY 6-20
BINDIVIDE 6-20
binary notation 5-2
binary word format 5-1
bit manipulation and test instructions (EIS) 6-7, 6-8
CLRB mask 6-8
SBO mask 6-8
SBZ mask 6-8
SETB mask 6-8
TOGB mask 6-8
bit test instruction combinations 6-9
SBOC mask 6-9
SBOS mask 6-9
bit test instructions (cont)
SBOT mask 6-9
SBZC mask 6-9
SBZS mask 6-9
SBZT mask 6-9
bit testing E-4
BTRY OK indicator (Mini-Panel) 2-12
Busy flag 4-4, 4-5, 4-10, 5-27, 5-34
byte access instructions 6-17 thru 6-19
cabling, power supply 2-9
carry bit 7-2
carry control field 5-14, 5-21, 5-22
Carry flag 1-15, 3-13, 5-16, 7-6
carry indicator (Mini-Panel) 3-5, 3-9
carry-out 5-16, 5-17 thru 5-19
cassette tape unit 3-21, 3-29
central processor 1-12
channel jumpering 4-6
chassis 1-15, 2-5, 2-6
connector mounting positions 2-10, 2-11
typical configuration 2-8
clear map instruction 7-24
CLRB mask instruction 6-8
code 77 instructions 5-1, 5-34
commands
MANIP 3-21, 3-23 thru 3-29
MFPU 8-6, 8-7
conditional skip instructions 5-37
connectors, chassis
power 4-34, 4-35
external I/O device 4-34, 4-35, 4-36
master terminal 4-37
CONTinue switch (Mini-Panel) 3-10
continuous reliability test
(Self-Test) 2-17
control characters 3-21, 3-29
CONVERT 6-14
CPU 1-3, 1-4, 1-5, 1-12, 1-13
indicators 3-9
Mini-Panel 3-5
program control switches 3-10
special (code 77) instructions 5-34, 5-35 thru 5-36
specifications 1-7
CPU board 1-9, 1-12, 2-7, 3-10, 3-20
jumpers 4-6, 6-2
universal 1-5, 1-12, 2-18, 2-19, 3-4
CSEL instruction 5-16
data channel 1-3, 1-4, 1-20, 2-19 access priorities 4-7
activity 1-17
control signals 4-9, 4-10, 4-14 thru 4-15
direct memory access (DMA) 3-10, 4-6
high-speed 1-3, 1-4, 1-20, 2-19, 4-6
jumpering 1-20, 2-19
priorities on Universal CPU 2-19
speed selection 4-7
standard-speed 1-3, 1-4, 1-20, 4-6
to set on Universal CPU 2-19
transfer timing 4-27 thru 4-33
transfers 4-6 thru 4-7 execution times 5-38, 5-39, 5-40, 5-41
data in
instruction 4-19
signals 4-19
data out
instruction 4-19
signals 4-19
DECADD 6-13
decrementing locations 5-9
DECSUB 6-14
device code signals 4-9, 4-10, 4-11
device control
instructions 5-28
signals 4-9, 4-10, 4-12
device interrupt processing 7-12
DIA instruction 4-5
DIA $f$ ac MAP 7-13, 7-20
DIA $f$ ac MAP1 7-13, 7-18
diagnostic 2-14
DIB instruction 7-5
DIBC instruction 7-5
DIC instruction 7-6, 7-13
DIC ac MAP 7-27
DICC instruction 7-10
Direct memory access (DMA) 3-10, 4-6
DOA instruction 7-8
DOA $f$ ac MAP 7-22
DOA $f$ ac MAP1 7-13, 7-16
DOAC 7-9
DOB $f$ ac Map 7-13, 7-14
DOC 7-13
DOC ac MAP 7-25
DOCP 7-2
DOCS 7-2
Done flag 4-4, 4-5, 4-10, 5-27, 5-34, 8-3

```
Effective Address Register 1-12, 5-6,
    5-7, 5-8, 5-9, 5-10, 5-11
equipment specifications
    electrical 1-8
    environmental 1-8
    MARK 5 CPU 1-7
    MARK }9\mathrm{ CPU 1-7
    mechanical 1-8
Extended Instruction Set 1-1, 1-3,
        1-4, 5-35, 6-1 thru 6-23,
        H-1 thru H-2
    binary multiply & divide
        instructions 6-20
        ABINMULTIPLY 6-20
        BINDIVIDE 6-20
    bit manipulation & test
        instructions 6-7, 6-8
    bit test instruction combinations
        6-9
    byte access instructions 6-17
        thru 6-19
        GETBYTE 6-18
        IGETBYTE 6-18
        IPUTBYTE 6-19
        PUTBYTE 6-18
        SGETBYTE 6-18
        SPUTBYTE 6-18
        XGETBYTE 6-18
        XPUTBYTE 6-18
        XSGETBYTE 6-18
        XSPUTBYTE 6-18
        XTRANSLATE 6-19
    chart H-1 thru H-2
    enabling 6-2
    execution times G-1 thru G-4
    extended load and store
        instructions 6-15
    XLOAD 6-15
    XSTORE 6-15
disabling 6-2
implementing 6-3
immediate compare instructions
        6-5
    SEQI constant 6-5
    SGRI constant 6-5
    SLEI constant 6-5
    SNEI constant 6-5
move and search instructions 6-21
        thru 6-22
    MOVEWORDS 6-21
    RMOVWORDS 6-21
    TABLSEARCH 6-22
nybble manipulation instructions
        6-13 thru 6-14
```

    CONVERT 6-14
    flags (cont)
Interrupt On (ION) 3-13, 4-2, 5-35, 5-36, 5-37, 7-3
Interrupt Request 4-2
Power Fail 5-36, 5-37
stack overflow 7-3
floating point binary arithmetic unit 8-5
frame pointer
move from 7-9
move to 7-8
front panel 1-9, 1-15, 1-17
installation 2-5
OCU attachment to 2-20 thru 2-21
operation (see MANIP) 3-20 thru 3-29
fuse 2-12
get byte instructions 6-17, 6-18
grounding 2-13
halt instruction 5-36
hamming error code circuitry 1-4
high-speed data channel 1-3, 1-4, 1-20, 2-19, 4-6

IGETBYTE 6-18
immediate compare instructions (EIS) 6-5
SEQI constant 6-5
SGRI constant 6-5
SLEI constant 6-5
SNEI constant 6-5
incrementing locations 5-9
indexing mode 5-6, 5-7
initiate page check instruction 7-16 thru 7-17
input/output
backplane connectors 4-16
bus 4-7, 4-27, 5-3, 5-27
data channel 1-20, 4-7 interface signals 4-8 thru 4-18
signal classifications 4-9
signal diagram 4-10
signal names, descriptions
4-11 thru 4-15
connectors 4-34, 4-35
pin assignments 4-36 master terminal 4-37
device 1-20, 3-18
interface 4-1 thru 4-37
signals 4-17, 4-18
input/output (cont)
timing 4-19 thru 4-33
data channel transfer 4-27
standard 4-28 thru 4-30
high-speed 4-31 thru 4-33
programmed interrupt 4-23 thru 4-26
programmed I/O instruction
4-19 thru 4-22
Input/Output instructions 5-3, 5-4, 5-26 thru 5-37
16-bit data transfer 5-26
assembler language conventions 5-37
conditional skip instruction 5-37
control field 5-27, 5-30
control functions 5-27
pulses 5-30
device flags 5-27
conventions 5-33
example 5-32
execution times 5-38 thru 5-41
OPCODE 5-28, 5-29
skip 5-26, 5-31, 5-32
SKPBN 5-31, 5-33
SKPBZ 5-31, 5-33
SKPDN 5-31, 5-33
SKPDZ 5-31, 5-33
special code 77 (CPU) instructions 5-34, 5-35
timing 4-19 thru 4-22
transfer 5-26, 5-28, 5-29, 5-30
DIA 5-29, 5-33
DIB 5-29, 5-33
DIC 5-29, 5-33
DOA 5-29, 5-33
DOB 5-29, 5-33
DOC 5-29, 5-33
NIO 5-29, 5-33
installation 2-1 thru 2-22
battery shelf-life 2-13
chassis 2-5, 2-6, 2-9
front panel 2-5
grounding 2-13
mounting $2-5$
Operator Control Unit 2-20, 2-21
powering up 2-12
printed circuit boards 2-7
requirements 2-1
enclosure 2-1
environmental 2-1
power 2-1
temperature 2-1
universal CPU board 2-18

```
installation (cont)
    unpacking 2-2 thru 2-4
        cartons 2-2
        container contents 2-2
instruction
    execution times 5-38 thru 5-41
        MARK 5 5-39
        MARK 5 with EIS 5-40
        MARK 9 5-41
    format 4-4, 5-3 thru 5-4
        summary 5-4
    register 1-12
instructions
    Arithmetic/Logic instructions
        5-14 thru 5-25
    basic arithmetic test E-1, E-2
    binary multiply and divide 6-20
    bit manipulation and test 6-7, 6-8
    bit test instruction combinations
        6-9
    byte access 6-17 thru 6-19
    clear map 7-24
    code 77 5-1, 5-34
    conditional skip 5-37
    data in 4-19
    data out 4-19
    device control 5-28
    Extended Instruction Set Sec 6
    extended load 6-15
    extended store 6-15
    get byte 6-17, 6-18
    halt 5-36
    immediate compare 6-5
    initiate page check 7-16, 7-17
    Input/Output instructions 5-26
        thru 5-37
    interrupt acknowledge 4-2
    jump 5-5, 5-11
    map single cycle 7-24
    mapped memory 7-13 thru 7-28
    MARK 9-Exclusive instructions
        Sec }
    Memory Reference 5-4, 5-5 thru
        5-13
    modify memory 5-5, 5-11, 5-12
    move 6-21
    move data 5-5, 5-10
    move and search 6-21, 6-22
    move from frame pointer 7-9
    move from stack pointer 7-9
    move to frame pointer 7-8
    move to stack pointer 7-8
    no-op skip 6-1
    nybble manipulation 6-13 thru
        6-14
```

```
LED indicators (cont)
    APL switch 3-4
    BTRY OK 3-8
    CARRY indicator 3-4, 3-9
    CONTinue switch 3-4, 3-13
    DATA 3-14, 3-15, 3-18
    memory error indicator (MEM ERR)
        3-4, 3-9
    parity error indicator (PARR ERR)
        3-4, 3-9, 3-13
    POWER OK 3-7, 3-8
    RUN indicator 3-4
    STOP switch 3-4, 3-10, 3-18
load accumulator instruction 5-10,
    5-13
load map instruction 7-14 thru 7-15
load map memory from main memory
                instruction 7-25 thru 7-26
load main memory from map memory
            instruction 7-27 thru 7-28
MANIP 1-15, 3-10, 3-20 thru 3-29
    addressing modes 3-22, D-1
    command descriptions 3-23 thru
        3-29
    command functions, parameters
        3-21, D-1 thru D-2
map single cycle 7-24
mapped memory 1-4, 7-12
    instructions 7-13 thru 7-28
MARK 5
    architecture 1-9 thru 1-20
    CPU/memory 1-12
        block diagram 1-13
    features 1-3
    models 1-5
    options 1-6
    specifications 1-7, 1-8
MARK }
    architecture 1-9 thru 1-20
    CPU/memory 1-12
        block diagram 1-13
    features 1-4
    models 1-5
    options 1-6
    specifications 1-7, 1-8
MARK 9-Exclusive Instructions Sec 7
    clear map 7-24
    initiate page check 7-16, 7-17
    load map 7-14 thru 7-15
    load map memory from main memory
        7-25 thru 7-26
    load main memory from map memory
        7-27 thru 7-28
```

most significant bit (MSB) 4-3, 5-1, 5-21, 6-2
move data instructions 5-5, 5-10
LDA 5-5, 5-10, 5-12, 5-13
STA 5-5, 5-10, 5-13
move and search instructions 6-21
MOVEWORDS 6-21
RMOVWORDS 6-21
TABLSEARCH 6-22
move from frame pointer 7-9
move from stack pointer 7-9
move to frame pointer 7-8
move to stack pointer 7-8
MOVEWORDS instruction 6-21
MSKO instruction 4-2, 5-35
new registers, instructions for 6-11 thru 6-12
NIO 7-8
NIOC 7-9, 7-13
NIOC MAP1 7-24
NIOP 6-2, 7-13
NIOP MAP 7-24
no-load field 5-21, 5-22
no-op skip instruction 6-1
NOP skip command format 6-3
number testing $\mathrm{E}-1$
nybble manipulation instructions 6-13 thru 6-14
NYBSL 6-13
NYBSR 6-13
octal display 3-14
octal notation 5-2
OCU - see Operator Control Unit
OPCODE field 5-26, 5-28, 5-29, 5-31
operand addressing 8-7
operating procedures 3-1
Operator Control Unit (OCU) 1-3, 1-4, 1-16 thru 1-17, 3-1, 3-11 thru 3-19, 5-35, 8-1, 8-4
accumulator access controls 3-17
capabilities 3-11
controls and indicators 3-11 thru 3-13
displays 3-14
front panel attachment 2-20, 2-21
installation 2-20, 2-21
memory access controls 3-15, 3-16
program execution controls 3-18 thru 3-19
ribbon cable attachment 2-20, 2-22
options
Main Memory Battery Backup 1-3, 1-4, 1-17, 1-18, 8-1 thru 8-3
Operator Control Unit 1-6, 8-4
options, MARK 5 only
Extended Instruction Set (EIS) 1-6
Main Memory Parity Error Halt 1-6
Micro-Programmed Floating Point Unit 1-6, 8-1, 8-5 thru 8-8
Voltage Regulator 1-6, 8-4
options, MARK 9 only
256KW memory 1-6
other immediate operations (EIS) 6-6
ADI constant 6-6
LDI constant 6-6
SBI constant 6-6
overflow condition (MFPU) 8-8
page check instruction 7-18, 7-19 initiate 7-16
page zero locations (EIS) 6-4
paper tape 4-5
PAR ERR indicator (Mini-Panel) 3-9
parity error
generation/checking E-6
halt 1-6
peripherals
card punch 1-5
card reader 1-5
cartridge disk 1-5
cassette 1-5
character printer 1-5
disk pack drive 1-5
diskette 1-5
fixed-head diskette 1-5
line printer 1-5
magnetic tape unit 1-5
paper tape punch 1-5
paper tape reader 1-5, 4-3, 4-5
plotter 1-5
printing terminals 1-5
Teletype 1-5, 4-3, 4-4
video display terminals 1-5
pop accumulator 7-5
power connectors 4-34, 4-35
power controls 3-6
power fail
flag 5-36, 5-37
interrupt 8-3
power indicator interpretations
with battery backup 3-8
without battery backup 3-7

POWER OK indicator (Mini-Panel) 2-12 power supply
block diagram 1-19
cabling 2-9
indicator panel 3-1, 3-2 description 3-3
module 1-17
voltages 1-17 thru 1-18
power up 2-12
printed circuit boards 2-7
priority, device 4-2
processor
chassis $1-15,2-12,3-7$
manipulation controls 3-15
Mini-Panel 3-1, 3-4, 3-5, 3-6
thru 3-10
APL switch 3-10
CONT switch 3-10
monitoring indicators 3-9
operating functions 3-4
power control 3-6
power indicators 3-7, 3-8
STOP switch 3-10
mounting 2-5
program
counter 1 -12, 3-10, 3-14, 3-18, 3-20
execution controls 3-4, 3-9, 3-10
interrupt and priority scheme 4-1
interrupt sequence 4-2
device priority 4-2
interrupt timing 4-23 thru 4-26
programmed
data transfer signals 4-9, 4-10, 4-11
I/O instruction timing 4-19 thru 4-22
transfers 4-3
programming
conventions 4-4 thru 4-5
examples App E
instruction formats 4-4
terminal input via
CRT 4-5
paper tape 4-5
terminal output 4-4
PROM 1-12, 2-14, 3-10, 3-19, 3-20
automatic program load (APL) 1-12
self-test 1-12
push accumulator 7-5
put byte instructions 6-17, 6-18
random access memory (RAM) 1-1, 1-3, 1-4, 1-9, 1-12, 3-20
read map status instruction $7-20$, 7-21
READS ac, CPU instruction 3-15, 5-35 reliability test $2-17$
requirements, installation 2-1
return instruction 7-10
RMOVWORDS 6-21
RUN indicator (Mini-Panel) 3-9
save 7-6, 7-7
SBI constant 6-6
SBO mask instruction 6-8
SBOC mask instruction 6-9
SBOS mask instruction 6-9
SBZ mask instruction 6-8
SBZC mask instruction 6-9
SBZS mask instruction 6-9
SBZT mask instruction 6-9
search instructions 6-21, 6-23
Self-Test 1-3, 1-4, 3-10, 3-19, 4-16 continuous reliability test 2-17 halt interpretation 2-17 operation 2-15
STSEL- 4-16
switch location 2-16
tests 2-14
SEQI constant 6-5
set instructions 6-7, 6-9
SETB mask instruction 6-8
SGETBYTE 6-18
SGRI constant 6-5
shift field 5-21
signals, I/O bus 4-8 thru 4-15
skip field 5-21, 5-23
skip instructions 5-34, 5-37, 6-3
skip testing flags 4-9, 4-10, 4-12
SLEI constant 6-5
SNEI constant 6-5
special code 77 (CPU) instructions 5-34 thru 5-36
specifications, equipment electrical 1-8 environmental 1-8
MARK 5 CPU 1-7
MARK 9 CPU 1-7
mechanical 1-8
SPUTBYTE 6-18
STA instruction 5-5, 5-10, 5-13
stack, MARK 9-exclusive
instructions
Move to Frame Pointer 7-8
Move to Stack Pointer 7-8
Move from Frame Pointer 7-9
Move from Stack Pointer 7-9
Pop accumulator 7-5

```
stack - MARK 9-exclusive (cont)
    instructions (cont)
        Push accumulator 7-5
        Return 7-10
        Save 7-6
        Stack Return Block Destination
            7-6, 7-7
        operation 7-3
        Overflow flag 7-3
stack, POINT 4 EIS 6-10 thru 6-12
    base (SB) pointer 6-10
    fault (SF) vector 6-10
    frame pointer (FP) 6-10
    instructions
            I2PUSHJUMP 6-12
            I3PUSHJUMP 6-12
            POP 6-11
            POPJUMP 6-12
            PUSH 6-11
            PUSHJUMP 6-11
            REDSP 6-11
            RPUSHJUMP 6-12
            SETSP 6-11
    limit (SL) pointer 6-10
Standard Instruction Set 5-1 thru
                5-41, 6-1, 6-3, A-1, B-1
STANDBY switch (Mini-Panel) 1-15,
                2-12
STOP switch (Mini-Panel) 3-10
store accumulator instruction 5-10,
                5-13
STSEL- 4-16
SUB instruction 6-6
SYMBOLS file 6-1
system
    architecture 1-9
    block diagram 1-11
    CPU elements 1-12
    CPU features 1-12
    functional units 1-9
    typical configuration 1-10
```


## COMMENT SHEET

MANUAL TITLE POINT 4 MARK 5/9 Computer Reference Manual
PUBLICATION NO._HM=085-0023 REVISION_ 01
FROM: NAME/COMPANY:
BUSINESS ADDRESS: $\qquad$
CITY/STATE/ZIP:
COMMENTS: Your evaluation of this manual will be appreciated by POINT 4 Data Corporation. Notation of any errors, suggested additions or deletions, or general comments may be made below. Please include page number references where appropriate.

# BUSINESS REPLY MAIL 

FIRST CLASS PERMIT NO. 1458 TUSTIN, CA
POSTAGE WILL BE PAID BY ADDRESSEE

## POINT 4 Data Corporation PUBLICATIONS DEPARTMENT <br> 15442 Del Amo Avenue <br> Tustin, CA 92680

NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES $\square=\square$



15442 Del Amo Avenue
Tustin, CA 92680
(714) 259-0777


[^0]:    *U.S. Patent No. $4,370,729$

[^1]:    *Nova is a trademark of Data General Corporation

[^2]:    *Not used by MARK 9 CPU. MARK 5 CPUs use this voltage.
    **Not used in POINT 4 chassis. Used in non-POINT 4 chassis as a timing signal.

[^3]:    *Not used by MARK 9 CPUs.

[^4]:    *For those who are familiar with POINT 4 Data Corporation's IRIS Operating System, MANIP is comparable to DBUG. The main differences are that MANIP does not have (l) symbolic capability, (2) breakpoints or trace, (3) disk read or write, and (4) CTRL-H/ CTRL-A (backspace) capability. MANIP occupies only 1000 (octal) words of memory, while DBUG occupies 3400 (octal) words of memory.

[^5]:    RQENB $-=$ REQUEST ENABLE: PROVIDES A CLOCK SIGNAL TO SYNCHRONIZE INTERRUPT REQUESTS (AS WELL AS DATA CHANNEL REQUESTS) FROM PERIPHERAL CONTROLLERS. ITS NOMINAL PERIOD IS 400ns (200ns OFF, 200ns ON). CONTROLLERS MAY CHANGE INTR (INTERRUPT REQUEST) OR DCHR- (DATA CHANNEL REQUEST) ONLY AT THE LEADING EDGE OF RQENB-.

    INTR = INTERRUPT REQUEST: SENSED BY CPU ABOUT 100ns BEFORE THE END OF EACH INSTRUCTION. IF INTR IS PRESENT, THE NEXT THREE MEMORY CYCLES ( 1200 ns ) ARE TAKEN TO SAVE PC IN LOCATION O AND TO JUMP TO THE INTERRUPT SERVICE ROUTINE WHOSE ADDRESS IS IN LOCATION 1.

[^6]:    *Battery recharging after a discharge causes the LED indicators to blink.

[^7]:    *The TRACE instruction is not supported by the MARK 9 CPU.

